Changeset 1251

Show
Ignore:
Timestamp:
11/14/10 23:11:49 (14 years ago)
Author:
smidl
Message:

restructuring of PMSM control

Location:
applications/pmsm
Files:
2 modified

Legend:

Unmodified
Added
Removed
  • applications/pmsm/experiments/ctrl.cfg

    r1247 r1251  
    99        params = "pmsm107@../cfg/zcu.cfg"; 
    1010        tstep = 1; // steps for profile in [s] 
    11 //      profileW = [0, 0, -30, -200, -90, -60, -30, 0, 30, 200]; 
    12         profileW = [0, -10, 30, 60, 90, 60, 30, 0, -30, -60, -30]; 
     11        profileW = [0, 30, 0, 2 ]; 
     12//      profileW = [0, -10, 30, 60, 90, 60, 30, 0, -30, -60, -30]; 
    1313//      profileW = [1, 10, 50, 200, 200, 30, 0, 0, -30, -30, -100, -100, -40, 0, 0]; 
    1414//      profileM = [0, 30, 0, 0, 30, 0, 0, 0, 0, 0, 10, 0, 0]; 
     
    2121         }; 
    2222         OM = {class="OMpmsm";}; 
    23         dQ=[0.01, 0.01, 0.0001, 0.0001]; 
     23        dQ=[0.01, 0.01, 0.0001, 0.0000000001]; 
    2424        dR=[0.05, 0.05]; 
    2525         //connect 
    26          yrv = {class="RV"; names=("o_ia","o_ib");};  // observed u 
    27          rvc = {class="RV"; names=("t_ua","t_ub");};  // observed u 
    28          rv = {class="RV"; names=("ia","ib","om","th");}; 
    29          log_level="logmean,logevidence,logU,logG,logD"; 
     26         log_level="logmean,logU,logG,logD"; 
    3027         name = "Est0"; 
    3128         }; 
  • applications/pmsm/pmsm_ctrl.h

    r1243 r1251  
    3535}; 
    3636 
    37 class PMSM_PICtrl: public Controller{ 
     37/*! \brief Root class for controllers of PMSM 
     38 *  
     39 * It defines the interface for controllers that connect to the pmsmDSctrl.  
     40 * The adapt() function calls bayes() of an internal BM. Note that it is assumed that the estimator is compatible with PMSM system. 
     41 * I.e. it must have rv={ia, ib} and rvc={ua,ub}, any other BM will not work. 
     42 *  
     43 */ 
     44class PMSMCtrl: public Controller{ 
    3845protected: 
     46        //! Est where rv and rcv are not used! 
    3947        shared_ptr<BM> Est; 
    40         vec state; 
     48        //! switch to use or not to use the internal estimator 
     49        bool estim; 
     50         
     51        // internal quantities filled by PMSMCtrl::ctrlaction() 
     52        double isa; 
     53        double isb; 
     54        double ome; 
     55        double the; 
     56        double Ww; 
     57         
     58public: 
     59 
     60        PMSMCtrl():Controller() { 
     61                rv = RV("{ua ub }"); 
     62                rvc = RV("{o_ia o_ib o_ua o_ub o_om o_th Ww }"); 
     63        } 
     64         
     65    void adapt(const itpp::vec& data){ 
     66                if (estim){ 
     67                        vec y=data.get(0,1); 
     68                        vec u=data.get(2,3); 
     69                        Est->bayes(y,u); 
     70                } 
     71        } 
     72         
     73         
     74    virtual vec ctrlaction(const itpp::vec& cond) { 
     75                 
     76                if (estim){ 
     77                        vec x_est=Est->posterior().mean(); 
     78                        isa=x_est(0); 
     79                        isb=x_est(1); 
     80                        ome=x_est(2); 
     81                        the=x_est(3); 
     82                } else { 
     83                        isa=cond(0);//x_est(0); 
     84                        isb=cond(1);//x_est(1); 
     85                        ome=cond(4);//x[2];//x_est(2); 
     86                        the=cond(5);//x_est(3); 
     87                } 
     88                Ww=cond(6); 
     89                 
     90                return empty_vec; // dummy return 
     91        }; 
     92    void from_setting(const libconfig::Setting& set){ 
     93                Controller::from_setting(set); 
     94                Est=UI::build<BM>(set,"estim",UI::optional); 
     95                estim = Est;  
     96        } 
     97        void log_register ( logger &L, const string &prefix ) { 
     98                Controller::log_register(L,prefix); 
     99                if (estim) Est->log_register(L,prefix); 
     100        } 
     101        void log_write() const{ 
     102                if (estim) Est->log_write(); 
     103        } 
     104}; 
     105//UIREGISTER(PMSMCtrl); -- abstract  
     106 
     107class PMSM_PICtrl: public PMSMCtrl{ 
    41108public: 
    42109        PI_ctrl Cwq; 
    43110        PI_ctrl Cuq; 
    44111        PI_ctrl Cud; 
    45  
    46         PMSM_PICtrl():  Cwq(3.0, 3.0*0.000125/0.1, -1200, 1200),  
    47                                         Cuq(20.0, 20.0*0.000125/0.005, -1200, 1200), 
    48                                         Cud(20.0, 20.0*0.000125/0.005, -1200, 1200) 
    49         { 
    50                 rv = RV("{ua ub }"); 
    51                 rvc = RV("{o_ia o_ib o_ua o_ub Ww o_om o_th }"); 
    52         } 
     112                 
     113        PMSM_PICtrl():PMSMCtrl(), 
     114        Cwq(3.0, 3.0*0.000125/0.1, -1200, 1200),  
     115        Cuq(20.0, 20.0*0.000125/0.005, -1200, 1200), 
     116        Cud(20.0, 20.0*0.000125/0.005, -1200, 1200) {} 
     117                 
    53118         
    54     void adapt(const itpp::vec& data){ 
    55                 vec y=data.get(0,1); 
    56                 vec u=data.get(2,3); 
    57                 Est->bayes(y,u); 
    58                  
    59         } 
    60          
    61          
    62     virtual vec ctrlaction(const itpp::vec& cond) { 
    63                 vec x_est=Est->posterior().mean(); 
    64                 double isa=cond(0);//x_est(0); 
    65                 double isb=cond(1);//x_est(1); 
    66                 double ome=cond(5);//x[2];//x_est(2); 
    67                 double the=cond(6);//x_est(3); 
    68                 double Ww=cond(4); 
     119        virtual vec ctrlaction(const itpp::vec& cond) { 
     120                PMSMCtrl::ctrlaction(cond); // fills isa,isb,om,the 
    69121                 
    70122                double Isd = isa*cos(the)+isb*sin(the); 
     
    78130                const double Ls0=0.003465; // inductance 
    79131                const double Fmag0= 0.1989; // Magnetic?? 
    80  
     132                 
    81133                ud-=Ls0*ome*Iqw; // har 
    82134                uq+=Fmag0*ome; 
     
    93145                return uab; 
    94146        }; 
    95     void from_setting(const libconfig::Setting& set){ 
    96                 Controller::from_setting(set); 
    97                 Est=UI::build<BM>(set,"estim",UI::compulsory); 
    98         } 
    99147}; 
    100148UIREGISTER(PMSM_PICtrl);