Chapter4 PDF
Chapter4 PDF
Chapter4 PDF
Chapter 4
Design of FIR Filters
4.1
Introduction
Digital FIR filters have many favourable properties, which is why they are extremely popular in digital signal
processing. One of these properties is that they may exhibit linear phase, which means that signals in the passband will
suffer no dispersion. Dispersion occurs when different frequency components of a signal have a different delay through
a system.
The simplest design method for FIR filters is impulse response truncation (IRT), but unfortunately it has undesirable
frequency-domain characteristics, owing to the Gibbs phenomenon. The second design method for a FIR filter that we
shall cover in this Chapter is the windowing technique. The windowing method can be used to mitigate the adverse
effects of impulse response truncation.
4.2
The frequency response of a generalised FIR filter is defined by Equation 4.1 below.
H (z ) =
h[n] z k
(4.1)
k =
z = e sT e jwT e j
(4.2)
H () =
h[n] e jk
(4.3)
k =
The inverse Fourier transform of H () gives an expression for the impulse response of the FIR filter:
h[n] =
1
2
H () e
jn
(4.4)
Equations (4.3) and (4.4) form a Fourier transform pair. There is a similarity between this pair and the pair for a
periodic signal x(t ) , as shown in equations (4.5):
x (t ) =
X (k ) e j 2kf t
0
k =
X (kf 0 ) =
1
x (t ) e j 2kf 0t dt
T 0
(4.5)
Both of the functions x(t ) and H () are periodic. The Fourier transform of x(t ) gives the discrete function of kf 0 ,
in other words the discrete harmonics of the spectrum. The inverse Fourier transform of H () gives the discrete
function of n in other words the discrete samples of the impulse response of the filter.
4.2.1
Consider the ideal low-pass filter frequency response, as illustrated in Figure 4.1 below, with a normalised angular cut
off frequency c. Usually the subscript D is used to distinguish between the ideal and actual, impulse and frequency
responses of a filter.
Page 4.1
HD()
1
-2
-c
-2
1
hD [ n] =
2
1 e
jn
1 e jn
d =
2 jn
=
c
1 e jn c e jn c
2 jn
jn
1 2 j sin( n c )
=
jn
2
Multiplying both the numerator and denominator by c, the Equation above becomes:
h D [ n] =
c sin( n c )
( n c )
The impulse response of an ideal low-pass filter can also be re-written by replacing c = 2Fc in the Equation above, to
obtain it in terms of the normalised cut-off frequency Fc. This is illustrated in Equation 4.6 below.
hD [n] = 2 Fc
sin(n c )
( n c )
(4.6)
In Chapter 2, we found that the Fourier transform of a rectangular window is a sinc function, which is same for the
impulse response of a low-pass filter, as illustrated in Figure 4.2 below.
h[n]
4.3
With reference to Figure 4.2, although h[n] decays to either side of n = 0 it theoretically continues for ever in both
directions. This reflects a general antithesis between band limitation and time limitation; since we have chosen a
frequency response with a sharp cut-off (or brick wall response), then the time-domain response continues forever. To
realise such a filter the impulse response is truncated in some way or other. One approach is to ignore the small sample
values at the ends and shift h[n] to begin at n = 0, giving a causal filter as depicted in Figure 4.3.
In general, the more samples we include of h[n] the closer we get to the desired form of HD(), but the less economic
the filter becomes due to the relative number of computations. In practice we must settle for an approximation to the
ideal frequency response. It is usually customary to truncate the impulse response to N = (2M + 1) terms. In Figure 4.3,
the impulse response of the ideal low-pass filter is truncated to M = 9 samples and is delayed by M samples.
Page 4.2
h[n]
Figure 4.3: Truncated impulse response to 2M+1 samples, with a delay of M samples.
The z-transfer function of the filter now becomes:
H (z) =
h[n] z
( n + M )
(4.7)
n = M
The ideal impulse responses for a low-pass, high-pass, band-pass and band-stop filters are depicted in Table 4.1 below.
hD[n], n 0
Filter type
sin (n c )
n c
Low-pass
2 Fc
High-pass
1 2 Fc
2 F2
Band-pass
Band-stop
sin (n c )
n c
sin (n 2 )
sin (n1 )
2 F1
n 1
n 2
sin (n1 )
sin (n 2 )
1 2 F2
2 F1
n1
n 2
hD[n], n = 1
2 Fc
1 2 Fc
2 F2 2 F1
1 [2 F2 2 F1 ]
Table 4.1: Ideal impulse responses for various FIR filter types.
4.4
Choose the ideal frequency response HD(), depending on the type of filter (e.g. low-pass, high-pass etc), from
Table 4.1.
Calculate the impulse response of the ideal filter hD[n], using the inverse Fourier transform formula of Equation
4.5.
4.5
A measure of the error between the frequency response of the ideal filter HD() and that of the designed filter H() is
the integral of the squared error, defined by Equation 4.8.
E ( ) =
1
2
( ) H ( ) d
(4.8)
Filters designed by the IRT method are considered optimal in the sense of minimising the integral of the squared error.
However, the IRT approach is not considered practical because of the oscillatory nature of the frequency response near
the discontinuity points of the desired response HD(). It is the case that as N increases, the magnitude of the
oscillations remains the same, but they become more localised to the discontinuity, with the result that E() decreases
with increasing N. This property is known as the Gibbs phenomenon and is described in detail in Section 4.6.
Page 4.3
4.6
Gibbs Phenomenon
Truncating the impulse response introduces undesirable ripples and overshoots in the frequency response. This effect is
known as the Gibbs phenomenon and is illustrated in Figure 4.4. As an example, the impulse response for a low-pass
filter is truncated with M = 9, 25 and an infinite number of samples. Notice how the undesirable ripples and overshoots
are clearly visible in the frequency response.
M=9
H()
-c
M = 25
M = infinite
H()
-c
-c
H()
Figure 4.4: Effects on the frequency response of truncating the ideal impulse response.
In the time-domain truncation is achieved by multiplying the impulse response with a window function w(n).
Conversely, in the frequency-domain truncation is achieved by convolving the frequency response H() with W(),
where W() is the Fourier transform of the window function. In this example, the truncation was achieved by
multiplying the impulse response with a rectangular window function. The height of the ripples is not dependent on the
value of M, it only affects the width. The heights of the ripples are however controlled by the type of window function
used for the time-domain multiplication. Table 4.2 illustrates the mathematical definitions, and Figure 4.5 shows the
characteristic shape and amplitude responses of various window functions.
Name of window function w(n)
Rectangular
Hanning
Hamming
Blackman
Kaiser
Mathematical definition
1
2n
0.5 0.5 cos
N 1
2n
0.54 0.46 cos
N 1
2n
2n
0.42 0.5 cos
+ 0.08 cos N 1
N
2n N + 1
2
I 0 1
xk
N 1
I 0 ( x) = k
Where,
k = 0 2 k!
I o ( )
Page 4.4
Rectangular window
Rectangular window
1.2
10
5
0
-5
0.8
Decibels
w(n)
-10
0.6
-15
-20
0.4
-25
-30
0.2
-35
0
10
15
20
25
30
35
40
-40
-1
45
-0.8
-0.6
-0.4
Hanning window
-0.2
0
0.2
Frequency in Pi units
0.4
0.6
0.8
0.4
0.6
0.8
0.4
0.6
0.8
0.4
0.6
0.8
0.4
0.6
0.8
Hanning window
10
0.9
0
0.8
-10
0.7
Decibels
w(n)
0.6
0.5
0.4
0.3
-20
-30
-40
0.2
-50
0.1
0
10
15
20
25
30
35
40
-60
-1
45
-0.8
-0.6
-0.4
Hamming window
Hamming window
10
1
0.9
-0.2
0
0.2
Frequency in Pi units
0.8
-10
0.7
Decibels
w(n)
0.6
0.5
0.4
0.3
-20
-30
-40
0.2
-50
0.1
0
10
15
20
25
30
35
40
-60
-1
45
-0.8
-0.6
-0.4
Blackman window
10
0.9
0.8
-10
0.7
-20
0.6
-30
Decibels
w(n)
Blackman window
0.5
-40
0.4
-50
0.3
-60
0.2
-70
-80
0.1
0
10
15
20
25
30
35
40
-90
-1
45
-0.8
-0.6
-0.4
Kaiser window
10
0.9
0.8
-10
0.7
-20
0.6
-30
Decibels
w(n)
-0.2
0
0.2
Frequency in Pi units
Kaiser window
0.5
-40
0.4
-50
0.3
-60
0.2
-70
-80
0.1
0
-0.2
0
0.2
Frequency in Pi units
10
15
20
25
n
30
35
40
45
-90
-1
-0.8
-0.6
-0.4
-0.2
0
0.2
Frequency in Pi units
Figure 4.5: Window functions and their respective amplitude responses in dB.
Page 4.5
4.7
Figure 4.6 provides a graphical description of the specifications of a normalised low-pass filter. The shaded areas in the
pass band and in the stop band indicate the forbidden magnitude values in these bands. In the transition band there are
no forbidden values but it is usually required that the magnitude decreases monotonically in this band.
1+p
Fc = (Fp + 0.5F)
1-p
Ap = 20log10(1 + p)
As = - 20log10(s)
F = Fs - Fp
s
Fp
Pass band
Fc
Transition band
Fs
Stop band
(4.9)
The parameter p is the tolerance of the magnitude response in the pass-band and the desired magnitude response is
close to unity. The quantity p is called the pass-band ripple and can also be expressed in terms of dBs using Equation
4.10 below.
Pass-band ripple, Ap = 20log10(1 + p)
4.8
(4.10)
The IRT design method is only suitable for filters whose tolerances are about 21dB in the stop-band and 0.75dB in the
pass-band. Practical filters are almost always required to have smaller tolerances, so the IRT method is impractical. This
is due to the Gibbs oscillations, as seen in the amplitude response of Figure 4.4. However, in Chapter 2 windows were
shown to reduce the side-lobe interference resulting from truncating an infinite-duration signal to a finite length. In a
similar way, windows can also be applied to the impulse response of a FIR filter to attenuate the Gibbs oscillations.
When designing a FIR filter using the window method, it is customary to start by defining the ideal frequency response
HD() of the filter, as in the IRT method. Once the ideal frequency response has been obtained, it is then necessary to
obtain the ideal impulse response hD[n] from the inverse Fourier transform of the frequency response (Equation 4.5).
The next step in the design process is to select an appropriate window function based on the specification of the passband p and stop-band s tolerances of the filter. The tolerances of a FIR filter ultimately depend upon the type of
window function used for the windowing but in the design process we always start by assuming that s p. In Table
4.3 below, it illustrates various window functions and their corresponding properties to enable in the design of a filter.
Once the appropriate window function has been determined by the designer based on the filter specification, then the
required number of filter coefficients N can then be calculated. The final procedure of the design process is to determine
the actual filter coefficients h[n] by multiplying the coefficients of the window function with the corresponding ideal
impulse response. This is mathematically shown in Equation 4.12 below:
h[ n] = w[ n] hD [n ]
(4.12)
Page 4.6
Transition
width F in
(Hz),
(normalised)
0.9/N
3.1/N
3.3/N
5.5/N
2.93/N
3.63/N
4.32/N
5.71/N
Pass-band
ripple Ap in
(dB)
0.741
0.0546
0.0194
0.0017
0.0274
0.00867
0.00275
0.000275
Ripple
p, s
Side-lobe level
in (dB)
0.089
0.063
0.0022
0.000196
-13
-31
-41
-57
Stop-band
attenuation As
in (dB)
21
44
53
74
50
60
70
90
4.9
Obtain the impulse response hD[n] by evaluating the inverse Fourier transform.
Select an appropriate window function w[n], that satisfies pass-band and attenuation specifications, and determine
the number of coefficients required from the relationship between N and F.
Determine the values of the window function and calculate the actual FIR filter coefficients by multiplying the
impulse response with the window function.
H ( j ) =
n= M
h[n] e
jTn
(4.13)
n = M
where T is the sampling period. If the coefficients h[n] are symmetrical around h=0, this can be written:
M
(4.14)
The phase of the filter is given by the argument of the complex function in (4.14). Since the term in the curly brackets
is purely real it therefore contributes nothing to the phase response. The term e jTM on the other hand has a phase of
TM rad, which is clearly linear in .
We can therefore conclude that filters with symmetrical impulse response (i.e. symmetrical coefficients) have
linear phase; those with asymmetrical impulse response do not.
2.
3.
Page 4.7
4.
5.
Using the window method, determine an appropriate window function and calculate the required number of filter
coefficients to design this filter. Furthermore, ascertain the corresponding filter coefficient values h[n] for
10 n 10 .
1+p
Fc = (Fp + 0.5F)
1-p
Ap = 20log10(1 + p)
As = - 20log10(s)
s
Fp
Pass band
Fc
Transition band
Fs
Stop band
0 .1
p = log 101 1 = 0.0116
20
Minimum stop-band attenuation As = - 20log10(s)
1 50
s = log 10
20 = 0.00316
Fp = f p f s =
2 x10 3
= 0.2
10 x10 3
F = f f s =
200
= 0.02
10 x10 3
First of all we need to choose an appropriate window function from Table 4.3, which has the narrowest F but meets
the s specification of 0.00316. With reference to Table 4.3, the closest specification is the Hamming window with a s
= 0.0022. From the Table, the normalised transition width F = 3.3/N, where N is the number of filter coefficient. By
re-arranging this Equation to make N the subject and inserting the value of the normalised transition width, then the
required number of filter coefficients can be calculated. For FIR filters the number of coefficients must be odd, so dont
forget to round up to the nearest odd number.
N=
3.3
= 165
0.02
The mathematical definition of the hamming window to achieve the desired filter specification is defined from Table
4.2.
Page 4.8
2n
w[n] = 0.54 0.46 cos
164
From Table 4.1, the ideal impulse response of a low-pass filter is defined by the following equation.
hD [n] = 2 Fc
sin(n c ) sin(n c )
=
n c
n
Where the normalised angular cut-off frequency c is defined by the equation below:
hD [n] =
sin (2 0.21 n )
n
In the time-domain, truncation is achieved by multiplying the impulse response with the window function w[n]. Hence
the filter coefficients h[n] = -10, 10 can be obtained by:
h[10] =
Since the coefficients of a FIR filter are symmetric, by definition h[-10] = h[10].
E ( ) = W ( )[H D ( ) H ( )]
(4.15)
where H D ( ) and H ( ) are the ideal and actual frequency response functions respectively, and W ( ) is a function
to weight different parts of the band differently. One approach is to then determine the h(n) such that the maximum
weighted value of E ( ) is minimised. Thus determine:
min max
h[n ]
For the optimum design filter method it is necessary to first estimate the number of coefficients required. The starting
point is the empirical formula given in Equation (4.16).
1
2 1
N =
log10
3 F
10 p s
(4.16)
Having calculated this estimate, the values of the coefficients are then determined using a suitable DSP simulation
package (e.g. REMEZ in Matlab). Using these coefficient values, the frequency response is compared with that
required; if it is outside the original specification then the value of N is increased, and the design process repeated.
The advantage of this technique over the window-based method is that a smaller value can be specified for s than for
p , and this can lead to a significant saving in the number of coefficients required, as illustrated in the example below.
Example:
8-12 kHz
0.001
0.01
Page 4.9
44.14 kHz
3 kHz
For the window method, the following parameters apply for the Kaiser window:
Required passband ripple
Required stopband attenuation
Cutoff frequencies
Ripple parameter,
Number of filter coefficients, N
Sampling frequency
For the optimal method, the remez function in Matlab would require the following vectors as input:
F=[0, 5/22.07, 8/22.07, 12/22.07, 15/22.07, 1]
A=[0, 0, 1, 1, 0, 0]
W=[(1/0.001), (1/0.01), (1/0.001)]
1 2
2 1
1
1
log10
log10
N =
=
= 39
(
)
3 F
10
3
3
44
.
14
10
0
.
01
0
.
001
p s
The filter length of 39 is significantly less than that required for the Kaiser window method.
N.B. In Matlab the functions FIR1 and REMEZ use frequency normalised to fs/2. Hence the frequencies required for
REMEZ in Matlab will be 0, 5/(44.14/2), 8/(44.14/2), etc. However, just to confuse things, the Matlab function FREQZ
returns the frequency vector W as an angular frequency normalised to fs/2. Hence, a value of W=1 corresponds to a
frequency of (fs/2) Hz.
It is also possible to design the above two filters using the sptool in Matlab. This provides an interactive method of
adjusting the filter characteristics.
Page 4.10
addition. A summary of these four sources of noise and their corresponding affects on the filter performance are shown
in Table 4.4 below.
Source of noise
Affect on performance
Quantisation noise limits the
signal-noise-ratio (SNR).
A/D conversion.
Coefficient quantisation.
Reduces SNR.
Arithmetic overflow.
Reduction techniques
Increase number of bits.
Use multirate techniques.
Use sufficient Nos. of bits in
fixed-point representation.
Optimise selection of filter
coefficients.
Use floating-point arithmetic.
Use double word length for
intermediate results.
Optimise filter structure.
Scale filter coefficients (at cost
of reduced SNR).
Detect and use maximum
rather than overflowed value.
Use floating-point arithmetic.
Page 4.11