切比雪夫ii型滤波怎么用C语言在单片机上实现滤波

2019-07-14 13:22发布

有谁可以帮忙,我需要切比雪夫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;   
}

这个函数只能实现低通滤波,高通实现不了,带通也不对,不知道是我用错了还是高低带通需要不同的程序来实现
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
11条回答
nyvvhxcs
1楼-- · 2019-07-14 18:40
 精彩回答 2  元偷偷看……
jerry181855
2楼-- · 2019-07-14 23:30
支持一下,没搞过
吕少大大
3楼-- · 2019-07-15 02:36
本帖最后由 adlu 于 2016-11-11 15:02 编辑



可以参考该文档的P79,DSPF_sp_iir()的实现,或者P141的DSPF_dp_iir()的实现。
两个函数结构是一样的,只是数据精度不同,一个是float的一个的double的。


文档中实现的是一个5阶IIR滤波器。

h1和h2是要通过MATLAB设计的参数。

陈囝囝100
4楼-- · 2019-07-15 03:58
mxjuwer
5楼-- · 2019-07-15 04:59
很想知道c怎么实现
liangxxxxx
6楼-- · 2019-07-15 08:31
 精彩回答 2  元偷偷看……

一周热门 更多>