An FIR filter design was selected for this pre-processing filter ASIC. FIR filters
have several advantages, including a linear phase shift with frequency, and limited
overall distortion. An N-tap FIR
is defined by its coefficients h[], pre-processed data [x], and post-processed
data y[]:
data:image/s3,"s3://crabby-images/50503/50503cfbf3a579a5f36a5e3562f1ace6715cefee" alt=""
Linear phase-shift FIR filters were used in this project. They are defined by a symmetric
set of coefficients:
data:image/s3,"s3://crabby-images/54e86/54e86f387d8044094f8e9750c2618946bfde685e" alt=""
Four sets of filter coefficients were designed for the filter
ROM. These coefficients
were initially produced in Matlab by the following commands:
- Low pass
- h1 = fir1(20,0.45,'low');
- High pass
- h2 = fir1(20,0.55,'high');
- Band stop
- h3 = fir1(20, [0.23 0.77],'stop');
- Band Pass
- h4 = fir1(20, [0.25 0.65]);
The low-pass filter is shown in Figure 1.
data:image/s3,"s3://crabby-images/9e8fb/9e8fb33b697c44fd66953a5e12a793dd40e00b95" alt=""
Figure 1: Low-pass filter
The high-pass filter is shown in Figure 2.
data:image/s3,"s3://crabby-images/7afc8/7afc8bfa7b2bc9590549e0c158d30a0778d7a5b6" alt=""
Figure 2: High-pass filter
The band-stop filter is shown in Figure 3.
data:image/s3,"s3://crabby-images/6eba5/6eba55db93cd593d5a0ea9b0211bab3d0e43f379" alt=""
Figure 3: Band-stop filter
The band-pass filter is shown in Figure 4.
data:image/s3,"s3://crabby-images/b8658/b8658ff42ccceee5d7a598d6a2bf449a22aabfb6" alt=""
Figure 4: Band-pass filter
Filtering of raw data in Matlab was easily accomplished with the following command:
The filter coefficients initially produced in Matlab were in floating-point decimal format.
They were converted into two's complement, fixed-point format before being stored
in the filter ROM.
|