The purpose of this tutorial is to illustrate the usage of Kalman Filter by a simple example.
The problem: Predict the position and velocity of a moving train 2 seconds ahead, having noisy measurements of its positions along the previous 10 seconds (10 samples a second).
Ground truth: The train is initially located at the point x = 0 and moves along the X axis with constant velocity V = 10m/sec, so the motion equation of the train is X = X0 + V*t. Easy to see that the position of the train after 12 seconds will be x = 120m, and this is what we will try to find.
Approach: We measure (sample) the position of the train every dt = 0.1 seconds. But, because of imperfect apparature, weather etc., our measurements are noisy, so the instantaneous velocity, derived from 2 consecutive position measurements (remember, we measure only position) is innacurate. We will use Kalman filter as we need an accurate and smooth estimate for the velocity in order to predict train's position in the future.
We assume that the measurement noise is normally distributed, with mean 0 and standard deviation SIGMA
nice work and well explained
This is the best implementation of Kalman Filter using simple example I ever have found. Thank you for sharing.
very nice and simple
This was SUPER helpful. Thanks!
thank you. Very helpful.
Clear demonstration of basic capabilities of the Kalman filter.
Excellent intro tu KFiltering!
good tutorial for Kalman Filter.
Dimitri u always say that close all and clear all is a bad habit... explain which one is a good one then!
it's good but i think u could add more comment and more explain ... but it's useful for every who want have quick start in Kalman Filter...
And anyway, what does it add to Michael Kleder's submission? (Nothing).
Correction: this is not a 'tutorial', but 'one commented program'. Of course, it can still be helpful. Note on programming: 'close all,
clear all' is bad form.
Download apps, toolboxes, and other File Exchange content using Add-On Explorer in MATLAB.