打印

DSP 的FFT库函数的使用

[复制链接]
6036|27
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
390146413|  楼主 | 2015-7-26 16:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
刚学DSP 芯片F2812。CCStudio v3.3编译器。在对ADC采样到的数组要进行FFT频谱分析。并显示在液晶上。听说TI的FFT库函数能做到数据频谱分析,不用自己C编程,太难。
网上找了个遍,也没个具体的使用方法。。谁有做过给个资料。谢谢了

相关帖子

沙发
尤彼卡| | 2015-7-26 19:04 | 只看该作者
使用DSP做信号处理吗,ARM能做吗

使用特权

评论回复
板凳
390146413|  楼主 | 2015-7-26 19:27 | 只看该作者
ARM能做,那用DSP做什么????

使用特权

评论回复
地板
fdasf| | 2015-7-26 21:56 | 只看该作者
信号处理是个处理器都能做,只是处理性能有差异而已。

使用特权

评论回复
5
390146413|  楼主 | 2015-7-26 22:22 | 只看该作者
这不是玩玩,数据处理。DSP、、、、、什么想成过家家了

使用特权

评论回复
6
chenci2013| | 2015-7-26 23:30 | 只看该作者
太大了容易不执行

使用特权

评论回复
7
fdasf| | 2015-7-27 00:37 | 只看该作者
DSP也没什么神奇的,不是说有什么功能只有DSP才能做。实际的产品无非从功耗、性能、价格、稳定性等方面综合来考虑罢了。

使用特权

评论回复
8
dontium| | 2015-7-27 11:07 | 只看该作者
楼主刚学TI的器件,为什么不用V6版的CCS,而用V3版的呢?本人没用过V3版的,也不知道它的优势在哪儿。

楼主安装CCS后,再安装controlSUITE,那里面有这方面的例子,

controlSUITE是对准C28 CPU做的, 2812用的是C28 CPU,

使用特权

评论回复
9
鱼乐圈的圈| | 2015-7-27 14:10 | 只看该作者
不错啊。。。。

使用特权

评论回复
10
可可球| | 2015-7-29 10:45 | 只看该作者
CCS现在出到几版本了

使用特权

评论回复
11
tongbu2015| | 2015-7-29 21:07 | 只看该作者
fdasf 发表于 2015-7-27 00:37
DSP也没什么神奇的,不是说有什么功能只有DSP才能做。实际的产品无非从功耗、性能、价格、稳定性等方面综合 ...

这一点的我同意啊,关键是合适就可以的。

使用特权

评论回复
12
tongbu2015| | 2015-7-29 21:54 | 只看该作者
这个在开发的时候需要多注意基本功能的。

使用特权

评论回复
13
风清云淡| | 2015-7-30 20:30 | 只看该作者
主要是分析一下dsp28335的C28x_FPU_LIB.lib这个库,这个库十分强大,首先可以计算复数域的CFFT(Complex Fast Fourier Transform
),其中函数为void CFFT_f32 (CFFT_F32_STRUCT *) 。其中CFFT_F32_STRUCT为官方定义的一个结构体成员有
typedef struct
{ float32 *InPtr;
float32 *OutPtr;
float32 *CoefPtr;
float32 *CurrentInPtr;
float32 *CurrentOutPtr;
Uint16 Stages;
Uint16 FFTSize;
} CFFT_F32_STRUCT;

使用特权

评论回复
14
风清云淡| | 2015-7-30 20:30 | 只看该作者
InPtr为输入数组指针,假设你的CFFT的采样点1024个点,那么你的输入数组为inputdata[2*FFTSize]因为你是复数的FFT吗,所以实部和虚部都是需要进行存储的,所以输入数组的长度为2*FFTSize.其中实部和虚部的存储方式为inputdata[0]存储你第一点的实部,inputdata[1]存储第一点的虚部,接着依次向下inputdata[2]存储第二个点的实部,inputdata[3]第二个点的虚部。。。。。。。。。

