FPGA-Based FIR Filter Design
FPGA-Based FIR Filter Design
Submitted By
PRABHAT RANJAN
Roll No.-60661018
In this thesis, a low-pass, band pass and high pass FIR filter is implemented in
FPGA. Direct-form approach in realizing a digital filter is considered. This approach
gives a better performance than the common filter structures in terms of speed of
operation, cost, and power consumption in real-time. The FIR filter is implemented in
Spartan-III-xc3s500c-4fg320 FPGA and simulated with the help of Xilinx ISE (Integrated
Software Environment). Software WEBPACK project navigator 9.2i was used for
synthesizing and simulation the code.
Codes for direct form fixed point FIR filter have been realized. Modules such as
multiplier, adder, ram and two’s compliment were used. For an N order filter the number
of shift register and adders required is N and the number of multipliers required is N+1.
These filters can work in real time.
TABLE OF CONTENTS
Certificate i
Acknowledgement ii
Abstract iii
Table of Contents iv
List of Figures vii
List of Tables ix
Abbreviation x
References 58-59
Appendix 60-63
LIST OF FIGURES
Figure No. Title Page
No.
1.1 General
In signal processing, the function of a filter is to remove unwanted parts of the
signal, such as random noise, or to extract useful parts of the signal, such as the
components lying within a certain frequency range [1].
There are two types of filter analog and digital. FIR Filter is the kind of digital filter,
which can be used to perform all kinds of filtering i.e. high pass, low pass, band pass and
band reject etc.
o Advantages:
Simple and consolidated methodologies of plan,
Fast and simple realization.
o Disadvantages:
Little stable and sensitive to temperature variations,
Expensive to realize in large amounts.
1.1.2 Digital Filters
A digital filter uses a digital processor to perform numerical calculations on
sampled values of the signal. The processor may be a general-purpose computer such as a
PC, or a specialized DSP (Digital Signal Processor) chip [2].
o Advantages:
A digital filter is programmable,
Digital filters are easily designed, tested and implemented on
computer or workstation,
Digital filters are extremely stable with respect both to time and
temperature,
Digital filters can handle low frequency signals accurately,
Digital filters are very much versatile.
where, y(n) is the current filter output, the ’s are previous filter outputs,
the ’s are current or previous filter inputs, the are the filter’s feed forward
coefficients corresponding to the zeros of the filter, the are the filter’s feedback
coefficients corresponding to the poles of the filter, and N is the filter’s order.
FIR, Finite Impulse Response, filters are one of the primary types of filters used
in Digital Signal Processing. FIR filters are said to be finite because they do not have any
feedback. Therefore, if we send an impulse through the system (a single spike) then the
output will invariably become zero as soon as the impulse runs through the filter.
IIR filters have one or more nonzero feedback coefficients. That is, as a result of
the feedback term, if the filter has one or more poles, once the filter has been excited with
an impulse there is always an output. FIR filters have no non-zero feedback coefficient.
That is, the filter has only zeros, and once it has been excited with an impulse, the output
is present for only a finite (N) number of computational cycles [3].
Because an IIR filter uses both a feed-forward polynomial (zeros as the roots) and
a feedback polynomial (poles as the roots), it has a much sharper transition characteristic
for a given filter order. Like analog filters with poles, an IIR filter usually has nonlinear
phase characteristics. Also, the feedback loop makes IIR filters difficult to use in adaptive
filter applications.
Due to its all zero structure, the FIR filter has a linear phase response when the
filter’s coefficients are symmetric, as is the case in most standard filtering applications. A
FIR’s implementation noise characteristics are easy to model, especially if no
intermediate truncation is used. In this common implementation, the noise floor is at
- 6.02 B + 6.02 log2N dB, where B is the number of actual bits used in the filter’s
coefficient quantization and N is again the filter order. That’s why most Intersil filter ICs
have more coefficient bits than data bits.
An IIR filter’s poles may be close to or outside the unit circle in the Z plane. This
means an IIR filter may have stability problems, especially after quantization is applied.
An FIR filter is always stable [3].
A digital filter is characterized in terms of difference equations .There are two
types of digital filters, they are non-recursive, and recursive filters which are
characterized based on their responses [1].
The response of a non-recursive filter at any instant depends on the present, past
and future values of the input. At any specific instant nT. The response is of the form
In addition, assuming ai 0 for i > N the response can be written as Nth-order linear
difference equation given as:
N
y ( nT ) ai x ( nT iT ) (1.4)
i 0
is applied to the system described by Equation (1.4), then the response, which is nothing
but the impulse response h(nT) is given as
N
h(nT )= ai ( nT iT ) (1.5)
i=0
From the above equation it can be inferred that the impulse response is finite and from
the property of the impulse function we can see that the constants ‘ ai ’s are nothing but
the samples of the impulse response. That means
h(0) a0 , h(T ) a1............h( nT ) an (1.6)
these constants are called the filter coefficients. They determine the type of the filter,
whether it is Low-pass, or High-pass, etc. Thus in filter design it is always important to
find the filter coefficients which mostly approximates the desired response.
In general, one can view equation 1.3 as a computational procedure (an algorithm)
to determine the output sequence y(nT) from the input sequence x(nT). In addition, in
various ways, the computations in equation 1.3 can be arranged into equivalent sets of
difference equations. Normally such a kind of re-arrangement of the basic difference
equation is done, to gain benefits in terms of memory, time-delays, computational
complexity, etc. before implementing the system in the computer. Each set of equations
defines a computational procedure or an algorithm for implementing it in a digital
computer system [1].
From these set of difference equations we can construct a block diagram
consisting of an interconnection including delay elements, multipliers, and adders. Such a
block diagram can be further analyzed in terms of signal flow diagrams. Such a block
diagram can be referred as a realization of the system or in other words as a structure for
realizing the system. These structures are nothing but the filter structures.
One of the limitations of the FIR filter is that the order of the filter is generally
large in order to meet the desired specifications of the filter. As the filter order is
increased, the computational complexity is more which may limit the frequency of
operation.
Traditionally, a DSP algorithms are implemented either using general purpose
DSP processors (low speed, less expensive, flexible) or using Application Specific
Integrated Circuits (ASIC) which offer high speed but are expensive and less flexible.
An alternate approach is to use Field Programmable Gate Arrays (FPGA) as they
provide solutions that maintain both the advantages of the approach based on DSP
processors and the approach based on ASICs. Since many current FPGA architectures are
in-system programmable, the configuration of the device may be changed to implement
different functionality if required.
In Chapter 4, the Simulation and Synthesis tools which are used in implementation of
FIR filter is discussed. This chapter also discusses the FPGAs architecture, FPGA Design
Flow, Spartan-III FPGA kit specifications.
Chapter 5 discusses about how FIR filter can be realized and the process of
implementation of FIR filter. It also discusses restriction and assumption of filter,
choosing the filter structure, because it is often important to choose a particular filter
structure for a given transfer function H (z).This chapter also discusses Fixed Point
Representation of data.
Chapter 6 contains results of simulation using ModelSim and XILINX ISE 9.2i of
lowpass, bandpass and highpass filters of given specifications.
Chapter 7 concludes the thesis and also discusses future scope of work.
CHAPTER 2
FIR Filter Design
2.1 Introduction
The design of a digital filter involves following five steps
Filter specification: This may include stating the type of filter, for example low pass
filter, the desired amplitude and/or phase responses and the tolerances, the sampling
frequency, the wordlength of the input data.
Filter coefficient calculation: The coefficient of a transfer function H(z) is
determined in this step, which will satisfy the given specification. The choice of
coefficient calculation method will be influenced by several factors. The most
important of which are the critical requirements i.e specification.
Realization: This involves converting the transfer function into a sutable filter
network or structure.
These five inter related steps are summarized by flow chart
Start
Performance specification
Calculation of filter
coefficients
Realization structuring
Stop
In the passband, the magnitude response has a peak deviation of äp and in the
stopband, it as a maximum deviation of äs. The width of transition band determines haw
sharp the filter is. The magnitude response decreases monotonically from the passband to
stopband in this region.
The following are the key parameters of interest:
äp peak passband deviation(or ripples)
äs stopband deviation.
fs stopband edge frequency.
fp passband edge frequency.
Fs sampling frequency.
The edge frequencies are often given n the normalized form, that is as the fraction
of the sampling frequency (f/Fs). Passband and stopband deviation may be expressed in
decibels. When they specify the passband ripples and minimum stopband attenuation
respectively. Thus the minimum stopband attenuation, As and the peak passband ripple,
Ap, in decibels are given as
As (stopband attenuation) = -20log10 äs
Ap (passband ripple) = 20 log10 (1+äp)
The difference between fs and fp gives the transition width of the filter. Another
important parameter is the filter length, N, which defines the number of filter.
1
hD ( n ) H D ( )e j n d (2.1)
2
Now start with the ideal lowpass response shown in figure, where ùc is the cutoff
frequency and the frequency scale is normalised: T=1. By letting the response go from
– ùc to ùc we simplify the integration operation. Thus the impulse response is given by:
c
1 j n 1 j n
hD (n) 1* e d e d
2
2 c
2 fc
sin( nc ) , ≠0, -∞ ≤ ≤∞
nc
2f , =0 (2.2)
2 2
sin( nc )
Lowpass 2 fc 2 fc
nc
sin( nc )
Highpass 2 f c 1 2 fc
nc
sin( n2 ) sin( n1 )
2 f2 2 f1 2( f 2 f1 )
Bandpass n2 n1
The ideal infinite impulse response is truncated by using various windows. Here we
multiply the ideal frequency response with a window function. When this window is
multiplied by the ideal transfer function then all the coefficients with in the window are
retained and all that are outside the window are discarded.
Table2.2 Summary of important features of common window function
Name of window Transition width(Hz) Passband Main lobe Stopband Window function w(n),
function (normalized) Ripple(dB) Relative to Attenuation |n|<=(N-1)/2
side lobe (dB)
(dB)
The frequency sampling method allows us to design nonrecursive FIR filter for
both standard frequency filters (lowpass, highpass & bandpass filter) and filter with
arbitrary frequency response. A unique attraction of the frequency sampling method is
that it also allows recursive implementation of FIR filters.
N 1
1 2
h( n) 2 | H (k ) | cos[2 k (n ) / N ] H (0) (2.9)
N k 1
where á = (N-1)/2, and H(k) are the samples of the frequency response of the filter taken
at intervals of kFs/N. For N odd, the upper limit in the summation is (N-1)/2.The
resulting filter will have exactly the same frequency response as the original response at
the sampling instants. To obtain a good approximation to the desired frequency response,
a sufficient number of frequency samples must be taken.
An alternative frequency sampling filter, know as type 2, results if frequency
sample taken at intervals of
f k ( k 1/ 2) Fs / N , k 0,1, 2,..........., N 1 (2.10)
To improve the amplitude response of frequency samples in the wider transition,
introducing frequency samples in the transition band. For a lowpass filter the stopband
attenuation increases, approximately, by 20 dB for each transition band frequency
sample, with a corresponding increase in the transition width:
Approximate stopband attenuation (25+20M) dB
Approximate transition width (M+1)Fs/N
where M is the number of transition band frequency samples and N is the filter length.
1 Z N N 1
H (k )
H ( z) 1 Z 1 j 2 k / N
H1 ( z ) H 2 ( z ) (2.11)
N k 0 e
Thus in recursive form, H ( z ) can be viewed as a cascade of two filters: a comb filter,
H1 ( z ) , which has N zeros uniformly distributed around the unit circle, and a sum of N
single all-pole filters, H 2 ( z ) . The zero of comb filter and the poles of the single pole
filters are coincide on the unit circle at points zk= .Thus the zero cancel the pole,
making H ( z ) an FIR as it effectively has no poles[4].
In practice, due to finite wordlength effects the poles of H 2 ( z ) not to be located
exactly on unit circle so that they are not cancelled by the zeros, making H ( z ) an IIR
and potentially unstable. Stability problems can be avoided by sampling H ( z ) at a
radius, r, slightly less than unity. Thus the transfer function in this case becomes
1 r N Z N N 1
H (k )
H (Z ) 1 re j 2 k / N
(2.12)
N k 0 Z 1
In general, the frequency samples, H(k), are complex. Thus direct implementation
requires complex arithmetic. To avoid this, the symmetry inherent use in frequency
response of any FIR filters with real impulse, . So above equation can expressed as
YES
Extrema
changed?
NO
Obtain the impulse response
coefficients
The heart of the optimal method is the first step where an iterative process is used to
determine the extremal frequencies of a filter whose amplitude-frequency response
satisfies the optimality condition.
2.3.4 Comparison of the window, frequency sampling and optimal methods
The optimum method provides the easy and optimum way of computing FIR filter
coefficients. Although the method provides total control of filter specifications, the
availability of the optimal filter design software is mandatory. For most applications the
optimal method will yield filters with good amplitude response characteristics for
reasonable value of N. The method is particularly good for designing Hilbert
transformers and differentiators. Other methods will yield larger approximation errors for
differentiators and Hilbert transformers than the optimal method.
In the absence of the optimal software or when the passband and stopband ripples
are equal, the window method represents a good choice. It is a particularly simple method
to apply and conceptually easy to understand. However, the optimal method will often
give a more economic solution in terms of the numb of the filter coefficients. The
window method does not allow the designer a precise control of the cut off the cutoff
frequencies or ripple in the passband and stopband.
The frequency sampling approach is the only method that allows both nonrecursive
and recursive implementations of FIR filters, and should be used when such
implementations are envisaged as the recursive approach is computationally economical.
The special form with integer coefficients should be considered only when primitive
arithmetic and programming simplicity are vital, but a check should always be made to
see whether its poor amplitude response is acceptable. Filters with arbitrary amplitude-
phase response can be readily designed by the frequency sampling method. The
frequency sampling method lacks precise control of the location of the band edge
frequencies or the passband ripples and relies on the availability of the design[4].
CHAPTER 3
FIR Filter Structures
3.1 Introduction
The analysis of linear, time-invariant FIR filter is generally carried out by using
the Z-transforms. A brief review of the Z-transform is presented. The filter structures
characterizing the difference equations are represented using basic elements such as
multipliers, time-delays, and adders.
3.1.1 Z Transform
The Z-transform is very useful role in the analysis and characterization of the
linear time-invariant systems. This is because the difference equations characterizing the
discrete system are transformed into algebraic equations, which are much easier to
manipulate.
for all z for which F(z) converges. Here the argument z is a complex variable.
Now, evaluating the Z-transform on Equation (1.4) we obtain,
N
z{ y (nT )} z ai x(nT iT )
i 0
By using the time translation property and the convolution property of Z-transform,
Equation (1.3) can be re-arranged as
N
Y ( z ) X ( z ) ai z i
i 0
Where H (z), X (z), Y (z) are the Z-transforms of Impulse Response, Input samples and
Output samples[1]. H (z) is called the transfer function of the filter and the time-domain
samples of this transfer function, which are the filter coefficients are approximated
according to the desired response.
x1 (nT ) x1 (nT )
xn (nT ) y ( nT ) x
k 1
k
( nT )
This way of presenting the difference equations in the form of block diagram and
signal flow diagram makes us easy to write an algorithm, which can be implemented in
the digital computer
n
Y (Z )
H ( z) ai z i (3.4)
X ( z ) i0
There are four Direct-form structures, which are different realizations of Equation (3.4).
The first Direct structure only is presented here and is as shown in Figure 3.2.
X(nT)
z 1 z 2 z ( n 1) z n
a0 a1 a 2 a n 1 an
Y(nT)
The 1-D structure is also called canonical because it possesses n-time delay elements.
The signal flow diagram of this structure is as shown below in figure 3.3.
x(nT) z 1 z 2 z ( n 1) z n
a 0 a1 an2 a n 1 a n y(nT)
As seen from the Signal Flow Diagram the above representation requires “n” Delay
elements, “n + 1” multipliers and “n” adders to implement in the digital computer. The
above structure suffers extreme coefficient sensitivity as the value of grows large. That is
a small change in a coefficient for large value of n causes large changes in the zeroes of
H (z).
Where the zi are the zeros of this polynomial. Since the coefficients of the polynomial are
usually real, the roots are usually complex-conjugate pairs, so we generally
combine 1 z j z 1 1 z j z 1 into one quadratic (length-2) section with real coefficients
1 z z 1 z z = 1-2R(Zj)Z-1+(|Zj|)2Z-2 = Hj(Z)
j
1
j
1
This is occasionally done in FIR filter implementation when one or more of the short-
length filters can be implemented efficiently.
4.1 Introduction
The following tools for implementation of FIR filter on FPGA:
1. XILINX ISE web pack 9.2i for design, synthesis and implementation.
2. MODSIM 5.5c for simulation.
The first one, structural, is the most commonly used as it allows description of the
structure of the IC very precisely by the user. This in very many cases gives the best
performance over compiler-optimized structures, especially for high speeds, fixed-point
applications like polyphase IIR structures. Its behavioral style permits the designer to
quickly test concepts, where the designer can specify the high-level function of the design
without taking much care how it will be done structurally. This can be very attractive for
quick design of low and medium speed and low-volume applications, where the designer
expertise is not available [7].
1. iMPACT
2. PROM File Formatter
The iMPACT programmer module allows you to program a device in-system for all
devices available in the WebPACK software. (we must connect a JTAG cable to the PC’s
parallel port.)
For FPGAs, the programmer module allows you to configure a device via the JTAG
cable.
iMPACT, a command line and GUI based tool, allows one to:
I. Configure FPGA designs using Boundary-Scan, Master Serial
II. Download
III. Read-Back and Verify design configuration data
IV. Perform functional tests on any device.
4.4 FPGAs: An Overview
The design of digital systems with VLSI circuits containing millions of transistors
is a formidable task and requires the assistance of computer-aided design (CAD) tools.
CAD tools consist of software programs that support computer-based representation and
aid in the development of digital hardware by automating the design process. The
designer can choose between a full-custom IC, a programmable logic device (PLD), an
application specific integrated circuit (ASIC), or a field-programmable gate array
(FPGA) [9].
What kinds of programmable logic devices are available today? How are they different
from one another?
There are a few major programmable logic architectures available today. Each
architecture typically has vendor-specific sub-variants. The major types include: [10]
Its initial role in rapid system prototyping is still important but in more recent
times it has grown in importance as a platform for implementing complete solutions. The
ability to implement a fully functional system, microcontroller or even full blown
computer using FPGAs and the recent advances in development software lead to highly
exciting possibilities with regards to the development of complete re-configurable
computing systems.
There are four main categories of FPGAs currently commercially available:
symmetrical array, row-based, hierarchical PLD, and sea-of-gates (Figure 4.2). In all of
these FPGAs the interconnections and how they are programmed vary.
The basic FPGA architecture consists of a two-dimensional array of logic blocks
and flip-flops with means for the user to configure (i) the function of each logic blocks,
(ii) the inputs/outputs, and (iii) the interconnection between blocks .Families of FPGAs
differ from each other by the physical means for implementing user programmability,
arrangement of interconnection wires, and basic functionality of the logic blocks.
Currently there are four technologies in use. They are static RAM cells, anti-fuse,
EPROM transistors, and EEPROM transistors. Depending upon the application, one
FPGA technology may have features desirable for that application.
Static RAM Technology: In the Static RAM FPGA programmable connections
are made using pass transistors, transmission gates, or multiplexers that are controlled by
SRAM cells. The advantage of this technology is that it allows fast in-circuit
reconfiguration. The major disadvantage is the size of the chip required by the RAM
technology.
Anti-Fuse Technology: An anti-fuse resides in a high-impedance state and can be
programmed into low impedance or "fused" state. A less expensive than the RAM
technology, this device is a program-one device.
Figure 4.2 Classes of FPGAs [9]
EPROM / EEPROM Technology: This method is the same as used in the EPROM
memories. One advantage of this technology is that it can be reprogrammed without
external storage of configuration; though the EPROM transistors cannot be re-
programmed in-circuit [11].
Specification Review
Design
Simulate
Design Review
Synthesize
Resimulate
Final Review
Chip Test
Chip Product
The addition or subtraction of two fixed-point numbers falling in the given range may
produce a result outside that range, though. Such a result, called overflow, it must be
either avoided, or corrected during DSP calculations. We are avoiding here.
The multiplication is the basic operation in computation of output y (k). Considering the
multiplication of two n-bit numbers, we have the product of 2n bits. This way of
multiplication is implemented in project while multiplying the coefficients and the input
samples.
Figure 5.3 Multiplication Modules.
It will add two numbers with taking care of negative number. If one of them or
both are negative, then before addition, negative number will be converted into two’s
compliment format and then it will be added. It will check whether result is overflowing
or not if it is overflowing then it will take two’s compliment of result.
Input will be shifted to right and result will be storing into temporary register.
Shifted input should have array size one more as compare to input but here array size
remains constant.
The above modules are used to implement the filter structure and the results are
discussed in next chapter.
CHAPTER 6
Results and Discussion
In this chapter, the lowpass, bandpass and highpass filters are implemented on FPGA
using real world examples. The filter specifications are real world and windowing
method is used to design the filter coefficients. These coefficients are used to implement
filter on Xilinx FPGA Spartan 3E kit using Xilinx ISE 9.2i.
The designed coefficients are given in Appendix-I. These coefficient are directly use in
VHDL Code. Now this VHDL code is used to generate the circuit using Xilinx synthesis
tool for low pass filter design and main circuit block is shown in figure 6.1.
2-bit adder :1
3-bit adder :1
32-bit adder : 53
4-bit adder :1
5-bit adder :1
6-bit adder :1
7-bit adder :1
8-bit adder :1
Total Adders/Subtractors : 60
Flip-Flops : 464
Total Registers (Flip-Flops) : 464
===============================================================
===============================================================
Speed Grade: -4
I(mA) P(mW)
Total estimated power consumption 81
Vccint 1.20V 26 31
Vccaux 2.50V 18 45
Vcco25 2.50V 2 5
Clocks 0 0
Inputs 0 0
Logic 0 0
Outputs
Vcco25 0 0
Signals 0 0
Quiescent Vccint 1.20V 26 31
Quiescent Vccaux 2.50V 18 45
Quiescent Vcco25 2.50V 2 5
A 7.95 60 7.95
N 72.49 73
14.36F 14.36(50 /1000)
The designed coefficients are given in Appendix II. These coefficient are directly use in
VHDL Code. Now this VHDL code is used to generate the circuit using Xilinx synthesis
tool for bandpass filter design and main circuit block is shown in Figure 6.5
2-bit adder :1
3-bit adder :1
32-bit adder : 72
4-bit adder :1
5-bit adder :1
6-bit adder :1
7-bit adder :1
8-bit adder :1
Total Adders/Subtractors : 79
Flip-Flops : 616
Total Registers(Flip-Flops) : 616
===============================================================
I(mA) P(mW)
Total estimated power consumption 81
Vccint 1.20V 26 31
Vccaux 2.50V 18 45
Vcco25 2.50V 2 5
Clocks 0 0
Inputs 0 0
Logic 0 0
Outputs
Vcco25 0 0
Signals 0 0
Quiescent Vccint 1.20V 26 31
Quiescent Vccaux 2.50V 18 45
Quiescent Vcco25 2.50V 2 5
The filter order of given specification is calculated using Hamming window technique as;
0.5
f 0.0625 (6.3)
8
3.3
N 52.80 53 (6.4)
f
The designed coefficients are given in Appendix III. These coefficient are directly use in
VHDL Code. Now this VHDL code is used to generate the circuit using Xilinx synthesis
tool for highpass filter design and main circuit block is shown in figure 6.9
===============================================================
Macro Statistics:
32x12-bit multiplier : 20
32x13-bit multiplier : 14
32x14-bit multiplier : 14
32x15-bit multiplier :6
Total Multipliers : 54
2-bit adder :1
3-bit adder :1
32-bit adder : 53
4-bit adder :1
5-bit adder :1
6-bit adder :1
7-bit adder :1
8-bit adder :1
Total Adders/Subtractors : 60
Flip-Flops : 464
Total Registers (Flip-Flops) : 464
===============================================================
===============================================================
Speed Grade: -4
I(mA) P(mW)
Total estimated power consumption 81
Vccint 1.20V 26 31
Vccaux 2.50V 18 45
Vcco25 2.50V 2 5
Clocks 0 0
Inputs 0 0
Logic 0 0
Outputs
Vcco25 0 0
Signals 0 0
Quiescent Vccint 1.20V 26 31
Quiescent Vccaux 2.50V 18 45
Quiescent Vcco25 2.50V 2 5
6.4 Discussions
The multipliers used for lowpass and highpass filters are 54 because they have
equal number of coefficients and that for highpass filter are 74. Similarly all other
components e.g. adders and registers are same for lowpass filter and highpass filter. The
adder for lowpass, highpass filter are 60 and for bandpass filter are 79. The registers are
464 for lowpass, highpass and 616 for bandpass filter.
The minimum period for lowpass, highpass filter are 75.51 ns (maximum
frequency: 13.243 MHz) and for bandpass filter is 93.191 ns (maximum frequency:
10.731 MHz). power consumed by the all three types of filters are 81 mW. The estimated
junction temperature of all three types of filter is 270C. The total number of 4 input LUTs
for lowpass, bandpass and highpass filters are 4561, 6381 and 4688 respectively. Total
gates used in design implementation are 47523, 65298, 47523, for lowpass, bandpass and
highpass filters respectively.
CHAPTER 7
Conclusion and Future Scope of Work
7.1 Conclusion
The FIR filters are widely used in digital signal processing and can be
implemented using programmable digital processors. But in the realization of large order
filters the speed, cost, and flexibility is affected because of complex computations. So,the
implementation of FIR filters on FPGAs is the need of the day because FPGAs can give
enhanced speed. This is due to the fact that the hardware implementation of a lot of
multipliers can be done on FPGA which are limited in case of programmable digital
processors.
In this thesis, a fifty three-order low-pass and highpass and seventy-three order
band pass FIR filter is implemented in Spartan-III-xc3s500c-4fg320 FPGA. The Direct-
form structure of these filters are implemented. This approach gives a better performance
than the common filter structures in terms of speed of operation, cost, and power
consumption. In the Direct-form structure, N Shift Registers, N Adder and N+1
multipliers are used to realize the N order lowpass , high pass and bandpass filter. The
designed filters can work for real time processing of any digital signal.
The optimization of the design can be done in terms of area occupied on chip.
References
[1] http://www.dsptutor.freeuk.com/dfilt1.htm
[2] Carmelina Ruggiero, “SEGNALI BIOMEDICI 1” Laboratorio MedInfo
[3] “An Introduction to Digital Filters” by INTERSIL, Application Note, January
1999
[4] Ifeachor E.C., Jervis B.W., “Digital Signal Processing”,2nd Edition, Low Price
Edition 2007.
[5] http://www.Xilinx.com/bvdocs/whitepapers/wp116.pdf.
[6] Jones D. L., “FIR Filter Structures”, Version 1.2: Oct 10, 2004.
[7] Perry D., “VHDL”, 3rd Edition, Tata Mc. Graw Hill Publications, 2001.
[8] Bhaskar J., “VHDL primer” ,3rd Edition, Pearson Education Asia Publications,
2000.
[15] Prokis J. G., Manolakis D. G., “Digital Signal Processing”, 3rd Edition, PHI
publication 2004.
[16] Antoniou A.,“ Digital Filter”, 3rd Edition, Tata Mc. Graw Hill publications, 2001.
[17] Mitra S. K., “Digital Signal Processing” 3rd Edition, Tata Mc. Graw Hill
Publications.
[18] Chapman S. J., “ Matlab Programming for Engineers”, 3rd Edition, Thomson
learning 2005.
[19] Lee H., Sobelman G E. “Performance Evaluation and Optimal design for FPGA-
based Digit-serial DSP Functions”. Computers and Electrical Engineering 29 ,2003
[20] Mirzaei S., Hosangadi A. and Kastner R. , “FPGA Implementation of High
Speed FIR Filters Using Add and Shift Method”, International Conference on
Computer Design (ICCD ),pp 308-313, 2006
[21] Takahashi Y. and Yokoyama M., “New cost-effective VLSI implementation of
multiplierless FIR filter using common subexpression elimination”, Proc. IEEE
Int. Symp. on Circuits and Systems (ISCAS 2005), pp.845–848, May 2005.
[22] Rocha Ed., “Implementation trade-offs of digital FIR filters,” Military Embeded
System, open system publishing,2007.
[23] Choi, Seak C. and Lee H., “A Partial Self-Reconfigurable Adaptive FIR Filter
System,” signal processing systems,pp.204-209,2007.
[24] Takalashi Y., Sekine T. and Yokoyama M., “A 70MHz Multiplierless FIR
Hilbert Transformer in 0.35 um standard CMOS Library,” IEICE Trans. 1376-
1383,2007.
Appendix-I