How to Design a Continuous Time Butterworth Filter
Design prototypes for stable, efficient, parametric IIR filters.
In the last article, I outlined the process of creating a parametric filter. The steps are
- Decide on the filter type.
- Design an analog prototype.
- Digitize the analog prototype using the bilinear transform.
- Implement the digital filter.
Here's how the process looks:
Figure 1. Parametric filter design workflow.
In this article, we'll discuss the second step of the process: designing the analog prototype.
Figure 2. In this article, we discuss analog prototype design.
Recap
As you remember from the previous article, parametric filters must have [VälimäkiReiss16]
- interpretable, real-time-adjustable controls and
- low processing delay.
This led us to choose infinite-impulse response (IIR) filters. To streamline the process of their design and to ensure that they remain stable, we said that the easiest way to come up with these filters is to design them in the analog domain and then digitize them.
How to design them in the analog domain, then?
Our Goal
Designing a filter in the analog domain is traditionally done by designing a low-pass filter with some of the desired characteristics and then transforming it to the desired filter type, for example, high-pass. This can be done with transformations like lowpass-to-bandpass transformation or lowpass-to-highpass transformation.
What is more, we can set the cutoff frequency of the low-pass filter to 1, because this frequency will be altered by the bilinear transform anyway.
So our first goal is to design a low-pass filter with the cutoff frequency equal to 1.
It's all downhill from there. 😉
Analog Filters Design Methods
Filter design in the analog or digital domain is the process of approximating the desired frequency response with a certain set of constraints. [Smith07]
As such, it may be considered a form of constrained optimization.
There are many methods to achieve this, as there are many optimization methods. There are, however, 4 basic filter approximations considered as standard. Each of them is optimal in a different sense [OppenheimSchafer10].
In Short
Standard Analog Filter Design Methods
Method | What is optimal? |
---|---|
Butterworth | The amplitude response is maximally flat in the passband. |
Chebyshev type I | The amplitude response is equiripple (has ripples on the curve of a fixed width) in the passband and monotonic in the stopband. |
Chebyshev type II | The amplitude response is monotonic in the passband and equiripple in the stopband. |
Elliptic functions | The amplitude response has equiripple error in the passband and the stopband. |
But in equalizer filters mostly Butterworth responses are used, because the amplitude response is monotonic (without any ripples) and the higher the frequency above the cutoff frequency, the bigger the filter's attenuation [Zölzer08].
Additionally, it is easy to control the slope of the roll-off above the cutoff frequency with the filter order. If the filter order is , its attenuation in the stopband is dB per octave (each doubling of frequency) [Zölzer08].
Analog Prototype Butterworth Low-pass
We know that we want to design an analog prototype low-pass using the Butterworth approximation. What do we want to approximate exactly?
Approximation Goal
The goal of the approximation is the ideal low-pass filter.
Figure 3. Amplitude response of the ideal low-pass filter with cutoff frequency equal to 1.
Frequency is the analog cutoff frequency in radians per second. We assume that , i.e., the filter's transfer function is normalized.
Our only constraint is the filter order. According to [Zölzer08] the most commonly used orders are and .
Butterworth Filter Derivation
WARNING: This part is math-heavy. It is intended for those who want to fully understand the derivation of analog prototypes. If you don't want to get that deep, just use tabularized, ready-made formulas. You can skip to their examples here.
Note: This part is based on the great explanation from [ParksBurrus87].
The frequency response of an analog filter is found by evaluating its transfer function along the imaginary axis, i.e., for .
We will formulate the problem of approximating the ideal filter in terms of the squared magnitude response . That is because is an analytic, real-valued function of a real variable, i.e., high-school mathematics apply. Another reason is that is proportional to the energy or power of the signal, which may be useful depending on the context.
To be able to get from the squared magnitude response to the transfer function, we introduce an intermediate, complex-valued function of the complex variable
It can be easily shown that
The Butterworth squared magnitude response is a Taylor series approximation of the ideal squared magnitude response around .
Taylor Series
Taylor series around is
where
with .
General Squared Magnitude Response
The squared magnitude response is an even function (symmetric with respect to the value axis) so it may be written in a general form as a function of , i.e., neglecting the odd powers of because they are odd functions. The general form reads
The following observations can already be made with regard to Equation 5.
- We require that so we can readily set .
- We require that which leads to the conclusion that the denominator must have a greater order than the numerator, i.e., and .
Error Formulation
We can write in terms of the sum of the desired value at and approximation error
We can insert Equation 6 into Equation 5 and obtain
Error Minimization
To achieve the closest Taylor approximation possible (minimize error ), we want to eliminate as many low order terms as possible so we set
Equations 8-13 tell us that the numerator of from Equation 5 can be arbitrary, because any setting of parameters and subsequent setting of parameters will yield equally good Taylor approximation.
That allows us to pick the numerator as we wish. In order to have , we set and .
We, thus, obtain
Determining the Cutoff Frequency
Parameter determines the analog cutoff frequency so that (-3 dB point).
We have already decided that for us so we need to set
Final Squared Magnitude Response
We obtained the final formula for the analog Butterworth low-pass filter of the -th order
Equation 16 is the Taylor approximation of the ideal low-pass filter's squared magnitude response at . This means that is maximally flat at .
It turns out that Equation 16 is at the same time the Taylor approximation at . So is maximally flat at both ends: and . That is why, Butterworth filter is said to have maximally flat amplitude response at the endpoints [Smith07].
Transfer Function Derivation
You may wonder:
Since Equation 16 is the squared magnitude response, how do we obtain the transfer function over the -domain?
We can use the definition of from Equation 1.
because if we substitute , we arrive back at Equation 16.
The fractional on the right side of Equation 17 has exactly poles. What are they?
Note: This indexing of is chosen so as to simplify further derivations. Another but equivalent indexing is .
So has poles evenly spaced around the unit circle. As their number is even, they are placed symmetrically: on the left half-plane, on the right half-plane.
Since we want just , we need to factorize into and .
For to be stable, we need all of its poles to lie on the left half-plane of the -plane, i.e., have negative real parts.
We can obtain it by finding the poles of (which lie on the right half-plane) and negating their real parts (because the poles are symmetrical with respect to the imaginary axis).
Poles of are from Equation 23 with arguments in the range, i.e., for if is odd, and for if is even. After negating the real part of these , we obtain the pole locations of
Note: Negating the real part of a complex number is equivalent to negating its complex conjugate.
Knowing all the poles, we can write out in the factorized version. Let's consider odd first (so ).
We did it! Now let's just polish this formula.
Tidying Up the Product
The polynomial in the denominator of Equation 17 has real coefficients. Therefore, all roots occur in complex conjugate pairs apart from , which is a real number (remember, we consider -odd case now).
Since the complex conjugate lies on the same half-plane, we can combine the roots with their conjugates to create a neat-looking real polynomial in the denominator. The single real pole ( ) must be factored out of the product, because it doesn't have a conjugate pair.
with (note the lack of nonpositive integers).
For even, we obtain analogously (without any real roots)
where . This comes from having to facilitate derivations.
According to [ParksBurrus87], Equations 26 and 27 are very convenient forms for implementation.
We did it! We obtained our analog prototype!
Now, let's analyze it a little bit. 😉
Butterworth Low-pass Transfer Function
As an example, the low-pass transfer function of the second-order Butterworth low-pass is [Zölzer08]
The fourth-order Butterworth low-pass has the following transfer function
Hint: To obtain an arbitrary analog cutoff frequency , simply replace with in the above transfer functions.
Visualization
To see, how much the Butterworth low-pass filter deviates from the ideal response from Figure 3, let's plot the amplitude responses of both filters against the ideal response.
Figure 4. Butterworth low-pass amplitude response of 2nd, 4th, and 11th order plotted against the ideal response.
The 11th order is shown for additional comparison.
We can observe that Butterworth filters cross the cutoff frequency with exactly the same gain, which is . That means that our derivations are correct.
Additionally, we can observe that the higher the filter order, the more steep the slope of the transition band (between the passband and the stopband).
Figure 4 also shows that the Butterworth approximation is indeed maximally flat at frequencies and .
Figure 5 shows the same amplitude responses but this time the magnitude is expressed in decibels ( ). The -3 dB at cutoff frequency is clearly visible.
Figure 5. Butterworth low-pass amplitude response in decibels for 2nd, 4th, and 11th orders plotted against the ideal response.
To obtain the transfer function, I used the Polynomial
class from the numpy.polynomial.polynomial
module of the NumPy library.
SciPy has a ready-made function to obtain the transfer function of an arbitrary analog filter with one of 5 different design methods. Alternatively, you may check out my implementation for the Butterworth case.
To obtain plots in Figures 4 and 5, I used the scipy.signal.freqs
function from the Python SciPy library.
All these SciPy functions have their equivalents in Matlab.
Summary
We did it! We obtained the transfer function of an analog low-pass filter which we can now digitize with the bilinear transform and then transform to the desired form (high-pass, band-pass, etc.).
I put a lot of effort into this article: if you find it useful, please, let me know in the comments!
If you have any questions, I would be happy to answer them in the comments as well.
Thank you for reading! 🙂
Bibliography
[OppenheimSchafer10] Alan V Oppenheim, Ronald W. Schafer, Discrete-Time Signal Processing, 3rd Edition, Pearson 2010.
[ParksBurrus87] T. W. Parks, C. S. Burrus, Digital Filter Design, John Wiley & Sons, Inc., 1987.
[Smith07] Julius O. Smith, Introduction to Digital Filters with Audio Applications, http://ccrma.stanford.edu/~jos/filters/, online book, 2007 edition, accessed November 26, 2021.
[VälimäkiReiss16] Vesa Välimäki, Joshua D. Reiss, All About Audio Equalization: Solutions and Frontiers [PDF], Applied Sciences, Vol. 6, Issue 5, May 6, 2016.
[Zölzer08] Zölzer Udo, Digital Audio Signal Processing, 2nd ed., Helmut Schmidt University, Hamburg, Germany, John Wiley & Sons Ltd, 2008.
Links above may be affiliate links. That means that I may earn a commission if you decide to make a purchase. This does not incur any cost for you. Thank you.
Source: https://thewolfsound.com/analog-prototype/
0 Response to "How to Design a Continuous Time Butterworth Filter"
Post a Comment