-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathkalman_filter.m
91 lines (77 loc) · 2.8 KB
/
kalman_filter.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
%-----------------------------%%-----------------------------%%
% Authors: Alessandra Galli, Claudio Narduzzi, Giada Giorgi. %
% Instrumentation and Measurement Research Group %
% University of Padova %
%-----------------------------%%-----------------------------%%
function[res]=kalman_filter(z_ppg1,z_ppg2)
Q=4^2;
R=10^2;
count=0;
countmax=5;
imax=3;
xposteriori=(z_ppg1(1)+z_ppg1(1))/2;
res(1)=(z_ppg1(1)+z_ppg1(1))/2;
Pposteriori=0;
for i=2:length(z_ppg1)
xpriori=xposteriori;
Ppriori=Pposteriori+Q;
S=Ppriori+R;
gain=Ppriori/S;
%---------------------------------------------------------------------
inn1=z_ppg1(i)-xpriori;
inn2=z_ppg2(i)-xpriori;
VAR1=var(z_ppg1(max(1,(i-90)):i));
VAR2=var(z_ppg2(max(1,(i-90)):i));
%check
if(isnan(inn1) || abs(inn1)>2*sqrt(S))
flag1=1;
else
flag1=0;
end
%check
if(isnan(inn2) || abs(inn2)>2*sqrt(S))
flag2=1;
else
flag2=0;
end
if (VAR1*2)<VAR2 && i>20
flag2=1;
elseif (VAR2*2)<VAR1 && i>20
flag1=1;
end
if((flag1==0 && flag2==0)||((count==countmax || i<imax) && (~isnan(inn1) && ~isnan(inn2))))
if(abs(inn1)<abs(inn2))
inn=inn1;
else
inn=inn2;
end
xposteriori=xpriori+gain*inn;
Pposteriori=(1-gain)*Ppriori;
if(count==countmax )
xposteriori(1)=(z_ppg1(i)+z_ppg2(i)+xpriori(1))/3;
end
count=0;
elseif((flag1==0 && flag2==1)||((count==countmax || i<imax) && ~isnan(inn1)))
inn=inn1;
xposteriori=xpriori+gain*inn;
Pposteriori=(1-gain)*Ppriori;
if(count==countmax )
xposteriori(1)=0.5*(z_ppg1(i)+xpriori(1));
end
count=0;
elseif((flag2==0 && flag1==1) ||((count==countmax || i<imax) && ~isnan(inn2)))
inn=inn2;
xposteriori=xpriori+gain*inn;
Pposteriori=(1-gain)*Ppriori;
if(count==countmax )
xposteriori(1)=0.5*(z_ppg2(i)+xpriori(1));
end
count=0;
else
count=count+1;
xposteriori=xpriori;
Pposteriori=Ppriori;
end
res(i)=xposteriori(1);
end
end