Microchip® Advanced Software Framework

vect_dsp16_convpart.c File Reference
#include "dsp.h"
#include "preprocessor.h"

Macros

#define DSP16_CONVPART_KERNEL_X_FCT(x_num, data)
 
#define DSP16_SUM_ITEM(x, line)   sum += pvect2[x]*pvect3[8 - x - 1];
 
#define DSP16_SUM_ITEM_INIT(x, line)   sum += *pvect2++**--pvect3;
 

Functions

void dsp16_vect_convpart (dsp16_t *vect1, dsp16_t *vect2, int vect2_size, dsp16_t *vect3, int vect3_size)
 16-bit fixed point version of the Partial Convolution. More...
 

#define DSP16_CONVPART_KERNEL_X_FCT (   x_num,
  data 
)
Value:
static void TPASTE2(dsp16_vect_convpart_kernel_x, x_num)(dsp16_t *vect1, dsp16_t *vect2, int vect1_size, dsp16_t *vect3, int vect3_size) \
{ \
int i, j; \
dsp32_t sum; \
dsp16_t *pvect3, *pvect2; \
for(j=0; j<vect1_size; j++) \
{ \
sum = 0; \
pvect3 = &vect3[vect3_size]; \
pvect2 = &vect2[j]; \
for(i=x_num; i<vect3_size; i += 8) \
{ \
pvect3 -= 8; \
pvect2 += 8; \
} \
vect1[j] = sum >> DSP16_QB; \
} \
}
#define DSP16_SUM_ITEM_INIT(x, line)
Definition: vect_dsp16_convpart.c:50
int i
Definition: jcmarker.c:150
A_ALIGNED dsp32_t vect3[VECT3_SIZE]
Second input signal.
Definition: dsp32_convolution/convolution_example.c:157
#define DSP16_SUM_ITEM(x, line)
Definition: vect_dsp16_convpart.c:48
dsp32_t__ dsp32_t
32-bit signed fixed point type optimized for 32-bit or lower microcontrollers
Definition: dsp_types.h:201
dsp16_t__ dsp16_t
16-bit signed fixed point type optimized for 32-bit or lower microcontrollers
Definition: dsp_types.h:192
A_ALIGNED dsp32_t vect1[VECT2_SIZE+2 *(VECT3_SIZE-1)+4]
The output buffer.
Definition: dsp32_convolution/convolution_example.c:86
A_ALIGNED dsp32_t vect2[VECT2_SIZE]
First input signal.
Definition: dsp32_convolution/convolution_example.c:89
#define DSP16_QB
number of fractional bits
Definition: dsp_types.h:137
int j
Definition: jquant1.c:193
#define MREPEAT8(macro, data)
Definition: mrepeat.h:77
#define TPASTE2(a, b)
Definition: tpaste.h:61
MREPEAT(AVR32_INTC_NUM_INT_GRPS, DECL_INT_LINE_HANDLER_TABLE,~)
for(i=0;i< DCTSIZE2;i++)
Definition: jcmarker.c:156
#define DSP16_SUM_ITEM (   x,
  line 
)    sum += pvect2[x]*pvect3[8 - x - 1];
#define DSP16_SUM_ITEM_INIT (   x,
  line 
)    sum += *pvect2++**--pvect3;