基于STM32(Keil)用C语言写一个巴特沃斯低通滤波

//滤波参数
float sos[2][6]={{0.00418553 ,0.00837105 , 0.00418553 , 1.   ,      -1.08130803,  0.31257603},
                         { 1. ,         2.  ,        1.  ,        1.  ,       -1.35390591 , 0.6434766}};

float prod_1[3] = {0,0,0};
float res0_1[3]= {0,0,0};
float res_1[3]= {0,0,0};

 

//函数声明

double Low_Pass(double data);

 

//使用函数,这里根据自己需求改写

Current_Resistance = Low_Pass(Current_Resistance);

 

//滤波公式

double Low_Pass(double data){
    prod_1[0]= data;
    res0_1[0] = (sos[0][0] * prod_1[0]) + (sos[0][1] * prod_1[1]) + (sos[0][2] * prod_1[2]) - (sos[0][4] * res0_1[1]) - (sos[0][5] * res0_1[2]);
    res_1[0] = (sos[1][0] * res0_1[0]) + (sos[1][1] * res0_1[1]) + (sos[1][2] * res0_1[2]) - (sos[1][4] * res_1[1]) - (sos[1][5] * res_1[2]);
    prod_1[2]=prod_1[1];
    prod_1[1]=prod_1[0];
    res0_1[2]=res0_1[1];
    res0_1[1]=res0_1[0];
    res_1[2]=res_1[1];
    res_1[1]=res_1[0];
    return res_1[0]; 
}

  • 2
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值