/*! \file \brief Simulation of disturbances in PMSM model, EKF runs with simulated covariances \author Vaclav Smidl. \ingroup PMSM ----------------------------------- BDM++ - C++ library for Bayesian Decision Making under Uncertainty Using IT++ for numerical operations ----------------------------------- */ #include #include #include #include #include #include "pmsm.h" #include "simulator.h" #include "sim_profiles.h" #include using namespace bdm; class IMpmsm_load : public IMpmsm { public: IMpmsm_load() :IMpmsm() {}; void condition ( const vec &val ) {Mz = val(0);} }; int main() { // Kalman filter int Ndat = 90000; double h = 1e-6; int Nsimstep = 125; int Npart = 200; dirfilelog L("exp/mpf_load",1000); // SET SIMULATOR pmsmsim_set_parameters ( 0.28,0.003465,0.1989,0.0,4,1.5,0.04, 200., 3e-6, h ); double Ww = 0.0; vec dt ( 2 ); vec ut ( 2 ); IMpmsm_load fxu; IMpmsm fxu0; // Rs Ls dt Fmag(Ypm) kp p J Bf(Mz) fxu.set_parameters ( 0.28, 0.003465, Nsimstep*h, 0.1989, 1.5 ,4.0, 0.04, 0.0 ); fxu0.set_parameters ( 0.28, 0.003465, Nsimstep*h, 0.1989, 1.5 ,4.0, 0.04, 0.0 ); OMpmsm hxu; // ESTIMATORS vec mu0= "0.0 0.0 0.0 0.0"; vec Qdiag0 ( "62 66 454 0.03" ); //zdenek: 0.01 0.01 0.0001 0.0001 vec Qdiag ( "6 6 1 0.003" ); //zdenek: 0.01 0.01 0.0001 0.0001 vec Rdiag ( "100 100" ); //var(diff(xth)) = "0.034 0.034" mat Q =diag( Qdiag ); mat R =diag ( Rdiag ); EKFfull Efix ( rx,ry,ru ); Efix.set_est ( mu0, 1*eye ( 4 ) ); Efix.set_parameters ( &fxu0,&hxu,diag(Qdiag0),R); RV rMz=RV("{Mz }"); mlnorm evolMz(rMz,rMz); evolMz.set_parameters(mat("1"),vec("0"),ldmat(1.0*vec("1"))); evolMz.condition(" 0.0"); EKFCh_cond Ep ( rx,ry,ru,rMz ); Ep.set_est ( mu0, 1*eye ( 4 ) ); Ep.set_parameters ( &fxu,&hxu,Q,R); MPF M ( rx,rMz,evolMz,evolMz, Npart, Ep ); M.set_est(evolMz.posterior()); //LOG int X_log = L.add(rx,"X"); int E_log = L.add(rx,"EX"); int M_log = L.add(concat(rMz,rx),"MX"); L.init(); for ( int tK=1;tK