亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fft.c

?? 使用Ti提供的支持庫(kù)編寫的1024、2048或4096點(diǎn)FFT
?? C
字號(hào):
/***********************************************************
*
* FFT library. SWUST, rhodesn@163.com
* MAX point is 4096 dot
* 2006-06-24
************************************************************/

#define PI 3.14159265358979

#include <math.h>
#include <string.h>
#include <dsp_radix2.h>
#include <dsp_bitrev_cplx.h>
#include "fft.h"
/*global functions*/

void digitrev_index(short *index, int n,int radix);
void gen_twiddle(short *w, int n, double scale);

/*global vars*/
#pragma DATA_SECTION(g_DSPFFTData,".dsp_fft_sect")
#pragma DATA_ALIGN(g_DSPFFTData,8)
static unsigned char g_DSPFFTData[40960+128];

#pragma DATA_ALIGN(g_x1,8)
short *g_x1;
//#pragma DATA_ALIGN(g_x2,8)
//int *g_x2;
#pragma DATA_ALIGN(g_window,8)
short *g_window;
#pragma DATA_ALIGN(g_index,8)
short *g_index;

/*
static short g_index[64];
static short g_window[numlength];
static short g_x1[numlength*2];
static int   g_x2[numlength];
*/

static int radix;
int nx1;

/*
	initializing the DSP_FFT functions, generate the table and index for FFT useing
	DotNumber: 1024/2048/4096... 2' power
	iRadix   : 2
*/
void DSP_FFT_init(int DotNumber,int iRadix)
{
	double scale;
	scale = 32767.5;
	radix = iRadix;
	nx1	  = DotNumber;
	
	memset(g_DSPFFTData,0,40960+128);
	g_x1 = (short *)g_DSPFFTData;
//	g_x2 = (int *)(g_x1+2*DotNumber);
	g_window = (short *)(g_x1+2*DotNumber);
	g_index = (short *)(g_window+DotNumber);

	/*init the index for fft bitrev*/
	digitrev_index(g_index,nx1,radix);
	/*init the fft coefficients*/
	gen_twiddle(g_window,nx1,scale);

}

/*
	test FFT algorithm. three kinds of frequency.
	and result of FFT is R0 I0, R1 I1,.....
*/
void DSP_FFT_test(short *OutData)
{
	int i;
	
	/*構(gòu)造要做FFT的序列,按實(shí)部0、虛部0,實(shí)部1、虛部1...序列構(gòu)造*/
	for (i=0; i<nx1; i++){
		g_x1[2*i]=(short)((cos(PI*i/5.0)+cos(PI*i/10.0)+cos(PI*i/20.0))*128);//
		g_x1[2*i+1]=0;
	}
	/*FFT algorithm*/
	DSP_radix2(nx1,g_x1,g_window);
	DSP_bitrev_cplx((int *)g_x1, g_index, nx1);
	
	memcpy((void *)OutData,(void *)g_x1,nx1*4);
	
	//calculate the magnitude of FFT
/*
	for (i=0;i<nx1; i++)
		//g_x2[i]=sqrt(g_x1[2*i]*g_x1[2*i]+g_x1[2*i+1]*g_x1[2*i+1]);
		g_x2[i] = sqrt(OutData[2*i]*OutData[2*i]+OutData[2*i+1]*OutData[2*i+1]);
*/
	
}

/*
	FFT core. 
	input : AudioData: real data, counter is DotNumber
	output: FftData  : magnitude of FFT, sqrt(R*R+I*I)
*/
void DSP_FFT_core(short *AudioData,short *FftData)
{
	int i;
	/*construct the sequence of input data*/
#pragma MUST_ITERATE(1024,,2)	
	for (i=0; i<nx1; i++)
	{
		g_x1[2*i] = AudioData[i];
		g_x1[2*i+1]=0;
	}
	/*radix 2 of fft*/
	DSP_radix2(nx1,g_x1,g_window);
	/*bit reversal of complex*/
	DSP_bitrev_cplx((int *)g_x1, g_index, nx1);
	
	memcpy((void *)FftData,(void *)g_x1,nx1*4);
	
/*	
	for (i=0;i<nx1; i++){
		g_x2[i]=sqrt(g_x1[2*i]*g_x1[2*i]+g_x1[2*i+1]*g_x1[2*i+1]);
	}
*/	
}

