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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fft.cpp

?? fft源程序
?? CPP
字號:
/**********************************************************************  FFT.cpp  Dominic Mazzoni  September 2000  This file contains a few FFT routines, including a real-FFT  routine that is almost twice as fast as a normal complex FFT,  and a power spectrum routine when you know you don't care  about phase information.  Some of this code was based on a free implementation of an FFT  by Don Cross, available on the web at:    http://www.intersrv.com/~dcross/fft.html  The basic algorithm for his code was based on Numerican Recipes  in Fortran.  I optimized his code further by reducing array  accesses, caching the bit reversal table, and eliminating  float-to-double conversions, and I added the routines to  calculate a real FFT and a real power spectrum.**********************************************************************/#include <stdlib.h>#include <stdio.h>#include <math.h>#include "FFT.h"#ifndef M_PI#define	M_PI		3.14159265358979323846	/* pi */#endifint **gFFTBitTable = NULL;const int MaxFastBits = 16;int IsPowerOfTwo (int x){  if ( x < 2 )	return false;    if ( x & (x-1) )  /* Thanks to 'byang' for this cute trick! */	return false;    return true;}int NumberOfBitsNeeded (int PowerOfTwo){  int i;    if ( PowerOfTwo < 2 ) {	fprintf(stderr, "Error: FFT called with size %d\n", PowerOfTwo);	exit(1);  }  for ( i=0; ; i++ )	if ( PowerOfTwo & (1 << i) )	  return i;}int ReverseBits ( int index, int NumBits ){  int i, rev;    for ( i=rev=0; i < NumBits; i++ ) {	rev = (rev << 1) | (index & 1);	index >>= 1;  }    return rev;}void InitFFT(){  gFFTBitTable = new int *[MaxFastBits];  int len=2;  for(int b=1; b<=MaxFastBits; b++) {	gFFTBitTable[b-1] = new int[len];	for(int i=0; i<len; i++)	  gFFTBitTable[b-1][i] = ReverseBits(i, b);	len <<= 1;  }}inline int FastReverseBits(int i, int NumBits){  if (NumBits <= MaxFastBits)  	return gFFTBitTable[NumBits-1][i];  else	return ReverseBits(i, NumBits);}/* * Complex Fast Fourier Transform */void FFT (    int       NumSamples,    bool      InverseTransform,    float    *RealIn,    float    *ImagIn,    float    *RealOut,    float    *ImagOut ){  int NumBits;    /* Number of bits needed to store indices */  int i, j, k, n;  int BlockSize, BlockEnd;  double angle_numerator = 2.0 * M_PI;  float tr, ti;     /* temp real, temp imaginary */  if ( !IsPowerOfTwo(NumSamples) ) {	fprintf (stderr, "%d is not a power of two\n", NumSamples);	exit(1);  }  if (!gFFTBitTable)	InitFFT();    if ( InverseTransform )	angle_numerator = -angle_numerator;    NumBits = NumberOfBitsNeeded ( NumSamples );  /*  **   Do simultaneous data copy and bit-reversal ordering into outputs...  */    for ( i=0; i < NumSamples; i++ ) {	j = FastReverseBits ( i, NumBits );	RealOut[j] = RealIn[i];	ImagOut[j] = (ImagIn == NULL) ? 0.0 : ImagIn[i];  }    /*  **   Do the FFT itself...  */    BlockEnd = 1;  for ( BlockSize = 2; BlockSize <= NumSamples; BlockSize <<= 1 ) {	  double delta_angle = angle_numerator / (double)BlockSize;	  float sm2 = sin ( -2 * delta_angle );	  float sm1 = sin ( -delta_angle );	  float cm2 = cos ( -2 * delta_angle );	  float cm1 = cos ( -delta_angle );	  float w = 2 * cm1;	  float ar0, ar1, ar2, ai0, ai1, ai2;			  for ( i=0; i < NumSamples; i += BlockSize ) {		ar2 = cm2;		ar1 = cm1;				ai2 = sm2;		ai1 = sm1;				for ( j=i, n=0; n < BlockEnd; j++, n++ ) {		  ar0 = w*ar1 - ar2;		  ar2 = ar1;		  ar1 = ar0;		  		  ai0 = w*ai1 - ai2;		  ai2 = ai1;		  ai1 = ai0;		  		  k = j + BlockEnd;		  tr = ar0*RealOut[k] - ai0*ImagOut[k];		  ti = ar0*ImagOut[k] + ai0*RealOut[k];		  		  RealOut[k] = RealOut[j] - tr;		  ImagOut[k] = ImagOut[j] - ti;		  		  RealOut[j] += tr;		  ImagOut[j] += ti;		}	  }	  	  BlockEnd = BlockSize;  }    /*  **   Need to normalize if inverse transform...  */    if ( InverseTransform ) {	float denom = (float)NumSamples;		for ( i=0; i < NumSamples; i++ ) {	  RealOut[i] /= denom;	  ImagOut[i] /= denom;	}  }}/* * Real Fast Fourier Transform * * This function was based on the code in Numerical Recipes in C. * In Num. Rec., the inner loop is based on a single 1-based array * of interleaved real and imaginary numbers.  Because we have two * separate zero-based arrays, our indices are quite different. * Here is the correspondence between Num. Rec. indices and our indices: * * i1  <->  real[i] * i2  <->  imag[i] * i3  <->  real[n/2-i] * i4  <->  imag[n/2-i] */void RealFFT(    int       NumSamples,    float    *RealIn,    float    *RealOut,    float    *ImagOut ){  int Half = NumSamples/2;  int i;  float theta = M_PI / Half;  float *tmpReal = new float[Half];  float *tmpImag = new float[Half];  for(i=0; i<Half; i++) {	tmpReal[i] = RealIn[2*i];	tmpImag[i] = RealIn[2*i+1];  }    FFT(Half, 0, tmpReal, tmpImag, RealOut, ImagOut);  float wtemp = float(sin(0.5*theta));  float wpr = -2.0 * wtemp * wtemp;  float wpi = float(sin(theta));  float wr = 1.0+wpr;  float wi = wpi;    int i3;  float h1r, h1i, h2r, h2i;  for(i=1; i<Half/2; i++) {	i3 = Half-i;	h1r = 0.5*(RealOut[i]+RealOut[i3]);	h1i = 0.5*(ImagOut[i]-ImagOut[i3]);	h2r = 0.5*(ImagOut[i]+ImagOut[i3]);	h2i = -0.5*(RealOut[i]-RealOut[i3]);	RealOut[i]=h1r+wr*h2r-wi*h2i;	ImagOut[i]=h1i+wr*h2i+wi*h2r;	RealOut[i3]=h1r-wr*h2r+wi*h2i;	ImagOut[i3]=-h1i+wr*h2i+wi*h2r;	wr=(wtemp=wr)*wpr-wi*wpi+wr;	wi=wi*wpr+wtemp*wpi+wi;  }  RealOut[0] = (h1r=RealOut[0])+ImagOut[0];  ImagOut[0] = h1r-ImagOut[0];  delete[] tmpReal;  delete[] tmpImag;}/* * PowerSpectrum * * This function computes the same as RealFFT, above, but * adds the squares of the real and imaginary part of each * coefficient, extracting the power and throwing away the * phase. * * For speed, it does not call RealFFT, but duplicates some * of its code. */void PowerSpectrum(    int       NumSamples,    float    *In,    float    *Out ){  int Half = NumSamples/2;  int i;  float theta = M_PI / Half;  float *tmpReal = new float[Half];  float *tmpImag = new float[Half];  float *RealOut = new float[Half];  float *ImagOut = new float[Half];  for(i=0; i<Half; i++) {	tmpReal[i] = In[2*i];	tmpImag[i] = In[2*i+1];  }    FFT(Half, 0, tmpReal, tmpImag, RealOut, ImagOut);  float wtemp = float(sin(0.5*theta));  float wpr = -2.0 * wtemp * wtemp;  float wpi = float(sin(theta));  float wr = 1.0+wpr;  float wi = wpi;    int i3;  float h1r, h1i, h2r, h2i, rt, it;  for(i=1; i<Half/2; i++) {	i3 = Half-i;	h1r = 0.5*(RealOut[i]+RealOut[i3]);	h1i = 0.5*(ImagOut[i]-ImagOut[i3]);	h2r = 0.5*(ImagOut[i]+ImagOut[i3]);	h2i = -0.5*(RealOut[i]-RealOut[i3]);	rt = h1r+wr*h2r-wi*h2i;	it = h1i+wr*h2i+wi*h2r;	Out[i] = rt*rt + it*it;	rt = h1r-wr*h2r+wi*h2i;	it = -h1i+wr*h2i+wi*h2r;	Out[i3] = rt*rt + it*it;	wr=(wtemp=wr)*wpr-wi*wpi+wr;	wi=wi*wpr+wtemp*wpi+wi;  }  rt = (h1r=RealOut[0])+ImagOut[0];  it = h1r-ImagOut[0];  Out[0] = rt*rt + it*it;  rt = RealOut[Half/2];  it = ImagOut[Half/2];  Out[Half/2] = rt*rt + it*it;  delete[] tmpReal;  delete[] tmpImag;  delete[] RealOut;  delete[] ImagOut;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀av一区二区三区| 中文字幕欧美一区| 激情伊人五月天久久综合| 欧美日本在线一区| 欧美a级理论片| 国产婷婷色一区二区三区四区| 狠狠色综合日日| 欧美国产国产综合| 色婷婷国产精品综合在线观看| 亚洲午夜久久久久久久久电影院 | 成人免费观看视频| 亚洲欧洲国产专区| 欧美精品xxxxbbbb| 国产一区在线观看视频| 国产精品久久福利| 欧美日韩在线三级| 精品一区二区三区在线播放| 国产欧美一区二区三区网站 | 欧美自拍偷拍一区| 久久机这里只有精品| 久久精品亚洲国产奇米99| 91在线看国产| 免费的成人av| 国产精品久久二区二区| 3atv一区二区三区| 91精品国产综合久久精品app| 青草av.久久免费一区| 久久久亚洲欧洲日产国码αv| 97久久超碰国产精品| 日本欧美加勒比视频| 综合欧美亚洲日本| 91精品国产综合久久精品性色| 成人午夜大片免费观看| 丝袜a∨在线一区二区三区不卡| 久久久高清一区二区三区| 在线观看一区日韩| 国产91精品精华液一区二区三区| 亚洲国产日韩a在线播放性色| 国产欧美精品一区aⅴ影院| 欧美日韩在线三区| 91免费精品国自产拍在线不卡| 蜜臀a∨国产成人精品| 亚洲精品自拍动漫在线| 久久精品无码一区二区三区| 欧美三级日本三级少妇99| 成人黄色在线网站| 久久综合综合久久综合| 亚洲v中文字幕| 亚洲人成网站色在线观看| 精品欧美乱码久久久久久1区2区| 欧美午夜精品理论片a级按摩| 成人国产亚洲欧美成人综合网| 捆绑调教美女网站视频一区| 亚洲一区二区视频在线观看| 国产精品视频一二三区| 精品国产网站在线观看| 欧美日韩不卡一区| 色综合天天综合给合国产| 国产黄色精品视频| 激情文学综合丁香| 免费三级欧美电影| 午夜视频在线观看一区二区 | 亚洲夂夂婷婷色拍ww47| 国产精品久久久久久久久快鸭| 2021中文字幕一区亚洲| 日韩精品中午字幕| 欧美一区二区性放荡片| 欧美美女视频在线观看| 欧美三级中文字| 欧美三级视频在线播放| 欧美亚洲动漫另类| 在线观看成人免费视频| 成人av综合一区| 岛国一区二区三区| 成a人片亚洲日本久久| 成人深夜视频在线观看| 成人深夜福利app| 91丨porny丨户外露出| 99久久精品费精品国产一区二区| 懂色av噜噜一区二区三区av| 无码av中文一区二区三区桃花岛| 伊人性伊人情综合网| 欧美日韩在线播放一区| 国产九色精品成人porny| 亚洲黄色av一区| 337p日本欧洲亚洲大胆精品| 成人免费视频视频在线观看免费 | 亚洲国产精品黑人久久久| 中文字幕欧美日本乱码一线二线| 欧美一级理论片| 精品国免费一区二区三区| 久久色.com| 国产精品人成在线观看免费| 中文字幕日韩av资源站| 亚洲一卡二卡三卡四卡无卡久久 | 精品电影一区二区三区| 欧美电影免费观看高清完整版在线 | 亚洲一区二区三区视频在线播放 | 在线免费观看成人短视频| 欧美日韩色一区| 日韩免费高清电影| 久久久亚洲国产美女国产盗摄| 欧美国产一区二区在线观看| 亚洲欧美日韩人成在线播放| 亚洲成人免费影院| 国产一区二区不卡老阿姨| 成人激情开心网| 欧美日韩一区成人| 精品女同一区二区| 亚洲人成电影网站色mp4| 视频一区二区欧美| 国产91在线观看| 国产精品高潮呻吟| 最好看的中文字幕久久| 亚洲黄色尤物视频| 麻豆精品一区二区av白丝在线 | 亚洲综合在线观看视频| 91丨porny丨国产入口| 三级欧美韩日大片在线看| 国产精品久久久久久亚洲毛片 | 国产精品午夜电影| 亚洲成人免费视频| 丁香激情综合国产| 在线电影国产精品| 久久亚洲欧美国产精品乐播 | 欧美影院一区二区三区| 久久先锋影音av鲁色资源| 亚洲精品乱码久久久久久黑人| 一二三四社区欧美黄| 国产一区二区三区在线观看免费视频 | 性欧美疯狂xxxxbbbb| 久久av资源网| 在线观看日韩一区| 国产日韩欧美麻豆| 亚洲午夜久久久久久久久久久| 国产精品1区2区3区在线观看| 欧美日韩在线一区二区| 国产午夜亚洲精品不卡| 日韩精品91亚洲二区在线观看| 粉嫩高潮美女一区二区三区| 一本大道久久精品懂色aⅴ| 欧美成人在线直播| 亚洲一区二区三区四区的| 99在线热播精品免费| 精品人在线二区三区| 日韩和的一区二区| 色94色欧美sute亚洲线路一ni | 久久久久99精品一区| 亚洲国产cao| 色噜噜狠狠成人网p站| 国产精品日日摸夜夜摸av| 国产精品一区二区三区四区 | 亚洲综合免费观看高清完整版| 免费成人av在线| 日韩一区二区三区在线| 秋霞影院一区二区| 精品电影一区二区| 国产一区二区主播在线| 久久丝袜美腿综合| 色综合久久久久综合体桃花网| 亚洲美女屁股眼交| 91福利视频久久久久| 视频精品一区二区| 久久久精品免费免费| 99国产精品久久久| 天堂在线亚洲视频| 久久久精品免费观看| av色综合久久天堂av综合| 蜜桃视频第一区免费观看| 国产女人aaa级久久久级| 日韩午夜在线观看| 成人性生交大片免费看在线播放| 午夜影视日本亚洲欧洲精品| 亚洲色图20p| 91精彩视频在线观看| 夜夜精品视频一区二区| 91久久精品一区二区二区| 久久av中文字幕片| 亚洲免费色视频| 一区二区三区在线播放| 国内欧美视频一区二区| 欧美精品久久天天躁| 中文字幕 久热精品 视频在线| 免费观看在线综合| 精品福利av导航| 国产91高潮流白浆在线麻豆| 国产欧美一区二区在线观看| 99视频一区二区三区| 亚洲精品菠萝久久久久久久| 欧美伦理影视网| 久久成人麻豆午夜电影| 久久精品人人爽人人爽| 99国产精品久| 日韩电影在线观看电影| 久久综合狠狠综合久久综合88| 成人av在线一区二区三区| 一区二区在线观看不卡| 欧美一区二区网站| 波波电影院一区二区三区| 亚洲国产精品视频|