完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
有谁可以帮忙,我需要切比雪夫ii型的高通、低通、带通的滤波程序,对这个不是很了解,想研究下,我可以从matlab上把滤波系数搞定,但是不知道怎么用C语言在单片机上实现滤波,请各位大侠帮忙,急需
int16_t IIR_Filter(double *a, int Lenth_a, double *b, int Lenth_b, int16_t Input_Data, double *Memory_Buffer) { int Count=0; double Output_Data = 0; int Memory_Lenth = 0; if(Lenth_a >= Lenth_b) Memory_Lenth = Lenth_a; else Memory_Lenth = Lenth_b; Output_Data += (*a) * Input_Data; //a(0)*x(n) for(Count = 1; Count < Lenth_a ;Count++) { Output_Data -= (*(a + Count)) * (*(Memory_Buffer + (Memory_Lenth - 1) - Count)); } //------------------------save data--------------------------// *(Memory_Buffer +Memory_Lenth-1 ) = Output_Data; Output_Data = 0; //----------------------------------------------------------// for(Count = 0; Count < Lenth_b ;Count++) { Output_Data += (*(b + Count)) * (*(Memory_Buffer + (Memory_Lenth - 1) - Count)); } //------------------------move data--------------------------// for(Count = 0 ; Count < Memory_Lenth -1 ; Count++) { *(Memory_Buffer + Count) = *(Memory_Buffer + Count + 1); } *(Memory_Buffer + Memory_Lenth - 1) = 0; //-----------------------------------------------------------// return (int16_t)Output_Data; } 这个函数只能实现低通滤波,高通实现不了,带通也不对,不知道是我用错了还是高低带通需要不同的程序来实现 |
|
相关推荐
12个回答
|
|
|
|
|
|
|
|
|
就没用过,顶一下
|
|
|
|
|
|
支持一下,没搞过
|
|
|
|
|
|
本帖最后由 adlu 于 2016-11-11 15:02 编辑
可以参考该文档的P79,DSPF_sp_iir()的实现,或者P141的DSPF_dp_iir()的实现。 两个函数结构是一样的,只是数据精度不同,一个是float的一个的double的。 文档中实现的是一个5阶IIR滤波器。 h1和h2是要通过MATLAB设计的参数。 |
|
|
|
|
|
|
|
|
很想知道c怎么实现
|
|
|
|
|
|
谢谢,各位,通过我上面的程序都是可以的,我只是采集的时候有点问题。
|
|
|
|
|
|
没有用C编过,
|
|
|
|
|
|
学习学习。。。。。
|
|
|
|
|
|
帮顶,帮顶
|
|
|
|
|
|
太高端了,还没有用过呢 !!!
|
|
|
|
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
STM32F405驱动DS1302时钟模块,输出时间错乱该怎么排查?
2810 浏览 2 评论
stm32f405rgt6驱动DS1302ZN出现时间错乱问题
2420 浏览 1 评论
stm32用fsmc读取ad7606采集数据,数据不变,只有开发版复位才更新数据
2288 浏览 0 评论
2404 浏览 1 评论
1643 浏览 1 评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-2 15:09 , Processed in 1.347672 second(s), Total 94, Slave 77 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
5913