forked from simondlevy/SensorFusion
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkalman.m
63 lines (52 loc) · 1.89 KB
/
kalman.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
function xhat = kalman(z, A, C, R, Q)
% Simple Kalman Filter (linear) with optimal gain, no control signal
%
% z Measurement signal m observations X # of observations
% A State transition model n X n, n = # of state values
% C Observation model m X n
% R Covariance of observation noise m X m
% Q Covariance of process noise n X n
%
% Based on http://en.wikipedia.org/wiki/Kalman_filter, but matrices named
% A, C, G instead of F, H, K.
%
% See http://home.wlu.edu/~levys/kalman_tutorial for background
%
% Copyright (C) 2014 Simon D. Levy
%
% This code is free software: you can redistribute it and/or modify
% it under the terms of the GNU Lesser General Public License as
% published by the Free Software Foundation, either version 3 of the
% License, or (at your option) any later version.
%
% This code is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU General Public License for more details.
%
% You should have received a copy of the GNU Lesser General Public License
% along with this code. If not, see <http:#www.gnu.org/licenses/>.
% Initializtion =====================================================
% Number of sensors
m = size(C, 1);
% Number of state values
n = size(C, 2);
% Number of observations
numobs = size(z, 2);
% Use linear least squares to estimate initial state from initial
% observation
xhat = zeros(n, numobs);
xhat(:,1) = C \ z(:,1);
% Initialize P, I
P = ones(size(A));
I = eye(size(A));
% Kalman Filter =====================================================
for k = 2:numobs
% Predict
xhat(:,k) = A * xhat(:,k-1);
P = A * P * A' + Q;
% Update
G = P * C' / (C * P * C' + R);
P = (I - G * C) * P;
xhat(:,k) = xhat(:,k) + G * (z(:,k) - C * xhat(:,k));
end