Reference no: EM13983
Q1 Filter function form is y = myfilter(x,b,a) where x is input, y is output and a and b are the IIR and FIR coefficients.
In the transfer function, the matrix "a" indicates the denominator coefficients and the matrix "b" is numerator coefficients.
I use command "global buffer;" to set a global variable as the shift buffer.
For a second order IIR filter, the transfer function is like:
data:image/s3,"s3://crabby-images/96dab/96dabf8c27276fa6c9f9ec1d41585ce015f56aa1" alt="362_IIR and FIR coefficients.png"
Where w0 is stopband filter frequency, r is the stopband width.
data:image/s3,"s3://crabby-images/8fa59/8fa598b8852a12f00c62a591ee712b86ccb014d5" alt="1629_IIR and FIR coefficients1.png"
The signal flow diagram is:
From the diagram, I work out the function in Matlab:
output=b(2)*buffer(1);
input=input-a(2)*buffer(1);
output=output+b(3)*buffer(2);
input=input-a(3)*buffer(2);
output=output+input*b(1);
When the output is figured out, the input is set to buffer(1) and the buffer(1) becomes buffer(2).
buffer(2)=buffer(1);
buffer(1)=input;
Q2
I use the command "load ('1104111.txt')" to load my ecg file. The signal minus 2048 to make it range from -2048mV to +2048mV.
And plot the original signal.
data:image/s3,"s3://crabby-images/6d0d9/6d0d91bbfec8b6233cf2bcf9b5838e224e71db93" alt="669_IIR and FIR coefficients2.png"
To eliminate the 50Hz hum, so I make w0=2*pi*50/fs; r refers to the width of the stopband. And the closer r goes to 1, the more narrow is the stopband. I choose r=0.93.
Because it is a second order filter so the buffer contains 2 components.
To define the buffer in advance, I use the command of "global buffer;buffer=zeros(2,1);"
The coefficients a and b are:
b1=1; b2=-2*cos(w0); b3=1;
a1=1; a2=-2*r*cos(w0); a3=r^2;
b=[b1,b2,b3]; a=[a1,a2,a3];
Then a loop is used for filtering the whole signal.
op1=zeros(l,1);
for k=1:l
op1(k)=myfilter_3(ecg1(k),b,a);
end
Plot the result.
data:image/s3,"s3://crabby-images/5ad1a/5ad1ae4caa70fb5b26bfd3a65be2f2747aecb04e" alt="300_IIR and FIR coefficients3.png"
Q3
In this section, the steps are similar with the Q2.
To eliminate the DC component, w0=0;
The other steps are almost same as the Q2.
The result is plotted as:
data:image/s3,"s3://crabby-images/435ba/435ba358ae4f7997e1ed797149cc632680fbc679" alt="1982_IIR and FIR coefficients4.png"
At last, to check the PQRST peaks, zoom in the plot
data:image/s3,"s3://crabby-images/d43e0/d43e0c2d38e6326785c4f78fd494bc1fe7c620f8" alt="856_IIR and FIR coefficients5.png"