DIGITAL SIGNAL PROCESSING
(PCC-EC592)
Project Name
FIR Filter Design Using Hamming Window
In Matlab
Year: 3rd Semester: 5th
Group: E5
Members:
Debayan Chatterjee (22022002003018)
Yaman B Gazmer (22022002003037)
Acknowledgement
It is my great pleasure to present this laboratory manual for third
year engineering students for the subject of DIGITAL SIGNAL
PROCESSING using Matlab. As a student, many of you may be
wondering with some of the questions in your mind regarding the
subject and exactly that has been tried to answer through this
manual. Faculty members are also advised that covering these
aspects in initial stage itself will greatly relieve them in future, as
much of the load will be taken care by the enthusiastic energies of
the students, once they are conceptually clear.
Thanking you,
Debayan Chatterjee
Yaman B Gazmer
CONTENTS
Introduction………………………………………………………………………….
Design Method Of FIR Filters…………………………………………………
Program ……………………………………………………………………………….
Simulation Results………………………………………………………………..
Application……………………………………………………………………………
Conclusion…………………………………………………………………………….
References…………………………………………………………………………….
INTRODUCTION
The digital signal processing has become an extremely important
subject. A fundamental aspect of digital signal
processing is filtering. A digital filter is a system that performs
mathematical operations on a sampled, discrete-time
signal to reduce or enhance certain aspects of that signal. There are
two types of digital filters on the basis of the impulse
response of the filter:
1.Infinite Impulse Response (IIR) filters, and
2.Finite Impulse Response (FIR) filters.
Digital filters with infinite duration impulse response referred to as
IIR filters. IIR filters are recursive type filters where
by the present output depends on the present input, past input and
past outputs. Digital filters with finite duration impulse
response referred to as FIR filters. FIR filters are non-recursive type
filters where by the present output depends on
present input and past inputs. FIR filters are widely used than IIR
filters, because FIR digital filters have an exactly linear
phase, always stable, non-recursive structure and arbitrary
amplitude-frequency characteristic etc. [1], [3]. In view of the
design and simulation analysis, the design of digital filter is
quickly and efficiently achieved by using powerful
computing capabilities of MATLAB.
Design Method Of FIR Filters
There are different methods for the design of FIR digital filter. The
most common methods are
1. Fourier series method.
2. The window method
3. Frequency sampling method.
4. Optimal filter design method.
1 .Fourier series method: In this method, the desired frequency
response specification Hd(w) and corresponding unit sample
response hd(n) is determined. In general, unit sample response
hd(n) obtained from the above relation is infinite in duration, so it
must be truncated at some point say n= + or - (n-1)/2 to yield an FIR
filter of length N. The amplitude response of the filter exhibits
oscillations in the pass band as well as in the stopband, which are
known as Gibb’s oscillations. They are caused by the truncations of
the Fourier series. As the length of the filter increased, the frequency
of the oscillations increases but the amplitude stays constant. In
other words, we do not seem to be able to reduce the pass band and
stop band errors below a certain limit by increasing the filter length.
Therefore, the filters that can be designed using the Fourier series
method are of little practical usefulness.
2. Window method: Several window functions have been proposed.
Listed below are some of the most common:
1.Rectangular Window
2.Hanning Window
3.Hamming Window
4.Blackman Window
5.Kaiser Window
To reduce the oscillations in Fourier series method, the Fourier
coefficients are modified by multiplying the infinite response by
finite weighing sequence w (n) called a window. Windows are
characterize by the main lobe width which is the bandwidth between
first negative and first positive zero crossing, and by their ripple ratio.
The main lobe width and the ripple ratio should be as low as
possible; i,e the spectral energy of the window should be
concentrated as far as possible in the main lobe and the energy in
the side lobes should be as low as possible.
Two desirable characteristics of a window function are [2];
(1). Fourier transform of the window function should have a small
width of the main lobe.
(2).Fourier transform of the window function should have side lobes
that decrease in energy rapidly as / tends to 0.
Windows can be categorized as fixed or adjustable window
function. Fixed windows such has Rectangular, Hanning,
Hamming and Blackman window have only one independent
parameter window length which controls the main-lobe
width. Adjustable windows have two or more independent parameters
such as window length and one or more additional
parameters that can control the other window’s characteristics [5,
7]. The Kaiser window is a kind of two parameter
window function. In a Kaiser window width of main lobe can be
controlled by adjusting the length of the filter and side lobe level can
be controlled by varying the other parameter α. But the Kaiser
window has the disadvantage of higher computational complexity
due to the use of Bessel functions in the calculation of the window
coefficients.
3. Frequency sampling method: In this method the given frequency
response is sampled at a set of equally spaced frequencies to obtain
N samples. Thus, sampling the continuous frequency response Hd
(w) at N points essentially gives us the N-point DFT of Hd(2pnk/N).
Thus by using the IDFT formula. The main attraction in this method is
that it allows for a recursive realization of FIR filters, which can be
computationally very efficient. However, it also lacks flexibility in
specifying or controlling filter parameters.
4. Optimal filter design method: With efficient and easy to use
programs it is now widely used in industry. To reduce the error in
frequency sampling method this method is used and this method is
best method to design the FIR filter. The basic idea of this method is
to design the filter coefficients again and again until a particular error
is minimized. But to determine the filter coefficients by using optimal
filter design method is very complex.
A complete procedure for the design of FIR filters are as follows:
1. Specification of the filter.
2. Choosing an appropriate linear phase filter type.
3. Choosing the method of design such as window.
4 .Calculation of the filter coefficients (impulse response).
5. Analysis of the finite word length effects.
6. Implementation of the filter in hardware and software.
Program
Source Code
clc;
clear all;
rp = input('Enter the passband ripple = ');
rs = input('Enter the stopband ripple = ');
fp = input('Enter the passband frequency = ');
fs = input('Enter the stopband frequency = ');
f = input('Enter the sampling frequency = ');
wp = 2*fp/f;
ws = 2*fs/f;
num = -20*log10(sqrt(rp*rs))-13;
dem = 14.6*(fs-fp)/f;
n = ceil(num/dem);
n1 = n+1;
if (rem(n,2)==50)
n1 = n;
n = n-1;
end
y = hamming(n1);
% low-pass filter
b = fir1(n,wp,y);
[h,o] = freqz(b,1,256);
m = 20*log10(abs(h));
subplot(2,2,1);
plot(o/pi,m);
title('Magnitude Response of LPF');
ylabel('Gain in dB ---->');
xlabel('Normalised Frequency ---->');
grid on;
% high-pass filter
b = fir1(n,wp,'high',y);
[h,o] = freqz(b,1,256);
m = 20*log10(abs(h));
subplot(2,2,2);
plot(o/pi,m);
title('Magnitude Response of HPF');
ylabel('Gain in dB ---->');
xlabel('Normalised Frequency ---->');
grid on;
% band pass filter
wn = [wp ws];
b = fir1(n,wn,y);
[h,o] = freqz(b,1,256);
m = 20*log10(abs(h));
subplot(2,2,3);
plot(o/pi,m);
title('Magnitude Response of BPF');
ylabel('Gain in dB ---->');
xlabel('Normalised Frequency ---->');
grid on;
% band stop filter
b = fir1(n,wn,'stop',y);
[h,o] = freqz(b,1,256);
m = 20*log10(abs(h));
subplot(2,2,4);
plot(o/pi,m);
title('Magnitude Response of BSF');
ylabel('Gain in dB ---->');
xlabel('Normalised Frequency ---->');
grid on;
Simulation Results
The design of FIR filter using hamming window function for different
values of ripple and frequency are shown in the figure below. we
considered a pass band ripple of 0.05 and a stop band ripple of 0.03,
a pass band frequency of 1300 rad/s and a stop band frequency of
1600rad/s with a normalized frequency of 7400rad/s. Considering
these values the order of the filter becomes 26.After simulation it is
observed that this window function provides lesser main lobe width
than the other window techniques, however the amplitude of the
side lobe and ripples in pass band is also increased.
APPLICATIONS
From the above simulation result it is found that the designed FIR
filter has lesser main lobe width so it can be used in speech
processing applications such as speech filtering, noise reduction,
frequency boosting and digital audio equalizing etc. In speech
filtering; filter are used to modify the frequency response of a
speech signal according to require applications of speech
processing. Designed low-pass FIR filter is used to eliminate the high-
frequency spectrum of the speech signal also as the designed filter
has lesser main lobe width so it is very useful for spectral analysis of
a signal.
CONCLUSION
In this paper, an FIR filter has been designed using hamming window
function. This type of window function is simple in operation and
provides greater flexibility in digital signal processing applications.
In frequency resolution problems a small main lobe width of window
function in frequency domain is required. In the range 0≤α ≤ 1, for
large values of α, as the value of α increase the main lobe width
is continuously decreasing; however the amplitude of side lobe is
also increased. In signal processing applications digital filters are
more preferable than analog filters. The digital filters are easily
designed and also easy to use in several of signal filtering
applications. The choice of technique to design the filter depends
heavily on the decision of designer whether to compromise
accuracy of approximation .FIR filter design by using hamming
window is stable as compare to rectangular and hanning window
techniques. Ripples in pass band are less in hamming as compared to
rectangular and hanning and also hamming has a linear phase than
rectangular and hanning.
REFERENCES
[1] J.G. Proakis and D. G. Manolakis, Digital Signal Processing
Principles, Algorithms and Applications 3rd Edition Prentice- Hall,
2002.
[2] Sanjit K. Mitra, Digital Signal Processing: A Computer-base
approach, Tata McGraw-Hill, 2nd Edition 2001.
[3] P. Ramesh Babu, Digital Signal Processing 4th Edition.
[4] Sonika Gupta, Aman Panghal Performance Performance analysis
of FIR Filter Design by using Rectangular, Hanning, and Hamming
window methods International Journal of Advanced Research in
Computer Science and Software Engineering Volume 2, Issue 6, June
2012.
[5] T. Saramaki, Finite impulse response filter design in Handbook for
Digital Signal Processing, Edited by S. K.
Mitra and J. F. Kaiser, IBSN 0-471-61995-7 John Wiley &Sons Inc,
1993.
[6] FREDRIC J.HARRIS On the Use of Windows for Harmonic
Analysis with the Discrete Fourier Transform
processing of IEEE vol.66 no.1 January 1978.