KALCVF Call
computes the one-step prediction
and the filtered estimate
, as well as their covariance matrices.
The call uses forward recursions, and you
can also use it to obtain
-step estimates.
- CALL KALCVF( pred, vpred, filt, vfilt, data, lead,
,
,
,
,
- var <, z0, vz0>);
The inputs to the KALCVF subroutine are as follows:
- data
- is a
matrix containing data
.
- lead
- is the number of steps to forecast after the end of the data.
data:image/s3,"s3://crabby-images/3c86a/3c86a963e2b669a85fee226386935dc6307beb4a" alt="a"
- is an
vector for a time-invariant input vector in
the transition equation, or a
vector containing input vectors in the transition equation.
data:image/s3,"s3://crabby-images/c5d50/c5d5016b98110a7305cacceb5a657cd111a9f0f0" alt="f"
- is an
matrix for a time-invariant
transition matrix in the transition equation, or a
matrix containing
transition matrices in the transition equation.
data:image/s3,"s3://crabby-images/73805/738050eae4c3abc2868bdfb668a197387ffe14f5" alt="b"
- is an
vector for a time-invariant input vector in
the measurement equation, or a
vector containing input vectors in the measurement equation.
data:image/s3,"s3://crabby-images/b6c6d/b6c6de7dad208ad82dab1947fdd48a282ca1b9d1" alt="h"
- is an
matrix for a time-invariant
measurement matrix in the measurement equation, or a
matrix containing
measurement matrices in the measurement equation.
- var
- is an
matrix for a
time-invariant variance matrix for the error in the transition
equation and the error in the measurement equation, or a
matrix
containing variance matrices for the error in the transition
equation and the error in the measurement equation -
that is,
.
data:image/s3,"s3://crabby-images/d512e/d512e382c117f2487d234bbe3307f474b4649e17" alt="z0"
- is an optional
initial
state vector
.
data:image/s3,"s3://crabby-images/0209c/0209cc01a600331c1dfccb5dc1b7b5fc1fd8eec4" alt="vz0"
- is an optional
covariance
matrix of an initial state vector
.
The KALCVF call returns the following values:
- pred
- is a
matrix containing
one-step predicted state vectors
.
- vpred
- is a
matrix
containing mean square errors of predicted state
vectors
.
- filt
- is a
matrix containing filtered state
vectors
.
- vfilt
- is a
matrix containing mean square errors of
filtered state vectors
.
The KALCVF call computes the conditional expectation of the
state vector
data:image/s3,"s3://crabby-images/40a67/40a6770623109d85a47dec3907a24fbc99245fb7" alt="{z}_t"
given the observations, assuming that the
mean and the variance of the initial state vector are known.
The filtered value is the conditional expectation of the
state vector
data:image/s3,"s3://crabby-images/40a67/40a6770623109d85a47dec3907a24fbc99245fb7" alt="{z}_t"
given the observations up to time
data:image/s3,"s3://crabby-images/7ff0a/7ff0ae733b3864956f5ee82fb3535a5094931245" alt="t"
.
For
data:image/s3,"s3://crabby-images/79c5c/79c5c6da8a98a5eefd5f7d0dad9491feb2efe0bb" alt="k"
-step forecasting where
data:image/s3,"s3://crabby-images/e7633/e76338bb3e2871743461115cdbfbf70708b492ef" alt="k\gt"
, the conditional expectation
at time
data:image/s3,"s3://crabby-images/4d7f0/4d7f06225e0b084cac1d47a1d067e8f62a865199" alt="t+k"
is computed given observations up to
data:image/s3,"s3://crabby-images/7ff0a/7ff0ae733b3864956f5ee82fb3535a5094931245" alt="t"
.
For notation,
data:image/s3,"s3://crabby-images/89c96/89c96c8a43c5718802dd297992e9bf33066d4a49" alt="{v}_t"
and
data:image/s3,"s3://crabby-images/08fcd/08fcd821b3c5876d7ab94d0562df5a338776b8c4" alt="{{r}}_t"
are variances of
data:image/s3,"s3://crabby-images/9cae6/9cae674706721712378cce78a097148fed0a124b" alt="\eta_t"
and
data:image/s3,"s3://crabby-images/92ccb/92ccbda14bf1f8aa87a38ab8ec94e2d73e1f45d5" alt="{\epsilon}_t"
, respectively, and
data:image/s3,"s3://crabby-images/b9f77/b9f772898be830e7cff067d2073b090ca4a6a194" alt="{g}_t"
is a covariance of
data:image/s3,"s3://crabby-images/9cae6/9cae674706721712378cce78a097148fed0a124b" alt="\eta_t"
and
data:image/s3,"s3://crabby-images/92ccb/92ccbda14bf1f8aa87a38ab8ec94e2d73e1f45d5" alt="{\epsilon}_t"
.
data:image/s3,"s3://crabby-images/159d4/159d489a7b9bd06cd23869a1b9bd3057496dd437" alt="{a}^-"
stands for the generalized inverse of
data:image/s3,"s3://crabby-images/c3fe0/c3fe0b4fa985b96bb47c099e4c3bdd223be6095b" alt="{a}"
.
The filtered value and its covariance matrix are
denoted
data:image/s3,"s3://crabby-images/bc03f/bc03f192e6a808d8e7a45670d174d0ea7af36f14" alt="{z}_{t| t}"
and
data:image/s3,"s3://crabby-images/62d17/62d179d765c866a3d7c977407da6c8ae562d073c" alt="{p}_{t| t}"
, respectively.
For
data:image/s3,"s3://crabby-images/e7633/e76338bb3e2871743461115cdbfbf70708b492ef" alt="k\gt"
,
data:image/s3,"s3://crabby-images/ad1fc/ad1fcb3cf5c8bc1cb1c9769ca9a7107d6149d9cc" alt="{z}_{t+k| t}"
and
data:image/s3,"s3://crabby-images/74a5f/74a5fda7e9e7a77ea35fc11a6e5b1e6da8152d88" alt="{p}_{t+k| t}"
stand for the
data:image/s3,"s3://crabby-images/79c5c/79c5c6da8a98a5eefd5f7d0dad9491feb2efe0bb" alt="k"
-step forecast of
data:image/s3,"s3://crabby-images/16887/16887d0148bf16028885ffb6a0b74cf958d2c35c" alt="{z}_{t+k}"
and its mean square error.
The Kalman filtering algorithm for one-step
prediction and filtering is given as follows:
data:image/s3,"s3://crabby-images/6b24f/6b24fb363ae9a4e1da003bddb39582c1e8a7600b" alt="\hat{\epsilon}_t & = & {y}_t - {b}_t - {h}_t {z}_{t| t-1} \ {d}_t & = & {h}_t ... ... {p}_{t+1| t} & = & {f}_t {p}_{t| t-1}{f}^'_t + {v}_t - {k}_t {d}_t {k}^'_t"
And for
data:image/s3,"s3://crabby-images/79c5c/79c5c6da8a98a5eefd5f7d0dad9491feb2efe0bb" alt="k"
-step forecasting for
data:image/s3,"s3://crabby-images/ea865/ea865623fcb93c616979e4694a78bdc135ed4931" alt="k\gt 1"
,
data:image/s3,"s3://crabby-images/54e0f/54e0f5b050981637819ed248f426e3a9d4b3cfdd" alt="{z}_{t+k| t} & = & {a}_{t+k-1} + {f}_{t+k-1} {z}_{t+k-1| t} \ {p}_{t+k| t} & = & {f}_{t+k-1} {p}_{t+k-1| t} {f}^'_{t+k-1} + {v}_{t+k-1}"
When you use the alternative transition equation
data:image/s3,"s3://crabby-images/285b4/285b49ede98592c0f0dc0c46c1c2e2deb7cb6ac6" alt="{z}_t = {a}_t + {f}_t{z}_{t-1} + \eta_t"
the forward recursion algorithm is written
data:image/s3,"s3://crabby-images/f5359/f53599910bdfa6eb5e3d2946f4d3a06d95305dea" alt="\hat{\epsilon}_t & = & {y}_t - {b}_t - {h}_t{z}_{t| t-1} \ {d}_t & = & {h}_t {... ... t} & = & {f}_{t+1} {p}_{t| t-1}{f}^'_{t+1} + {v}_{t+1} - {k}_t {d}_t {k}^'_t"
And for
data:image/s3,"s3://crabby-images/79c5c/79c5c6da8a98a5eefd5f7d0dad9491feb2efe0bb" alt="k"
-step forecasting
data:image/s3,"s3://crabby-images/dbf92/dbf92541373f874707d201d4a606769b344bb4c2" alt="(k\gt 1)"
,
data:image/s3,"s3://crabby-images/f55da/f55dadcef743b1b46caf01a3bedff69240b9840b" alt="{z}_{t+k| t} & = & {a}_{t+k} + {f}_{t+k}{z}_{t+k-1| t} \ {p}_{t+k| t} & = & {f}_{t+k} {p}_{t+k-1| t} {f}^'_{t+k} + {v}_{t+k}"
You can use the KALCVF call when you specify the
alternative transition equation and
data:image/s3,"s3://crabby-images/075ef/075efe14d6eab5d48304bbfc71070b103f24e579" alt="{g}_t = 0"
.
The initial state vector and its covariance
matrix of the time invariant Kalman filters
are computed under the stationarity condition
data:image/s3,"s3://crabby-images/eb84f/eb84fd9c4c969b1591640aec18ba10a6e1efcfc8" alt="{z}_{1|} & = & ({i}- {f})^- {a}\ {p}_{1|} & = & ({i}- {f}\otimes {f})^- {vec}({v})"
where
data:image/s3,"s3://crabby-images/dfb01/dfb01e3f711cccd0df6d5cfae44c161e86747fcf" alt="{f}"
and
data:image/s3,"s3://crabby-images/fba1c/fba1cccf586c74b30a39fecf8dacf94040895c8e" alt="{v}"
are the time-invariant transition
matrix and the covariance matrix of transition equation noise,
and vec
data:image/s3,"s3://crabby-images/b42a9/b42a99132ed28552ec1326a85e761d5542673947" alt="({v})"
is an
data:image/s3,"s3://crabby-images/7e894/7e8944de926fe09c329ad85a2f5ee3aedd6a2de2" alt="n_z^2 x 1"
column vector that is
constructed by the stacking
data:image/s3,"s3://crabby-images/b7e92/b7e92736a19269dced43896d5b58163e79e65e5f" alt="n_z"
columns of matrix
data:image/s3,"s3://crabby-images/fba1c/fba1cccf586c74b30a39fecf8dacf94040895c8e" alt="{v}"
.
Note that all eigenvalues of the matrix
data:image/s3,"s3://crabby-images/dfb01/dfb01e3f711cccd0df6d5cfae44c161e86747fcf" alt="{f}"
are
inside the unit circle when the SSM is stationary.
When the preceding formula cannot be applied, the initial
state vector estimate
data:image/s3,"s3://crabby-images/80166/80166156cc817d925546d6b415aaf03bf7184c9c" alt="{z}_{1|}"
is set to
data:image/s3,"s3://crabby-images/e4308/e430805cd7e01743d4fec29f67685a6b71683ca9" alt="{a}_1"
and
its covariance matrix
data:image/s3,"s3://crabby-images/aca6a/aca6a194f1a812c177fef38567a1c3e0a88bb7ac" alt="{p}_{1|}"
is given by
data:image/s3,"s3://crabby-images/6a46b/6a46b5dbd443c8db9e1a281d498168ee6d531bb0" alt="10^6"
I.
Optionally, you can specify initial values.
The KALCVF call accepts missing values in observations.
If there is a missing observation, the filtered state vector
for the missing observation is given by the one-step forecast.
The following program gives an example of the KALCVF call:
q=2;
p=2;
n=10;
lead=3;
total=n+lead;
seed = 25735;
x=round(10*normal(j(n,p,seed)))/10;
f=round(10*normal(j(q*total,q,seed)))/10;
a=round(10*normal(j(total*q,1,seed)))/10;
h=round(10*normal(j(p*total,q,seed)))/10;
b=round(10*normal(j(p*total,1,seed)))/10;
do i = 1 to total;
temp=round(10*normal(j(p+q,p+q,seed)))/10;
var=var//(temp*temp`);
end;
call kalcvf(pred,vpred,filt,vfilt,x,lead,a,f,b,h,var);
/* default initial state and covariance */
call kalcvs(sm,vsm,x,a,f,b,h,var,pred,vpred);
print sm [format=9.4] vsm [format=9.4];
This program produces the following output:
SM VSM
-1.5236 -0.1000 1.5813 -0.4779
0.3058 -0.1131 -0.4779 0.3963
-0.2593 0.2496 2.4629 0.2426
-0.5533 0.0332 0.2426 0.0944
-0.5813 0.1251 0.2023 -0.0228
-0.3017 0.7480 -0.0228 0.5799
1.1333 -0.2144 0.8615 -0.7653
1.5193 -0.6237 -0.7653 1.2334
-0.6641 -0.7770 1.0836 0.8706
0.5994 2.3333 0.8706 1.5252
0.3677 0.2510
0.2510 0.2051
0.3243 -0.4093
-0.4093 1.2287
0.1736 -0.0712
-0.0712 0.9048
1.3153 0.8748
0.8748 1.6575
8.6650 0.1841
0.1841 4.4770