可调谐巴特沃斯滤波器是否有任何标准实现形式?

信息处理 过滤器 软件实现 无限脉冲响应 硬件实现
2022-01-18 02:38:38

实现巴特沃斯滤波器的标准方法之一是使用级联的二阶部分,每个部分对应于一对复共轭极点。例如,对于四阶滤波器,将有两个二阶部分。如果我们考虑在 z 平面中低通滤波器的极点位置是如何变化的,因为截止点设计用于 0hz 附近到 Nyquist 附近,每对极点“扫出”的路径对应于单位圆内的一对圆弧,如下图所示[对于四阶滤波器]:

四阶巴特沃斯低通滤波器的 Z 平面极点位置

考虑到这些滤波器已经存在了多长时间,并且考虑到这些“弧”对应于 s 平面中的直线这一事实,理所当然,有人会开发出一种具有单个参数的实现形式,该形式能够扫过极点在“运行时”[与“设计时”相反]沿弧线。但是,我还没有遇到过这样的事情。

想出各种方法来做这件事是相对简单的,尤其是在范围内,并且愿意对其进行一些额外的计算。我想知道的是以下内容:

是否有一些标准方法可以实现给定阶数的可调[数字]巴特沃斯滤波器,1)具有最佳特性(例如效率、鲁棒性),以及 2)覆盖整个范围?

或者这真的只是一个没有人愿意谈论它的简单问题吗?如果是这种情况,它似乎会出现在“静态”设计选项旁边的过滤器设计程序中。

我确实找到了这个:具有可变截止频率的多功能巴特沃斯滤波器,但起初谷歌搜索似乎没有太多关于其中内容的信息。

更新(回复:答案)

只是为了更清楚一点:

  • 我正在寻找一个带有参数(比如从 [0,1] 开始)的“元设计”,它将自动调整从 DC 到 Nyquist 的截止(同时保持增益归一化)以用于时变系统。类似于这个两极谐振器的东西,除了巴特沃斯约束。这个想法是计算参数将比在运行时通过典型的离线设计过程更有效。
  • 我什至不一定要寻找如何设计“元过滤器”(即用变量而不是数字进行数学运算),我想知道是否有标准[非显而易见]实现形式的选择——因为,比如说,对应于静态情况的直接方法最终会在时变情况下出现数值问题。
  • 也许没有问题,直接的方法就是实践中使用的方法。那很好啊。我担心的是我没有在我咨询过的任何资料中看到明确提到这个话题,但也许我只是错过了一些非常明显的东西,所以我在问。
  • 在此处添加更多细节的过程中,我遇到了对参数双二阶结构的一般处理,这几乎是我正在寻找的(并且有一些很好的参考资料)。

更新 2

我正在寻找类似于我在对 Jason R 的第二条评论中提出的答案,如下所示:

“哦,是的,你想使用某某论文中的参数化 III-2b,以抽头状态晶格形式,因为它在使用最少乘法数的同时解决了某某边缘情况。”

也许不存在这样的东西,但我的问题是它是否存在,如果是,它是什么,或者我在哪里可以找到它?

头奖

基于 Tim Wescott 在Jason R 的回答中 comp.dsp 线程中对“观察者规范形式”的引用,我决定假设我可能不得不开始研究控制系统文献,所以我尝试搜索巴特沃斯“状态空间”,它出现了以下非常酷的设计/实现处理,不仅是参数巴特沃斯,还有切比雪夫和椭圆滤波器:

Sophocles J. Orfanidis,“高阶数字参数均衡器设计”,J. Audio Eng。社会,卷。53,第 1026-1046 页,2005 年 11 月。

深入研究需要一点时间,但根据我目前所读到的内容,如果它不是我想要的,我会感到非常惊讶。我将这个给 Jason R 以作为 comp.dsp 的参考资料,该参考资料将我引向 Orfanidis 论文。他的回答也是设计巴特沃斯滤波器的一个很好的实用概述。

2个回答

我不确定你在寻找什么。正如您在问题中指出的那样,巴特沃斯滤波器系列的传递函数很容易理解并且易于分析计算。实现一个可通过滤波器阶数和截止频率调整的巴特沃斯滤波器结构非常简单:

  1. 根据选定的滤波器阶数、截止频率和采样率,计算巴特沃斯模拟原型滤波器的极点位置。由于巴特沃斯滤波器没有零点,因此传递函数由极点位置(和直流增益)决定。

  2. 使用双线性变换,将模拟原型的极点位置映射到滤波器数字实现中的相应位置。

  3. 同样,数字滤波器由步骤 2 中找到的极点位置定义。通过将极点成对分组,将滤波器分成二阶部分

而已。正如我所说,使用您可能需要的任何参数以编程方式设计巴特沃斯滤波器很简单;没有一个操作实施起来非常复杂。

编辑:我不确定您要寻找什么最终结果。我认为您最感兴趣的是如何实现具有时变系数的 IIR 滤波器,不一定特定于巴特沃斯滤波器。我假设您的目标是在更改滤波器截止频率时尽量减少伪影;今年早些时候在 comp.dsp 新闻组的讨论中对此进行了讨论。虽然我不确定您对此过滤器结构的用例或要求是什么,但有多种方法可以完成切换。

我知道你说过你希望你的滤波器有一个定义截止频率的参数,但事实仍然是你的可调结构必须有一种方法可以将截止频率转换为所需的系数(或者在巴特沃斯的情况下,只是极点位置)。我上面描述的过程适用于根据所需的归一化采样率生成极点位置。

您可以通过分析数字滤波器极点在 z 平面中的几何形状来潜在地简化极点计算过程。模拟巴特沃斯滤波器的极点位于 s 平面左半部分的半圆中;双线性变换将此半圆映射到您在问题描述中说明的椭圆形图案。将这种已知模式用于模拟巴特沃斯滤波器的极点、双线性变换的映射函数和一些代数,您可能能够为数字滤波器的极点位置提出一个相对简单的表达式,从而为您提供更直观的滤波器调整动作。

是的,Butterworth 和几乎所有其他过滤器响应都有标准实现形式。它们都在我的开源 IIR 滤波器库中完全实现。这是为任意度数的巴特沃斯滤波器生成极点/零对的代码片段:

void AnalogLowPass::design (int numPoles)
{
  if (m_numPoles != numPoles)
  {
    m_numPoles = numPoles;

    reset ();

    const double n2 = 2 * numPoles;
    const int pairs = numPoles / 2;
    for (int i = 0; i < pairs; ++i)
    {
      complex_t c = std::polar (1., doublePi_2 + (2 * i + 1) * doublePi / n2);
      addPoleZeroConjugatePairs (c, infinity());
    }

    if (numPoles & 1)
      add (-1, infinity());
  }
}

如您所见,极点的位置是通过将 s 平面细分为“对”相等的段来计算的。

为所有常见类型的过滤器响应提供了合适的代码:Chebyshev、Elliptic、Legendre,包括每个的现成版本。

https://github.com/vinniefalco/DSPFiltersDemo.git

https://github.com/vinniefalco/DSPFilters.git

截屏