void digitrev_index(short *index, int n,int radix)              
{                                                                   
    int   i, j, k;//, radix = 2;                                                  
    short nbits, nbot, ntop, ndiff, n2, raddiv2;                    
                                                                    
    nbits = 0;                                                      
    i = n;                                                          
    while (i > 1)                                                   
    {                                                               
        i = i >> 1;                                                 
        nbits++;                                                    
    }                                                               
                                                                    
    raddiv2 = radix >> 1;                                           
    nbot    = nbits >> raddiv2;                                     
    nbot    = nbot << raddiv2 - 1;                                  
    ndiff   = nbits & raddiv2;                                      
    ntop    = nbot + ndiff;                                         
    n2      = 1 << ntop;                                            
                                                                    
    index[0] = 0;                                                   
    for ( i = 1, j = n2/radix + 1; i < n2 - 1; i++)                 
    {                                                               
        index[i] = j - 1;                                           
                                                                    
        for (k = n2/radix; k*(radix-1) < j; k /= radix)             
            j -= k*(radix-1);                                       
                                                                    
        j += k;                                                     
    }                                                               
    index[n2 - 1] = n2 - 1;                                         
} 

/* ======================================================================== */
/*  D2S -- Truncate a 'double' to a 'short', with clamping.                 */
/* ======================================================================== */
static short d2s(double d)
{
    if (d >=  32767.0) return  32767;
    if (d <= -32768.0) return -32768;
    return (short)d;
}
    
