C#零相位数字滤波器,改写自Matlab函数filtfilt

本文介绍了零相位数字滤波器的概念,并展示了如何将Matlab的filtfilt函数改写为C#代码。这个滤波器通过前后两次滤波实现零相位特性,适用于非实时处理。文章提供了详细的C#实现过程,包括滤波器初始化、添头添尾处理、正向和反向滤波操作。
摘要由CSDN通过智能技术生成

任何一个数字滤波器都有幅频特性和相频特性,如果对于滤波不要求实时性,我们可以设计一种滤波器,使得它的相频特性始终为0,这种数字滤波器就称为零相移数字滤波器。

Matlab中,零相移滤波器对应的函数名称为filtfilt,其帮助中提供的信息如下,翻译一下:

FILTFILT Zero-phase forward and reverse digital filtering.

    Y = FILTFILT(B, A, X) filters the data in vector X with the filter described by vectors A and B to create the filtered data Y.  The filter is described by the difference equation:

FILTFILT 零相移前向后向数字滤波器

         Y = FILTFILT(B, A, X)通过向量AB描述的旅欧不起对数据向量X滤波得到滤波后的数据Y。滤波器可以通过差分方程描述如下:

      y(n) = b(1)*x(n) + b(2)*x(n-1) + ... + b(nb+1)*x(n-nb)

                       - a(2)*y(n-1) - ... - a(na+1)*y(n-na)

After filtering in the forward direction, the filtered sequence is then reversed and run back through the filter; Y is the time reverse of the output of the second filtering operation. The result has precisely zero phase distortion and magnitude modified by the square of the filter's magnitude response.  Care is taken to minimize startup and ending transients by matching initial conditions.

通过前向滤波之后,滤波序列被反折并且再次通过滤波器,Y是第二次滤波器输出的时间反折序列。其结果是相位特性精确的为零,没有变形并且幅频特性被滤波器幅频特性的平方所改变。初值和终值都被选择的很小的跳变来匹配初始条件。

The length of the input x must be more than three times the filter order, defined as max(length(b)-1,length(a)-1). Note that FILTFILT should not be used with differentiator and Hilbert FIR filters, since the operation of these filters depends heavily on their phase response.

输入序列x的长度必须大于滤波器阶数的三倍,阶数定义为max(length(b)-1,length(a)-1)。注意FILTFILT不应当被用于Hilbert FIR滤波器,因为这些滤波器的相位特性是很重要的。

考虑到这个滤波器的科研应用价值,为便于将它引入到自己的分析软件中,于是调试将其matlab代码改写为了C#代码。源码如下:

public class DigitalFilter

    {

        private double[] b = new double[2];

        private double[] a = new double[2];

        private double[] x;

        private double zi;

        private double[] y = new double[1024];

        private double[] zf = new double[1];

 

        public

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值