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 N, its attenuation in the stopband is N⋅6 dB per octave (each doubling of frequency) [Zölzer08].
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 ωa is the analog cutoff frequency in radians per second. We assume that ωa=1, 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 N=2 and N=4.
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 H(s) along the imaginary axis, i.e., for s=jω.
We will formulate the problem of approximating the ideal filter in terms of the squared magnitude response ∣H(jω)∣2. That is because ∣H(jω)∣2 is an analytic, real-valued function of a real variable, i.e., high-school mathematics apply. Another reason is that ∣H(jω)∣2 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 s
Ha(s)=Ha(s)Ha(−s).(1)
It can be easily shown that
Ha(s)s=jω=∣Ha(jω)∣2.(2)
The Butterworth squared magnitude response Ha(ω)=∣Ha(jω)∣2 is a Taylor series approximation of the ideal squared magnitude response around ω=0.
Taylor Series
Taylor series around ω=0 is
Ha(jω)=K0+K1ω+K2ω2+⋯=k=0∑∞Kkωk,(3)
where
Kk=k!1dωkdkHa(ω)ω=0,(4)
with K0=Ha(0).
General Squared Magnitude Response
The squared magnitude response Ha(jω) is an even function (symmetric with respect to the value axis) so it may be written in a general form as a function of ω2, i.e., neglecting the odd powers of ω because they are odd functions. The general form reads
Equations 8-13 tell us that the numerator of Ha(jω) from Equation 5 can be arbitrary, because any setting of parameters d0,…,d2M and subsequent setting of parameters c0,…,c2M will yield equally good Taylor approximation.
That allows us to pick the numerator as we wish. In order to have Ha(j∞)=0, we set c0=d0=1 and d2=d4=⋯=d2M=0.
We, thus, obtain
Ha(jω)=1+c2Nω2N1.(14)
Determining the Cutoff Frequency
Parameter c2N determines the analog cutoff frequency ωa so that Ha(ωa)=21 (-3 dB point).
We have already decided that for us ωa=1 so we need to set
c2N=1.(15)
Final Squared Magnitude Response
We obtained the final formula for the analog Butterworth low-pass filter of the N-th order
Ha(jω)=1+ω2N1.(16)
Equation 16 is the Taylor approximation of the ideal low-pass filter’s squared magnitude response at ω=0. This means that Ha(jω) is maximally flat at ω=0.
It turns out that Equation 16 is at the same time the Taylor approximation at ω=∞. So Ha(jω) is maximally flat at both ends: ω=0 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 s-domain?
We can use the definition of Ha(s) from Equation 1.
Ha(s)=Ha(s)Ha(−s)=1+(−s2)N1,(17)
because if we substitute s=jω, we arrive back at Equation 16.
The fractional on the right side of Equation 17 has exactly 2N poles. What are they?
(−s2)N+1=0,(18)(−s2)N=−1,(19)(−1)Ns2N=−1,(20)s2N=(−1)N+1,(21)s2N={−1,if N is even,1,if N is odd.(22)sk={ei(π+2kπ)/2N,if N is even,ei2kπ/2N,if N is odd.,k=−(N−1),−(N−2),…,0,1,2,…,N−1,N.(23)
Note: This indexing of k is chosen so as to simplify further derivations. Another but equivalent indexing is k=0,1,2,…,2N−1.
So Ha(s) has 2N poles evenly spaced around the unit circle. As their number is even, they are placed symmetrically: N on the left half-plane, N on the right half-plane.
Since we want just Ha(s), we need to factorize Ha(s) into Ha(s) and Ha(−s).
For Ha(s) to be stable, we need all of its poles to lie on the left half-plane of the s-plane, i.e., have negative real parts.
We can obtain it by finding the poles of Ha(−s) (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 Ha(−s) are sk from Equation 23 with arguments in the (−π/2,π/2) range, i.e., for k=0,±1,±2,…,±(N−1)/2 if N is odd, and for k=0,±1,±2,…,±(N/2−1),−N/2 if N is even. After negating the real part of these sk, we obtain the pole locations of Ha(s)
skHa(s)={−e−i(π+2kπ)/2N,k=0,±1,…,±(N/2−1),−N/2if N is even,−e−i2kπ/2N,k=0,±1,±2,…,±(N−1)/2if N is odd.(24)
Note: Negating the real part of a complex number is equivalent to negating its complex conjugate.
Knowing all the poles, we can write out Ha(s) in the factorized version. Let’s consider N odd first (so k=0,±1,±2,…,±(N−1)/2).
Ha(s)=k∏s−sk1=k∏s+e−i2kπ/2N1.(25)
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 s0, which is a real number (remember, we consider N-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 (−1) must be factored out of the product, because it doesn’t have a conjugate pair.
with k=1,2,…,(N−1)/2 (note the lack of nonpositive integers).
For N even, we obtain analogously (without any real roots)
Ha(s)=m∏s2+2cos(mπ/2N)s+11,(27)
where m=1,3,…,N−1. This comes from having m=2k+1,k=0,1,…,(N/2−1) 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]
H2(s)=s2+2s+11.(28)
The fourth-order Butterworth low-pass has the following transfer function
H4(s)=(s2+1.848s+1)(s2+0.765s+1)1.(29)
Hint: To obtain an arbitrary analog cutoff frequency ωa, simply replace s with s/ωa 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 1/2. 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 ω=0 and ω=∞.
Figure 5 shows the same amplitude responses but this time the magnitude is expressed in decibels (20log10(⋅)). 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.
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.
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.
Comments powered by Talkyard.