beautypg.com

Texas Instruments TMS320C64X User Manual

Page 141

background image

DSP_fft16x16t

4-113

C64x+ DSPLIB Reference

/* y0i = x0i + x2i + x1i + x3i = xh1 + xh21 */

/* y1r = x0r − x2r + (x1i − x3i) = xl0 + xl21 */

/* y1i = x0i − x2i − (x1r − x3r) = xl1 − xl20 */

/* y2r = x0r + x2r − (x1r + x3r) = xh0 − xh20 */

/* y2i = x0i + x2i − (x1i + x3i = xh1 − xh21 */

/* y3r = x0r − x2r − (x1i − x3i) = xl0 − xl21 */

/* y3i = x0i − x2i + (x1r − x3r) = xl1 + xl20 */

/* −−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−*/

y0r = xh0_0 + xh20_0; y0i = xh1_0 + xh21_0;

y4r = xh0_1 + xh20_1; y4i = xh1_1 + xh21_1;

xt0_0 = xh0_0 − xh20_0; yt0_0 = xh1_0 − xh21_0;

xt0_1 = xh0_1 − xh20_1; yt0_1 = xh1_1 − xh21_1;

xt1_0 = xl0_0 + xl21_0; yt2_0 = xl1_0 + xl20_0;

xt2_0 = xl0_0 − xl21_0; yt1_0 = xl1_0 − xl20_0;

xt1_1 = xl0_1 + xl21_1; yt2_1 = xl1_1 + xl20_1;

xt2_1 = xl0_1 − xl21_1; yt1_1 = xl1_1 − xl20_1;

/*−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−*/

/* Store out first output, of the four outputs of a radix4 */

/* butterfly. Since two such radix4 butterflies are per− */

/* formed in parallel, there are 2 such 1st outputs. */

/*−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−*/

x2[0] = y0r; x2[1] = y0i;

x2[2] = y4r; x2[3] = y4i;

/*−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−*/

/* Perform twiddle factor multiplies of three terms,top */

/* term does not have any multiplies. Note the twiddle */

/* factors for a normal FFT are C + j (−S). Since the */

/* factors that are stored are C + j S, this is */

/* corrected for in the multiplies. */

/* */

/* Y1 = (xt1 + jyt1) (c + js) = (xc + ys) + (yc −xs) */

/* Perform the multiplies using 16 by 32 multiply macro */

/* defined. This treats the twiddle factor as 16 bits */

/* and incoming data as 32 bits. */

/*−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−*/

x2[h2 ] = (si10 * yt1_0 + co10 * xt1_0) >> 15;