Kalman filter is a technology to achieve Bayes filter. It’s an optimal linear state estimation method (eqauls to optimal linear filter under the minimum mean square error criterion), which seeks the state vector that best fits the observed data by mathematical methods.
In localization and navigation of robots, kalman filter is the most commonly used method to estimante the robot’s status, as it solve the problem recursively and only the estimation value in the last sampling period and the measurement in the current sampling period are needed, which saves memory and calculating time.
Principle
Prerequisite
Before using kalman filter, 3 prerequisites should be statisfied:
State transition probability must be the linear function fo parameters with random Gaussian noise
Measurement probabilty also has to contain Gaussian component
Initial confidence is normally distributed
Problem Description
Define a status vector with random-Gaussian-noise parameters:
xt=Atxt−1+Btut+ϵt
In this equation, xt and xt−1 represents the status vector (n×1) in moment t and t−1 respectively; A is the state transition matrix in nxn dimension; ut represents the control vector (m×1) on moment t; Bt is an optional gain matrix of control vector in n×m dimension; ϵt is a random Gaussian vector that represents the uncertainty introduced by status transition.
Note: all vectors are column vectors in the following form:
In this equation, Ht is the gain matrix in k∗n dimension; δt is the observation noise.
Example
Give an example to explain the above equations. Suppose that we are tracking a car in uniform motion through GPS and other sensors. In general, we would like to get information about its position and velocity (or orientation) when we observe a vehicle.
Therefore, status vector could be defined as xt=(xt,yt,vx,vy)T. Simultanenously, it’s known that in uniform motion the control vector is ut=(vx,vy)T.
As a result, the matrix A and B are defined as follow:
Similarly, H is also required to be defined. As we can get the information about vehicle’s position from GPS sensor, the observation vector is defined as zt=(xt,yt)T. H is a k∗n dimensional matrix, so that we can get the equation as follow:
x^t−: the priori estimated value of status vector at moment t
x^t: the posterior estimated value of status vector at moment t, the result of kalman filter
x^t−1: the posterior estimated value of status vector at moment t−1
A: status transition matrix
B: an optional gain matrix of control vector
ut: control vector at moment t
P^t−: the priori estimated covariance at moment t
P^t−1: the posterior estimated covariance at moment t, a part of result of filter
Kt: kalman gain coefficient, intermediate variable of equation
Q: covariance of process noise that represents the error between status transition matrix and actual process.It’s difficult to seek the best value of Q,
but it follows some priciples: In general, Q is diagonal matrix and the values are small for prompt convergence.
R: covariance of measured noise that relates to measured instruments, the smaller of this value, the higher of the convergence speed
Expansion
Unfortunately, kalman fitler only can be applied to problems with linear status transition matrix and measurement, which confine it in simple robotic problem. Therefore, Extended Kalman Filter is introduced to break the limitation.
Reality
Essentially, the linear prediction and measurement in kalman filter are replaced by no-linear prediction and measurement in extended kalman filter. As the result, Axt−1+But is replaced by Jacobi Matrix g(xt−1,ut) and Hxt is replaced by Jacobi Matrix h(xt) .