一个fft算法的问题~求教!

Cacar 2008-02-28 11:05:04
VOID WINAPI FFT(complex<double> * TD, complex<double> * FD, int r)
{
// 付立叶变换点数
LONG count;

// 循环变量
int i,j,k;

// 中间变量
int bfsize,p;

// 角度
double angle;

complex<double> *W,*X1,*X2,*X;

// 计算付立叶变换点数
count = 1 << r;

// 分配运算所需存储器
W = new complex<double>[count / 2];
X1 = new complex<double>[count];
X2 = new complex<double>[count];

// 计算加权系数
for(i = 0; i < count / 2; i++)
{
angle = -i * PI * 2 / count;
W[i] = complex<double> (cos(angle), sin(angle));
}

// 将时域点写入X1
memcpy(X1, TD, sizeof(complex<double>) * count);

// 采用蝶形算法进行快速付立叶变换
for(k = 0; k < r; k++)
{
for(j = 0; j < 1 << k; j++)
{
bfsize = 1 << (r-k);
for(i = 0; i < bfsize / 2; i++)
{
p = j * bfsize;
X2[i + p] = X1[i + p] + X1[i + p + bfsize / 2];
X2[i + p + bfsize / 2] = (X1[i + p] - X1[i + p + bfsize / 2]) * W[i * (1<<k)];
}
}
X = X1;
X1 = X2;
X2 = X;
}

// 重新排序
for(j = 0; j < count; j++)
{
p = 0;
for(i = 0; i < r; i++)
{
if (j&(1<<i))
{
p+=1<<(r-i-1);
}
}
FD[j]=X1[p];
}

// 释放内存
delete W;
delete X1;
delete X2;
}

我看了很多对算法的解释,还是看不懂是怎么实现的
特别是X2[i + p] = X1[i + p] + X1[i + p + bfsize / 2];这一行为什么没有乘系数?

X2[i + p + bfsize / 2] = (X1[i + p] - X1[i + p + bfsize / 2]) * W[i * (1<<k)];这一行为什么先相减 再乘系数?
还有数组的下标为什么要这样计算.
我实现搞不懂,不能和书上给出的公式对应起来,那位高手帮我解释一下.非常感谢.
我初来乍到没多少分,就给100分吧
...全文
41 3 打赏 收藏 举报
写回复
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
Cacar 2008-03-21
  • 打赏
  • 举报
回复
懂了,是按照频分来写的~从另一个方向拆而已~可以参考下胡广书的数字信号处理~
rover___ 2008-03-01
  • 打赏
  • 举报
回复
X2[i+p]=X1[i+p]+X1[i+p+bfsize/2]]*W[i*(1 < <k)];

X2[i+p+bfsize/2]=X1[i+p]-X1[i+p+bfsize/2]*W[i*(1 < <k)];

蝶行算法
rover___ 2008-03-01
  • 打赏
  • 举报
回复
X2[i+p]=X1[i+p]+X1[i+p+bfsize/2];

X2[i+p+bfsize/2]=(X1[i+p]-X1[i+p+bfsize/2])*W[i*(1 < <k)];

上面两句是否应为:

X2[i+p]=X1[i+p]+X1[i+p+bfsize/2]])*W[i*(1 < <k)];

X2[i+p+bfsize/2]=X1[i+p]-X1[i+p+bfsize/2]*W[i*(1 < <k)];
相关推荐
发帖
图形处理/算法

1.9w+

社区成员

VC/MFC 图形处理/算法
社区管理员
  • 图形处理/算法社区
加入社区
帖子事件
创建了帖子
2008-02-28 11:05
社区公告
暂无公告