使用特权

评论回复
15
风清云淡| | 2015-7-30 20:30 | 只看该作者
第二个成员OutPtr,为指向输出数组的指针,输出数组的大小也为2*FFTSize,存储方式同样的outputdata[0]为第一个点的实部,接着虚部,接着第二个点,第三个点。

使用特权

评论回复
16
风清云淡| | 2015-7-30 20:30 | 只看该作者
接着第三个成员CoefPtr,为指向转化因子数组的指针,长度为FFTSize,决定傅里叶转化因子的只有傅里叶变换的阶数,换句话说就是样本点的个数,如果又不知道傅里叶转化因子是什么的建议百度一下你就知道。第四个成员CurrentInPtr也是指向输入数组的指针,但是该输入数组不同于上面的输入数组,这个指针的用途是用来计算幅值所用的,如果你想计算某一复数数组的幅值直接把该数组指针指向那个数组就好了。比如你想得出傅里叶变换后结果数组的幅值趋势便可以直接将该指针指向outputdata[2*FFTSize],当然有输入就有输出,CurrentOutPtr来指向幅值输出的数组

使用特权

评论回复
17
风清云淡| | 2015-7-30 20:32 | 只看该作者
stage为傅里叶变换的阶数,FFTSize为FFT变换的长度FFTSize=2^stage
前面主要讲了一个结构体,这个结构体在后面函数的应用是很重要的。下面主要分享一下函数的应用
第一个函数 CFFT_f32_sincostable(&cfft) 其中cfft就是上述的一个结构体,这个函数的作用就是计算傅里叶变换的转化因子。转化因子由公式可知转化因子只与你傅里叶变换的阶数有关,所以只要你在结构体中对stage和FFTSize进行了赋值就可以计算转化因子了,而且转化因子是固定的,如果不需改变傅里叶变换的阶数,只需要计算一次就好了。
转化因子当然保存在*CoefPtr指向的数组中。第二个函数CFFT_f32(&cfft)这个是重头戏,他就是做复数傅里叶变换的函数,将*InPtr指向的数组中的复数进行傅里叶变换,然后将结果保存在*OutPtr指向的数组当中。此函数只与 float32 *InPtr;
float32 *OutPtr;
float32 *CoefPtr;
Uint16 Stages;
Uint16 FFTSize; 这几个成员有关系,与另两个无关
CFFT_f32_mag(&cfft)计算幅值的函数,只与float32 *CurrentInPtr;
float32 *CurrentOutPtr这两个成员有关,主要作用就是计算*CurrentInPtr指向的复数数组中的复数的摩值,将计算出来的摩值保存在*CurrentOutPtr该成员指向的数组中,与其他成员无关。
最后一个重头戏ICFFT_f32(&cfft),进行了傅里叶变化当然还不行,还要进行傅里叶反变换,将波形还原,直接调用它就好了,他会将*InPtr指向的数组中的复数进行傅里叶反变换,然后将值保存到输出数组中。

使用特权

评论回复
18
baimiaocun2015| | 2015-7-31 22:05 | 只看该作者
fft的用法是需要多注意的,在DSP中是最基本的。

使用特权

评论回复
19
390146413|  楼主 | 2015-8-2 08:44 | 只看该作者
风清云淡
能交我什么样在F2812上实现FFT,之前只做单片机,,DSP刚刚入门,不会让你白忙的给辛苦费的,加我QQ390146413

使用特权

评论回复
20
呆头鹅| | 2016-5-30 10:05 | 只看该作者
风清云淡 发表于 2015-7-30 20:30
主要是分析一下dsp28335的C28x_FPU_LIB.lib这个库,这个库十分强大,首先可以计算复数域的CFFT(Complex Fa ...

求问怎么在TMS320F2812上用FFT求出信号的相位(或者说两个信号的相位差)

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

5

主题

18

帖子

1

粉丝