C中的FIR滤波器?

尼古拉斯·R。

我有一个作业用C语言实现FIR滤波器,我想知道您是否认为我正确理解了分配。我写的解决问题的程序是:

#include <stdio.h>
float FIRfloats[5];
void floatFIR(float newsample)
{
  int i;
  float sum=0;

  FIRfloats[0]=newsample*0.0299;
  FIRfloats[1]=FIRfloats[2]*0.4701;
  FIRfloats[2]=FIRfloats[3]*0.4701;
  FIRfloats[3]=FIRfloats[4]*0.0299;

  /* sum */
   for(i=0;i<5;i++)
  {
    sum=sum+FIRfloats[i];
  }
  printf("Sum: %f\n", sum);
}

int main ()
{

  float n=0.0f; 
  while (scanf("%f", &n) > 0)
  {
  floatFIR(n);
  }
  return 0;
}

规格是

在新样本xk到达之前,旧样本向右移动,然后在计算结果yk之前,对每个样本进行系数缩放,然后计算出所有缩放样本的总和

系数应为c0 = 0.0299,c1 = 0.4701,c2 = 0.4701,c3 = 0.0299。

您认为我正确解决了作业吗?我认为这似乎太容易了,因此我想知道。

阿维·佩雷尔(Avi Perel)

恐怕问题中提供的实现无法提供正确的结果。

在具有4个系数的FIR(有限脉冲响应)滤波器中,输入序列(x)的输出序列(y)为:

y[t] = c0*x[t] + c1*x[t-1] + c2*x[t-2] + c3*x[t-3]

因此,实现应类似于:

/* add includes (stdio.h and whatever else you'll need...) */

float floatFIR(float inVal, float* x, float* coef, int len)
{
    float y = 0.0;
    for (int i = (len-1) ; i > 0 ; i--)
    {
         x[i] = x[i-1];
         y = y + (coef[i] * x[i]);
    }
    x[0] = inVal;
    y = y + (coef[0] * x[0]);
    return y;
}

main(int argc, char** argv)
{
    float coef[4] = {0.0299, 0.4701, 0.4701, 0.0299};
    float x[4] = {0, 0, 0, 0}; /* or any other initial condition*/
    float y;
    float inVal;

    while (scanf("%f", &inVal) > 0)
    {
        y = floatFIR(inVal, x, coef, 4);
    }
    return 0;

}

这将在同一循环中执行移位和乘法操作(这不会影响结果-只会更有效。)如果要完全遵循规范,可以像下面这样更改floatFir:

float floatFIR(float inVal, float* x, float* coef, int len)
{
    float y = 0.0;
    for (int i = (len-1) ; i > 0 ; i--)
    {
         x[i] = x[i-1];
    }
    x[0] = inVal;

    for (int i = 0 ; i < len ; i++)
    {
        y = y + (coef[i] * x[i]);
    }
    return y;
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章