Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
gtsam / tests / test_KalmanFilter.py
Size: Mime:
"""
GTSAM Copyright 2010-2019, Georgia Tech Research Corporation,
Atlanta, Georgia 30332-0415
All Rights Reserved

See LICENSE for the license information

KalmanFilter unit tests.
Author: Frank Dellaert & Duy Nguyen Ta (Python)
"""
import unittest

import numpy as np

import gtsam
from gtsam.utils.test_case import GtsamTestCase


class TestKalmanFilter(GtsamTestCase):

    def test_KalmanFilter(self):
        """ 
        Kalman Filter Definitions:
        F - State Transition Model
        B - Control Input Model
        u - Control Vector
        modelQ - Covariance of the process Noise (input for KalmanFilter object) - sigma as input
        Q - Covariance of the process Noise (for reference calculation) - sigma^2 as input
        H - Observation Model
        z1 - Observation iteration 1
        z2 - Observation iteration 2
        z3 - observation iteration 3
        modelR - Covariance of the observation Noise (input for KalmanFilter object) - sigma as input
        R - Covariance of the observation Noise (for reference calculation) - sigma^2 as input
        """

        F = np.eye(2)
        B = np.eye(2)
        u = np.array([1.0, 0.0])
        modelQ = gtsam.noiseModel.Diagonal.Sigmas(np.array([0.1, 0.1]))
        Q = 0.01 * np.eye(2)
        H = np.eye(2)
        z1 = np.array([1.0, 0.0])
        z2 = np.array([2.0, 0.0])
        z3 = np.array([3.0, 0.0])
        modelR = gtsam.noiseModel.Diagonal.Sigmas(np.array([0.1, 0.1]))
        R = 0.01 * np.eye(2)

        # Create the set of expected output TestValues
        expected0 = np.array([0.0, 0.0])
        P00 = 0.01 * np.eye(2)

        expected1 = np.array([1.0, 0.0])
        P01 = P00 + Q
        I11 = np.linalg.inv(P01) + np.linalg.inv(R)

        expected2 = np.array([2.0, 0.0])
        P12 = np.linalg.inv(I11) + Q
        I22 = np.linalg.inv(P12) + np.linalg.inv(R)

        expected3 = np.array([3.0, 0.0])
        P23 = np.linalg.inv(I22) + Q
        I33 = np.linalg.inv(P23) + np.linalg.inv(R)

        # Create an KalmanFilter object
        KF = gtsam.KalmanFilter(n=2)

        # Create the Kalman Filter initialization point
        x_initial = np.array([0.0, 0.0])
        P_initial = 0.01 * np.eye(2)

        # Create an KF object
        state = KF.init(x_initial, P_initial)
        self.assertTrue(np.allclose(expected0, state.mean()))
        self.assertTrue(np.allclose(P00, state.covariance()))

        # Run iteration 1
        state = KF.predict(state, F, B, u, modelQ)
        self.assertTrue(np.allclose(expected1, state.mean()))
        self.assertTrue(np.allclose(P01, state.covariance()))
        state = KF.update(state, H, z1, modelR)
        self.assertTrue(np.allclose(expected1, state.mean()))
        self.assertTrue(np.allclose(I11, state.information()))

        # Run iteration 2
        state = KF.predict(state, F, B, u, modelQ)
        self.assertTrue(np.allclose(expected2, state.mean()))
        state = KF.update(state, H, z2, modelR)
        self.assertTrue(np.allclose(expected2, state.mean()))

        # Run iteration 3
        state = KF.predict(state, F, B, u, modelQ)
        self.assertTrue(np.allclose(expected3, state.mean()))
        state = KF.update(state, H, z3, modelR)
        self.assertTrue(np.allclose(expected3, state.mean()))

if __name__ == "__main__":
    unittest.main()