void gen_twiddle(short *w, int n, double scale)
{
    double angle, step;
    int i;

    step = (2.0 * PI) / (double)n;
    for (i = 0, angle = 0.0; i < n; i += 2, angle += step)
    {
        w[i + 0] = d2s(scale * -cos(angle));
        w[i + 1] = d2s(scale * -sin(angle));
    }

    return ;
}                                                                                           

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久国产综合精品麻豆| 久久久99精品免费观看| 91亚洲精品一区二区乱码| 国产成人精品综合在线观看| 国产在线不卡一卡二卡三卡四卡| 美腿丝袜亚洲色图| 日本在线播放一区二区三区| 日韩vs国产vs欧美| 老鸭窝一区二区久久精品| 狠狠色综合色综合网络| 国产综合久久久久久鬼色 | jizzjizzjizz欧美| 成人免费的视频| 91在线精品秘密一区二区| 在线欧美日韩国产| 欧美狂野另类xxxxoooo| 日韩一区二区三区免费看| 欧美精品一区二区三区久久久| 久久久91精品国产一区二区三区| 国产女人aaa级久久久级| 国产精品视频观看| 亚洲精品成人少妇| 婷婷六月综合网| 麻豆精品视频在线观看视频| 狠狠狠色丁香婷婷综合久久五月| 国产成a人亚洲| 在线视频你懂得一区二区三区| 欧美日韩国产首页在线观看| 精品国产乱码久久久久久免费 | 久久精品视频在线看| 国产精品久久久久精k8| 亚洲香肠在线观看| 秋霞午夜av一区二区三区| 国产传媒久久文化传媒| 一本高清dvd不卡在线观看| 91精品国产欧美一区二区18| 久久精品综合网| 伊人色综合久久天天人手人婷| 免费人成网站在线观看欧美高清| 国产成人在线视频网站| 欧美色综合网站| 26uuu精品一区二区| 亚洲精品中文字幕在线观看| 麻豆视频观看网址久久| 成人a区在线观看| 制服丝袜国产精品| 日本一区二区综合亚洲| 亚洲成人在线免费| 风间由美一区二区三区在线观看 | 日韩一区二区在线观看视频| 国产亚洲成av人在线观看导航| 亚洲美女精品一区| 韩国av一区二区三区在线观看| 91污在线观看| 久久综合av免费| 亚洲福利电影网| 成人爱爱电影网址| 日韩欧美自拍偷拍| 一区二区三区四区中文字幕| 国产一区二区免费在线| 91国产成人在线| 国产拍揄自揄精品视频麻豆| 婷婷久久综合九色综合伊人色| 成人av高清在线| 久久综合丝袜日本网| 婷婷一区二区三区| 91久久精品一区二区三| 国产日韩欧美制服另类| 麻豆精品一区二区综合av| 欧美亚洲动漫精品| 国产精品第四页| 国产在线播放一区三区四| 亚洲精品你懂的| 丰满放荡岳乱妇91ww| 日韩精品一区二区在线| 一区二区三区四区高清精品免费观看| 国产成人精品亚洲日本在线桃色| 欧美福利电影网| 一区二区三区不卡在线观看| 国产ts人妖一区二区| 欧美精品一区二区在线观看| 欧美二区三区的天堂| 亚洲乱码国产乱码精品精小说| 国内成+人亚洲+欧美+综合在线 | 午夜精品福利久久久| 91色|porny| 国产精品国产精品国产专区不蜜 | 日韩一级高清毛片| 亚洲国产精品久久人人爱| 色猫猫国产区一区二在线视频| 日本一二三不卡| 国产精品亚洲一区二区三区在线 | 91精品国产色综合久久不卡蜜臀 | 黄色小说综合网站| 欧美电影免费观看高清完整版 | 麻豆91在线观看| 91精品国产综合久久精品| 性做久久久久久免费观看| 在线欧美日韩精品| 亚洲综合在线视频| 在线观看国产一区二区| 亚洲综合色噜噜狠狠| 在线看国产一区二区| 一区二区三区四区视频精品免费 | 麻豆精品在线看| 欧美日韩国产影片| 日韩电影在线一区| 日韩欧美区一区二| 国精产品一区一区三区mba视频| 欧美精品一区二区三区四区| 国产精品香蕉一区二区三区| 欧美v日韩v国产v| 国产在线不卡一区| 国产精品天美传媒| 9i在线看片成人免费| 亚洲精品日产精品乱码不卡| 欧美主播一区二区三区| 肉肉av福利一精品导航| 欧美一级黄色片| 国产又黄又大久久| 国产精品美女视频| 色一区在线观看| 三级不卡在线观看| 久久综合国产精品| 99re8在线精品视频免费播放| 成人免费小视频| 欧美日韩国产另类不卡| 免费高清视频精品| 欧美激情一区三区| 91国偷自产一区二区三区观看| 日韩经典一区二区| 久久久精品影视| 色香色香欲天天天影视综合网| 爽好久久久欧美精品| 久久久久久电影| 在线观看精品一区| 经典一区二区三区| 国产精品毛片a∨一区二区三区| 日本丰满少妇一区二区三区| 美女精品自拍一二三四| 中文字幕乱码亚洲精品一区| 欧洲一区在线电影| 国产在线播精品第三| 亚洲男女一区二区三区| 欧美va亚洲va国产综合| 99久免费精品视频在线观看| 午夜精品久久久久久久| 久久久国产一区二区三区四区小说 | 国产精华液一区二区三区| 亚洲欧美精品午睡沙发| 日韩免费一区二区三区在线播放| av电影在线观看不卡 | 欧美一区二区视频网站| 成人黄色777网| 日韩电影在线免费观看| 中文字幕高清一区| 欧美一区二区三区四区在线观看| 丁香六月久久综合狠狠色| 午夜精品福利久久久| 国产精品美女www爽爽爽| 制服视频三区第一页精品| www..com久久爱| 国产综合成人久久大片91| 亚洲国产一二三| 国产精品国产三级国产专播品爱网 | 欧美久久久久久久久久| 成人aaaa免费全部观看| 麻豆国产一区二区| 亚洲成人一区在线| 粉嫩高潮美女一区二区三区| 青青草国产成人av片免费| 亚洲精品菠萝久久久久久久| 久久综合狠狠综合| 91精品国产一区二区三区| 91丨porny丨蝌蚪视频| 国产在线不卡视频| 免费人成精品欧美精品| 亚洲在线视频免费观看| 国产精品成人免费精品自在线观看| 日韩免费看网站| 欧美精品丝袜中出| 一本大道av一区二区在线播放| 国产iv一区二区三区| 国产综合成人久久大片91| 日本欧美一区二区| 午夜在线电影亚洲一区| 亚洲激情综合网| 亚洲欧洲国产日韩| 欧美高清在线视频| 久久无码av三级| 亚洲精品在线免费观看视频| 这里只有精品免费| 欧美日韩国产另类一区| 欧美色倩网站大全免费| 日本韩国视频一区二区| 一本到三区不卡视频| 91蜜桃在线观看| 色视频欧美一区二区三区| 99久久精品国产一区二区三区| 成人精品小蝌蚪|