⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 #fft.cpp#

📁 快速傅里叶变换fft算法
💻 CPP#
字号:
/*  Short test program to accompany fix_fft.c*/#define DEBUG 1#define SPECTRUM 0#include <stdio.h>#include <stdlib.h>#include <math.h>#include "fft.h"#define FFT_SIZE  128#define log2FFT   7#define N         (2 * FFT_SIZE)#define log2N     (log2FFT + 1)#define FREQUENCY 5#define AMPLITUDE 12288int main(){	int i, scale;	unsigned diff;	short x[N], fx[N];	for (i=0; i<N; i++){		x[i] = AMPLITUDE*cos(i*FREQUENCY*(2*3.1415926535)/N);		if (i & 0x01)			fx[(N+i)>>1] = x[i];		else			fx[i>>1] = x[i];#if DEBUGprintf("%d %d\n", i, x[i]);#endif	}puts("");	fix_fftr(fx, log2N, 0);#if SPECTRUMfor (i=0; i<N/2; i++) printf("%d %d\n", i, fx[i]);return 0;#endif	scale = fix_fftr(fx, log2N, 1);fprintf(stderr, "scale = %d\n", scale);	for (i=0,diff=0; i<N; i++) {		int sample;		if (i & 0x01)			sample = fx[(N+i)>>1] << scale;		else			sample = fx[i>>1] << scale;#if DEBUGprintf("%d %d\n", i, sample);#endif		diff += abs(x[i]-sample);	}	fprintf(stderr, "sum(abs(diffs)))/N = %g\n", diff/(double)N);	return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -