root/applications/pmsm/simulator_zdenek/ekf_example/ekf_obj.h @ 1206

Revision 1201, 6.6 kB (checked in by smidl, 14 years ago)

verbose ekf

  • Property svn:eol-style set to native
Line 
1/*!
2  \file
3  \brief Bayesian Filtering for linear Gaussian models (Kalman Filter) and extensions
4  \author Vaclav Smidl.
5
6  -----------------------------------
7  BDM++ - C++ library for Bayesian Decision Making under Uncertainty
8
9  Using IT++ for numerical operations
10  -----------------------------------
11*/
12
13#ifndef EKFfix_H
14#define EKFfix_H
15
16
17#include <estim/kalman.h>
18#include "fixed.h"
19#include "matrix.h"
20#include "matrix_vs.h"
21#include "reference.h"
22#include "parametry_motoru.h"
23
24using namespace bdm;
25
26double minQ(double Q);
27
28void mat_to_int(const imat &M, int *I);
29void vec_to_int(const ivec &v, int *I);
30void UDtof(const mat &U, const vec &D, imat &Uf, ivec &Df, const vec &xref);
31       
32/*!
33\brief Extended Kalman Filter with full matrices in fixed point arithmetic
34
35An approximation of the exact Bayesian filter with Gaussian noices and non-linear evolutions of their mean.
36*/
37class EKFfixed : public BM {
38public:
39void init_ekf(double Tv);
40void ekf(double ux, double uy, double isxd, double isyd);
41
42/* Declaration of local functions */
43void prediction(int *ux);
44void correction(void);
45void update_psi(void);
46
47/* Constants - definovat jako konstanty ?? ?kde je vyhodnejsi aby v pameti byli?*/
48 int Q[16]; /* matrix [4,4] */
49 int R[4]; /* matrix [2,2] */
50
51 int x_est[4];
52 int x_pred[4];
53 int P_pred[16]; /* matrix [4,4] */
54 int P_est[16]; /* matrix [4,4] */
55 int Y_mes[2];
56 int ukalm[2];
57 int Kalm[8]; /* matrix [5,2] */
58
59 int PSI[16]; /* matrix [4,4] */
60
61 int temp15a[16];
62
63 int cA, cB, cC, cG, cH;  // cD, cE, cF, cI ... nepouzivane
64
65 long temp30a[4]; /* matrix [2,2] - temporary matrix for inversion */
66 enorm<fsqmat> E;
67 mat Ry;
68 
69public:
70        //! Default constructor
71        EKFfixed ():BM(),E(),Ry(2,2){
72                int i;
73                for(i=0;i<16;i++){Q[i]=0;}
74                for(i=0;i<4;i++){R[i]=0;}
75
76                for(i=0;i<4;i++){x_est[i]=0;}
77                for(i=0;i<4;i++){x_pred[i]=0;}
78                for(i=0;i<16;i++){P_pred[i]=0;}
79                for(i=0;i<16;i++){P_est[i]=0;}
80                P_est[0]=0x7FFF;
81                P_est[5]=0x7FFF;
82                P_est[10]=0x7FFF;
83                P_est[15]=0x7FFF;
84                for(i=0;i<2;i++){Y_mes[i]=0;}
85                for(i=0;i<2;i++){ukalm[i]=0;}
86                for(i=0;i<8;i++){Kalm[i]=0;}
87
88                for(i=0;i<16;i++){PSI[i]=0;}
89
90                set_dim(4);
91                E._mu()=zeros(4);
92                E._R()=zeros(4,4);
93                init_ekf(0.000125);
94        };
95        //! Here dt = [yt;ut] of appropriate dimensions
96        void bayes ( const vec &yt, const vec &ut );
97        //!dummy!
98        const epdf& posterior() const {return E;};
99       
100};
101
102UIREGISTER(EKFfixed);
103
104/*!
105\brief Extended Kalman Filter with UD matrices in fixed point arithmetic
106
107An approximation of the exact Bayesian filter with Gaussian noices and non-linear evolutions of their mean.
108*/
109class EKFfixedUD : public BM {
110        public:
111                LOG_LEVEL(EKFfixedUD,logU, logG, logD, logA);
112               
113                void init_ekf(double Tv);
114                void ekf(double ux, double uy, double isxd, double isyd);
115                               
116                /* Constants - definovat jako konstanty ?? ?kde je vyhodnejsi aby v pameti byli?*/
117                int Q[16]; /* matrix [4,4] */
118                int R[4]; /* matrix [2,2] */
119               
120                int x_est[4]; /* estimate and prediction */
121               
122                int PSI[16]; /* matrix [4,4] */
123                int PSIU[16]; /* matrix PIS*U, [4,4] */
124               
125                int Uf[16]; // upper triangular of covariance (inplace)
126                int Df[4];  // diagonal covariance
127                int Dfold[4]; // temp of D
128                int G[16];  // temp for bierman
129               
130                int cA, cB, cC, cG, cH;  // cD, cE, cF, cI ... nepouzivane
131               
132                enorm<fsqmat> E;
133                mat Ry;
134               
135        public:
136                //! Default constructor
137                EKFfixedUD ():BM(),E(),Ry(2,2){
138                        int i;
139                        for(i=0;i<16;i++){Q[i]=0;}
140                        for(i=0;i<4;i++){R[i]=0;}
141                       
142                        for(i=0;i<4;i++){x_est[i]=0;}
143                        for(i=0;i<16;i++){Uf[i]=0;}
144                        for(i=0;i<4;i++){Df[i]=0;}
145                        for(i=0;i<16;i++){G[i]=0;}
146                        for(i=0;i<4;i++){Dfold[i]=0;}
147                       
148                        for(i=0;i<16;i++){PSI[i]=0;}
149                       
150                        set_dim(4);
151                        E._mu()=zeros(4);
152                        E._R()=zeros(4,4);
153                        init_ekf(0.000125);
154                };
155                //! Here dt = [yt;ut] of appropriate dimensions
156                void bayes ( const vec &yt, const vec &ut );
157                //!dummy!
158                const epdf& posterior() const {return E;};
159                void log_register(logger &L, const string &prefix){
160                        BM::log_register ( L, prefix );
161                       
162                                L.add_vector ( log_level, logG, RV("G",16), prefix );
163                                L.add_vector ( log_level, logU, RV ("U", 16 ), prefix );
164                                L.add_vector ( log_level, logD, RV ("D", 4 ), prefix );
165                                L.add_vector ( log_level, logA, RV ("A", 16 ), prefix );
166                               
167                };
168                //void from_setting();
169};
170
171UIREGISTER(EKFfixedUD);
172
173//! EKF for comparison of EKF_UD with its fixed-point implementation
174class EKF_UDfix : public BM {
175        protected:
176                //! logger
177                LOG_LEVEL(EKF_UDfix,logU, logG);
178                //! Internal Model f(x,u)
179                shared_ptr<diffbifn> pfxu;
180               
181                //! Observation Model h(x,u)
182                shared_ptr<diffbifn> phxu;
183               
184                //! U part
185                mat U;
186                //! D part
187                vec D;
188                               
189                mat A;
190                mat C;
191                mat Q;
192                vec R;
193               
194                enorm<ldmat> est;
195               
196               
197        public:
198               
199                //! copy constructor duplicated
200                EKF_UDfix* _copy() const {
201                        return new EKF_UDfix(*this);
202                }
203               
204                const enorm<ldmat>& posterior()const{return est;};
205               
206                enorm<ldmat>& prior() {
207                        return const_cast<enorm<ldmat>&>(posterior());
208                }
209               
210                EKF_UDfix(){}
211               
212               
213                EKF_UDfix(const EKF_UDfix &E0): pfxu(E0.pfxu),phxu(E0.phxu), U(E0.U), D(E0.D){}
214               
215                //! Set nonlinear functions for mean values and covariance matrices.
216                void set_parameters ( const shared_ptr<diffbifn> &pfxu, const shared_ptr<diffbifn> &phxu, const mat Q0, const vec R0 );
217               
218                //! Here dt = [yt;ut] of appropriate dimensions
219                void bayes ( const vec &yt, const vec &cond = empty_vec );
220               
221                void log_register ( bdm::logger& L, const string& prefix ){
222                        BM::log_register ( L, prefix );
223                       
224                        if ( log_level[logU] )
225                                L.add_vector ( log_level, logU, RV ( dimension()*dimension() ), prefix );
226                        if ( log_level[logG] )
227                                L.add_vector ( log_level, logG, RV ( dimension()*dimension() ), prefix );
228                       
229                }
230                /*! Create object from the following structure
231               
232                \code
233                class = 'EKF_UD';
234                OM = configuration of bdm::diffbifn;    % any offspring of diffbifn, bdm::diffbifn::from_setting
235                IM = configuration of bdm::diffbifn;    % any offspring of diffbifn, bdm::diffbifn::from_setting
236                dQ = [...];                             % vector containing diagonal of Q
237                dR = [...];                             % vector containing diagonal of R
238                --- optional fields ---
239                mu0 = [...];                            % vector of statistics mu0
240                dP0 = [...];                            % vector containing diagonal of P0
241                -- or --
242                P0 = [...];                             % full matrix P0
243                --- inherited fields ---
244                bdm::BM::from_setting
245                \endcode
246                If the optional fields are not given, they will be filled as follows:
247                \code
248                mu0 = [0,0,0,....];                     % empty statistics
249                P0 = eye( dim );             
250                \endcode
251                */
252                void from_setting ( const Setting &set );
253               
254                void validate() {};
255                // TODO dodelat void to_setting( Setting &set ) const;
256               
257};
258UIREGISTER(EKF_UDfix);
259
260
261
262
263#endif // KF_H
264
Note: See TracBrowser for help on using the browser.