root/applications/pmsm/simulator_zdenek/ekf_example/matrix_vs.h @ 1245

Revision 1245, 1.9 kB (checked in by smidl, 14 years ago)

fixes in UD + Chol

RevLine 
[1174]1/************************************
2        Extended Kalman Filter
3        Matrix operations
4
5        V. Smidl
6
7Rev. 30.8.2010
8
930.8.2010      Prvni verze
10
11*************************************/
[1225]12
[1228]13#define qAU 14
[1240]14#define qD 14
[1245]15#define qCh 14
[1225]16
[1245]17#define int16 int
18#define int32 long
[1240]19
[1225]20/* Matrix multiply Full matrix by upper diagonal matrix with unit diagonal; */
[1240]21extern void mmultAU(int16 *m1, int16 *up, int16 *result, unsigned int16 rows, unsigned int16 columns);
[1174]22
[1225]23/* Matrix multiply Full matrix by upper diagonal matrix; */
[1240]24extern void mmultACh(int16 *m1, int16 *up, int16 *result, unsigned int16 rows, unsigned int16 columns);
[1225]25
[1174]26/* perform Thorton update of UD matrix using PSI*U, Q, and temporaries G, Dold, for size dimx*/
[1240]27extern void thorton(int16 *U, int16 *D, int16 *PSIU, int16 *Q, int16 *G, int16 *Dold, unsigned int16 dimx);
[1174]28
29/* perform Bierman update of UD matrix using difz, R and xp, for size dimx*/
[1240]30extern void bierman(int16 *difz, int16 *xp, int16 *U, int16 *D, int16 *R, unsigned int16 dimy, unsigned int16 dimx );
[1179]31
32/* perform Thorton update of UD matrix using PSI*U, Q, and temporaries G, Dold, for size dimx*/
[1240]33extern void thorton_fast(int16 *U, int16 *D, int16 *PSIU, int16 *Q, int16 *G, int16 *Dold, unsigned int16 dimx);
[1179]34
35/* perform Bierman update of UD matrix using difz, R and xp, for size dimx*/
[1240]36extern void bierman_fast(int16 *difz, int16 *xp, int16 *U, int16 *D, int16 *R, unsigned int16 dimy, unsigned int16 dimx );
[1225]37
38/* perform Householder update of Ch matrix using PSI*Ch , Q, */
[1240]39extern void householder(int16 *Ch /*= int16 *PSICh*/, int16 *Q, unsigned int16 dimx);
[1225]40
[1230]41/* perform Givens update of Ch matrix using PSI*Ch , Q, */
[1240]42extern void givens(int16 *Ch /*= int16 *PSICh*/, int16 *Q, unsigned int16 dimx);
[1230]43
[1225]44/* perform Carlson update of Ch matrix using difz, R and xp, for size dimx*/
[1240]45extern void carlson(int16 *difz, int16 *xp, int16 *Ch, int16 *R, unsigned int16 dimy, unsigned int16 dimx );
Note: See TracBrowser for help on using the browser.