OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 8781|回复: 8

stm32中 如何使用fft算法将已经收集到的ADC信号转换为频率或幅值?求代码

[复制链接]

2

主题

7

帖子

0

精华

新手上路

积分
26
金钱
26
注册时间
2016-4-12
在线时间
3 小时
发表于 2016-4-27 21:11:55 | 显示全部楼层 |阅读模式
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

7

帖子

0

精华

新手上路

积分
26
金钱
26
注册时间
2016-4-12
在线时间
3 小时
 楼主| 发表于 2016-4-27 21:32:29 | 显示全部楼层
打算做一个能够判断婴儿哭泣的项目,使用的是mini stm32开发板,和一个声音开发板,准备使用FFT算法将采集到的ADC信号转换为频率,从而判断出婴儿哭泣。求大神指导!!!
回复

使用道具 举报

351

主题

1472

帖子

12

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
8077
金钱
8077
注册时间
2015-10-15
在线时间
2915 小时
发表于 2016-4-28 14:24:16 | 显示全部楼层
F4的话可以直接使用DSP里面的库。。。
如果是F1,你百度搜索一下FFT C语言,很多代码可以参考。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

2

主题

7

帖子

0

精华

新手上路

积分
26
金钱
26
注册时间
2016-4-12
在线时间
3 小时
 楼主| 发表于 2016-5-2 18:39:53 | 显示全部楼层
openedvadmin 发表于 2016-4-28 14:24
F4的话可以直接使用DSP里面的库。。。
如果是F1,你百度搜索一下FFT C语言,很多代码可以参考。

F4和F1指的是什么?引脚个数吗?
回复

使用道具 举报

2

主题

7

帖子

0

精华

新手上路

积分
26
金钱
26
注册时间
2016-4-12
在线时间
3 小时
 楼主| 发表于 2016-5-2 21:26:49 | 显示全部楼层
openedvadmin 发表于 2016-4-28 14:24
F4的话可以直接使用DSP里面的库。。。
如果是F1,你百度搜索一下FFT C语言,很多代码可以参考。

谢谢,我用的是F1的,也去找了C语言代码,但是不知道怎么将ADC信号赋值到FFT中
回复

使用道具 举报

36

主题

256

帖子

0

精华

高级会员

Rank: 4

积分
921
金钱
921
注册时间
2016-4-20
在线时间
169 小时
发表于 2016-5-14 16:32:51 | 显示全部楼层
明月丶海狼 发表于 2016-5-2 21:26
谢谢,我用的是F1的,也去找了C语言代码,但是不知道怎么将ADC信号赋值到FFT中

楼主,从你的回答来讲我觉得要考虑下可行性。
首先你需要理解利用FFT是把你采样得到的时域的信号转换为频域的信息。从你项目的目的来看你是想通过特定的频率信息判断是否为婴儿的哭啼声。我说下我的意见,人的声音是在20~20KHz之间。即使是一个人说话的话他的声音的频率范围也是变化的,不可能落到一个频率点上,如果落在一个点上,听的感觉是类似 “嘟”的声音。
你要完成这个项目最好看看语音识别的相关内容。

另外,你准备用多大的采样率进行数据采样,如果你要获得完整的不失真的声音信号,建议采样率时40KHz以上。这么高的采样率还要加上算法处理,你得衡量一下在stm32f1xx系列上你能不能算的过来。如果下降到普通的8K的采样率,你最后可以分析的频率范围只有0~4KHz,这个频率范围你是不是能够得到什么有效数据呢。
回复

使用道具 举报

36

主题

256

帖子

0

精华

高级会员

Rank: 4

积分
921
金钱
921
注册时间
2016-4-20
在线时间
169 小时
发表于 2016-5-14 16:38:10 | 显示全部楼层
明月丶海狼 发表于 2016-5-2 21:26
谢谢,我用的是F1的,也去找了C语言代码,但是不知道怎么将ADC信号赋值到FFT中

我这里有个附件是当初练手的时候写的测试fft的,不过我这里是电信号,20ms一个周期的。希望有所帮助。

newfft.rar

57.17 KB, 下载次数: 1534

回复

使用道具 举报

9

主题

58

帖子

0

精华

高级会员

Rank: 4

积分
542
金钱
542
注册时间
2016-2-24
在线时间
61 小时
发表于 2016-5-14 16:41:32 | 显示全部楼层
czdspeed 发表于 2016-5-14 16:32
楼主,从你的回答来讲我觉得要考虑下可行性。
首先你需要理解利用FFT是把你采样得到的时域的信号转换为 ...

不用担心,我试过用F2实现48Khz,1024点的FFT变换然后逆变换,大概是占用50%的CPU时间。
如果只变换不逆变换,F1应该是足够的。
如果点数增加,消耗的时间应该会稍微增加,但主要矛盾应该是内存而不是CPU速度吧
回复

使用道具 举报

36

主题

256

帖子

0

精华

高级会员

Rank: 4

积分
921
金钱
921
注册时间
2016-4-20
在线时间
169 小时
发表于 2016-5-14 16:48:59 | 显示全部楼层
shark_32 发表于 2016-5-14 16:41
不用担心,我试过用F2实现48Khz,1024点的FFT变换然后逆变换,大概是占用50%的CPU时间。
如果只变换不逆 ...

我这个过程不会只用到fft,后面还要提取其他的语音信息。楼主再看看,我觉得如果是开发的话可以留有余量,为什么不用dsp呢。ti的c5xx  c6xx都是有基本的fft  fir 逆fft库的,效率比arm高不少。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-7 12:52

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表