module Kalman (
extKalman
)where
import GHC.TypeLits
import Numeric.LinearAlgebra.Static hiding ( create )
import Data.Maybe ( fromJust )
extKalman :: forall m n .
(KnownNat m, KnownNat n, (1 <=? n) ~ 'True, (1 <=? m) ~ 'True) =>
R n -> Sq n ->
L m n -> Sq m ->
(R n -> R n) -> (R n -> Sq n) -> Sq n ->
[R m] ->
[(R n, Sq n)]
extKalman muPrior sigmaPrior bigH bigSigmaY
littleA bigABuilder bigSigmaX ys = result
where
result = scanl update (muPrior, sigmaPrior) ys
update :: (R n, Sq n) -> R m -> (R n, Sq n)
update (xHatFlat, bigSigmaHatFlat) y =
(xHatFlatNew, bigSigmaHatFlatNew)
where
v :: R m
v = y (bigH #> xHatFlat)
bigS :: Sq m
bigS = bigH <> bigSigmaHatFlat <> (tr bigH) + bigSigmaY
bigK :: L n m
bigK = bigSigmaHatFlat <> (tr bigH) <> (inv bigS)
xHat :: R n
xHat = xHatFlat + bigK #> v
bigSigmaHat :: Sq n
bigSigmaHat = bigSigmaHatFlat bigK <> bigS <> (tr bigK)
bigA :: Sq n
bigA = bigABuilder xHat
xHatFlatNew :: R n
xHatFlatNew = littleA xHat
bigSigmaHatFlatNew :: Sq n
bigSigmaHatFlatNew = bigA <> bigSigmaHat <> (tr bigA) + bigSigmaX
inv :: (KnownNat n, (1 <=? n) ~ 'True) => Sq n -> Sq n
inv m = fromJust $ linSolve m eye