Changeset 1302

Show
Ignore:
Timestamp:
03/23/11 19:39:30 (14 years ago)
Author:
vahalam
Message:

pridana penalizace (u(t)-u(t-1))2, jeji koeficient se nastavuje v rpd a pricita se k predchozim, r zustava koeficient u u(t)2

Files:
1 modified

Legend:

Unmodified
Added
Removed
  • applications/pmsm/pmsm_ctrl.h

    r1298 r1302  
    174174UIREGISTER(PMSM_PICtrl); 
    175175 
     176/*************************************/ 
     177/*                      LQ alpa-beta              */ 
     178/*************************************/ 
     179 
    176180class PMSM_LQCtrl: public PMSMCtrl{ 
    177181public: 
     
    214218         
    215219//control maximum 
    216         const double MAXu; 
     220        double MAXu; 
     221        int MAXuflag; 
    217222         
    218223//lqg controler class 
     
    225230                                r(0.005), Dt(0.000125), rec_hor(10),                                    //for r is a default value rewrited by pcp.txt file value 
    226231                                A(5, 5), B(5, 2), Q(5, 5), R(2, 2), 
    227                                 uab(2), icond(6), MAXu(100.0)   {                        
     232                                uab(2), icond(6), MAXu(100.0), MAXuflag(0)      {                        
    228233                //set fix matrices elements & dimensions 
    229234                A.zeros(); 
     
    294299                vec tmp = L*icond;                   
    295300                 
    296                 uab = tmp(0,1); 
    297                  
    298                 if(uab(0) > MAXu) uab(0) = MAXu; 
    299                 else if(uab(0) < -MAXu) uab(0) = -MAXu; 
    300                 if(uab(1) > MAXu) uab(1) = MAXu; 
    301                 else if(uab(1) < -MAXu) uab(1) = -MAXu; 
     301                uab = tmp(0,1);          
     302                 
     303                if(MAXuflag == 1){ //square cut off 
     304                        if(uab(0) > MAXu) uab(0) = MAXu; 
     305                        else if(uab(0) < -MAXu) uab(0) = -MAXu; 
     306                        if(uab(1) > MAXu) uab(1) = MAXu; 
     307                        else if(uab(1) < -MAXu) uab(1) = -MAXu; 
     308                } 
     309                else if(MAXuflag == 2){ //circular cut off 
     310                        double uampl = sqrt(uab(0)*uab(0)+uab(1)*uab(1)); 
     311                        double uangl = atan2(uab(1), uab(0)); 
     312                        if (uampl > MAXu) uampl = MAXu; 
     313                        uab(0) = uampl*cos(uangl); 
     314                        uab(1) = uampl*sin(uangl); 
     315                } 
     316                //else{ //(MAXuflag == 0) //no cut off } 
    302317                 
    303318                return uab; 
    304         }; 
     319        } 
     320         
    305321        void from_setting(const Setting &set){ 
    306322                PMSMCtrl::from_setting(set); 
    307323                UI::get(r,set, "r", UI::optional); 
    308324                UI::get(rec_hor,set, "h", UI::optional); 
     325                UI::get(MAXu,set, "MAXu", UI::optional); 
     326                UI::get(MAXuflag,set, "MAXuflag", UI::optional); 
    309327        } 
    310328 
     
    351369UIREGISTER(PMSM_LQCtrl); 
    352370 
     371/*************************************/ 
     372/*                      LQ d-q 1                          */ 
     373/*************************************/ 
     374 
    353375class PMSM_LQCtrl_dq: public PMSMCtrl{ 
    354376public: 
     
    371393//input penalty 
    372394        double r; 
     395        double rpd; //penalize differences u - u_old 
    373396         
    374397//time step 
     
    383406        //mat C; //2x5 
    384407        mat Q; //5x5 
    385         mat R; //2x2     
     408        mat R; //2x2 
     409        mat Rpd; //2x4 
    386410         
    387411//control matrix 
    388412        mat L; 
    389         vec uab; 
    390         vec icond; 
     413        vec uab;         
     414        vec icondpd; 
     415        vec u_old; 
    391416         
    392417//control maximum 
    393         const double MAXu; 
     418        double MAXu; 
     419        int MAXuflag; 
    394420         
    395421//lqg controler class 
     
    400426                 
    401427        PMSM_LQCtrl_dq():PMSMCtrl(), a(0.9898), b(0.0072), c(0.0361), d(1.0), e(0.0149), 
    402                                 r(0.005), Dt(0.000125), rec_hor(10),                                    //for r is a default value rewrited by pcp.txt file value 
    403                                 A(5, 5), B(5, 2), Q(5, 5), R(2, 2), 
    404                                 uab(2), icond(6), MAXu(100.0)   {                        
     428                                r(0.005), rpd(0.1), Dt(0.000125), rec_hor(10),                                  //for r is a default value rewrited by pcp.txt file value 
     429                                A(5, 5), B(5, 2), Q(5, 5), R(2, 2), Rpd(2, 4), 
     430                                uab(2), u_old(2), icondpd(8), MAXu(100.0), MAXuflag(0)  {                        
    405431                //set fix matrices elements & dimensions 
    406432                A.zeros(); 
     
    413439                        A(3, 3) = A(4, 4) = 1.0; 
    414440                B.zeros(); 
    415                         B(0, 0) = B(1, 1) = c; 
    416                 //C.zeros(); 
    417                 //      C(0, 0) = C(1, 1) = 1.0; 
     441                        B(0, 0) = B(1, 1) = c;           
    418442                Q.zeros(); 
    419443                        Q(2, 2) = 1.0; 
    420444                R.zeros(); 
    421                                                                  
     445                Rpd.zeros(); 
     446                u_old.zeros();                                           
    422447        } 
    423448                 
     
    425450        virtual vec ctrlaction(const itpp::vec& cond) { 
    426451                PMSMCtrl::ctrlaction(cond); // fills isa,isb,ome,the,Ww 
    427                  
    428                 int i; 
     452                                 
    429453                vec udq; 
     454                vec tmp; 
     455                 
    430456                lq.resetTime(); 
    431                  
    432                 //create prediction 
    433                 /*p_isa.zeros(); 
    434                 p_isb.zeros(); 
    435                 p_ome.zeros(); 
    436                 p_the.zeros(); 
    437                 p_isa(0) = isa; 
    438                 p_isb(0) = isb; 
    439                 p_ome(0) = ome; 
    440                 p_the(0) = the; 
    441                                  
    442                 //create control matrix 
    443                 /*for(i = rec_hor; i > 0; i--){                                                          
    444                         lq.redesign(); 
    445                 } 
    446                 lq.redesign(); 
    447                 */ 
     457                                 
    448458                L = lq.getL(); 
    449                 icond(0) = isa*cos(the) + isb*sin(the); 
    450                 icond(1) = isb*cos(the) - isa*sin(the); 
    451                 icond(2) = ome - Ww; 
    452                 icond(3) = the; 
    453                 icond(4) = Ww; 
    454                 icond(5) = 1; 
    455                 vec tmp = L*icond;                   
    456                  
     459                 
     460                icondpd(0) = isa*cos(the) + isb*sin(the); 
     461                icondpd(1) = isb*cos(the) - isa*sin(the); 
     462                icondpd(2) = ome - Ww; 
     463                icondpd(3) = the; 
     464                icondpd(4) = Ww; 
     465                icondpd(5) = u_old(0); 
     466                icondpd(6) = u_old(1); 
     467                icondpd(7) = 1;  
     468                         
     469                tmp = L*icondpd;                 
     470                                                 
    457471                udq = tmp(0,1); 
    458472                 
     
    461475                uab(1) = udq(1)*cos(the) + udq(0)*sin(the); 
    462476                 
    463                 if(uab(0) > MAXu) uab(0) = MAXu; 
    464                 else if(uab(0) < -MAXu) uab(0) = -MAXu; 
    465                 if(uab(1) > MAXu) uab(1) = MAXu; 
    466                 else if(uab(1) < -MAXu) uab(1) = -MAXu; 
     477                if(MAXuflag == 1){ //square cut off 
     478                        if(uab(0) > MAXu) uab(0) = MAXu; 
     479                        else if(uab(0) < -MAXu) uab(0) = -MAXu; 
     480                        if(uab(1) > MAXu) uab(1) = MAXu; 
     481                        else if(uab(1) < -MAXu) uab(1) = -MAXu; 
     482                } 
     483                else if(MAXuflag == 2){ //circular cut off 
     484                        double uampl = sqrt(uab(0)*uab(0)+uab(1)*uab(1)); 
     485                        double uangl = atan2(uab(1), uab(0)); 
     486                        if (uampl > MAXu) uampl = MAXu; 
     487                        uab(0) = uampl*cos(uangl); 
     488                        uab(1) = uampl*sin(uangl); 
     489                } 
     490                //else{ //(MAXuflag == 0) //no cut off } 
     491                 
     492                u_old = uab; 
    467493                 
    468494                return uab; 
    469         }; 
     495        } 
     496         
    470497        void from_setting(const Setting &set){ 
    471498                PMSMCtrl::from_setting(set); 
    472499                UI::get(r,set, "r", UI::optional); 
    473500                UI::get(rec_hor,set, "h", UI::optional); 
     501                UI::get(MAXu,set, "MAXu", UI::optional); 
     502                UI::get(MAXuflag,set, "MAXuflag", UI::optional); 
     503                UI::get(rpd,set, "rpd", UI::optional);           
    474504        } 
    475505 
    476506        void validate(){ 
    477                 R(0,0)=R(1,1)=r; 
    478  
     507                R(0, 0) = R(1, 1) = r; 
     508                Rpd(0, 0) = Rpd(1, 1) = rpd; 
     509                Rpd(0, 2) = Rpd(1, 3) = -rpd; 
     510                                 
    479511                p_isa.set_length(rec_hor+1); 
    480512                p_isb.set_length(rec_hor+1); 
     
    482514                p_the.set_length(rec_hor+1); 
    483515 
    484                 Array<quadraticfn> qloss(2); 
     516                Array<quadraticfn> qloss(3); 
    485517                qloss(0).Q.setCh(Q); 
    486                 qloss(0).rv = RV("x", 5, 1); 
     518                qloss(0).rv = RV("x", 5, 1);             
    487519                qloss(1).Q.setCh(R); 
    488                 qloss(1).rv = RV("u", 2, 0);             
     520                qloss(1).rv = RV("u", 2, 0); 
     521                qloss(2).Q.setCh(Rpd);           
     522                qloss(2).rv = RV("u", 2, 0); 
     523                qloss(2).rv.add(RV("u", 2, -1));                 
    489524                lq.Losses = qloss;               
    490525 
    491                                 //set lq 
    492                 lq.rv = RV("u", 2, 0);                   
    493                 lq.set_rvc(RV("x", 5, 0)); 
     526                //set lq 
     527                lq.rv = RV("u", 2, 0);   
     528                RV tmp = RV("x", 5, 0); 
     529                tmp.add(RV("u", 2, -1)); 
     530                lq.set_rvc(tmp);                 
    494531                lq.horizon = rec_hor;    
    495532                 
     
    507544                lq.finalLoss.Q.setCh(Q); 
    508545                lq.finalLoss.rv = RV("x", 5, 1); 
    509                  
     546                                 
    510547                lq.validate(); 
    511548                                                 
    512549                uab.zeros(); 
    513                  
     550                                 
    514551                //create control matrix 
    515552                for(int i = rec_hor; i > 0; i--){                                                                
     
    520557}; 
    521558UIREGISTER(PMSM_LQCtrl_dq); 
     559 
     560/*************************************/ 
     561/*                      LQ d-q 2                          */ 
     562/*************************************/ 
    522563 
    523564class PMSM_LQCtrl_dq2: public PMSMCtrl{ 
     
    541582//input penalty 
    542583        double r; 
     584        double rpd; //penalize differences u - u_old 
    543585         
    544586//time step 
     
    553595        //mat C; //2x5 
    554596        mat Q; //5x5 
    555         mat R; //2x2     
     597        mat R; //2x2 
     598        mat Rpd; //2x4   
    556599         
    557600//control matrix 
    558601        mat L; 
    559602        vec uab,udq; 
    560         vec icond; 
     603        vec icondpd; 
     604        vec u_old; 
    561605         
    562606//control maximum 
    563         const double MAXu; 
     607        double MAXu; 
     608        int MAXuflag; 
    564609         
    565610//lqg controler class 
     
    570615                 
    571616        PMSM_LQCtrl_dq2():PMSMCtrl(), a(0.9898), b(0.0072), c(0.0361), d(1.0), e(0.0149), 
    572                                 r(0.005), Dt(0.000125), rec_hor(10),                                    //for r is a default value rewrited by pcp.txt file value 
    573                                 A(5, 5), B(5, 2), Q(5, 5), R(2, 2), 
    574                                 uab(2), udq(2), icond(6), MAXu(100.0)   {                        
     617                                r(0.005), rpd(0.1), Dt(0.000125), rec_hor(10),                                  //for r is a default value rewrited by pcp.txt file value 
     618                                A(5, 5), B(5, 2), Q(5, 5), R(2, 2), Rpd(2, 4), 
     619                                uab(2), udq(2), u_old(2), icondpd(8), MAXu(100.0), MAXuflag(0)  {                        
    575620                //set fix matrices elements & dimensions 
    576621                A.zeros(); 
     
    582627                        A(3, 3) = A(4, 4) = 1.0; 
    583628                B.zeros(); 
    584                         B(0, 0) = B(1, 1) = c; 
    585                 //C.zeros(); 
    586                 //      C(0, 0) = C(1, 1) = 1.0; 
     629                        B(0, 0) = B(1, 1) = c;           
    587630                Q.zeros(); 
    588631                        Q(2, 2) = 1.0; 
    589632                R.zeros(); 
    590                                                                  
     633                Rpd.zeros(); 
     634                u_old.zeros();                                           
    591635        } 
    592636                 
     
    596640                 
    597641                int i; 
     642                vec tmp; 
    598643                 
    599644                lq.resetTime(); 
    600         //cout << "OK" << endl; 
     645         
    601646                //create prediction 
    602647                p_isd.zeros(); 
     
    608653                p_ome(0) = ome; 
    609654                p_the(0) = the; 
    610         //cout << "OKkkk" << endl;       
    611                 for(i = 0; i < rec_hor-1; i++){ 
    612                         /*p_isa(i+1) = a*p_isa(i) + b*p_ome(i)*sin(p_the(i)) + c*0;//uab(0); //use last used control 
    613                         p_isb(i+1) = a*p_isb(i) - b*p_ome(i)*cos(p_the(i)) + c*0;//uab(1); 
    614                         p_ome(i+1) = d*p_ome(i) + e*(p_isb(i)*cos(p_the(i)) - p_isa(i)*sin(p_the(i))); 
    615                         p_the(i+1) = p_the(i) + Dt*p_ome(i);*/ 
    616                         p_isd(i+1) = a*p_isd(i) + p_isq(i)*p_ome(i)*Dt + c*udq(0); 
    617                         //cout << "OKaa" << endl; 
     655                 
     656                for(i = 0; i < rec_hor-1; i++){                  
     657                        p_isd(i+1) = a*p_isd(i) + p_isq(i)*p_ome(i)*Dt + c*udq(0);                       
    618658                        p_isq(i+1) = -p_isd(i)*p_ome(i)*Dt + a*p_isq(i) - b*p_ome(i) + c*udq(1); 
    619659                        p_ome(i+1) = d*p_ome(i) + e*p_isq(i); 
    620                         p_the(i+1) = p_the(i) + Dt*p_ome(i); 
    621                         //cout << "1"; 
     660                        p_the(i+1) = p_the(i) + Dt*p_ome(i);                     
    622661                } 
    623662                 
    624663                //create control matrix 
    625664                for(i = rec_hor; i > 0; i--){            
    626                         //set variable matrices elements (A matrix only) 
    627                         /*A(0, 2) = b*sin(p_the(i)); 
    628                         A(0, 3) = b*(p_ome(i))*cos(p_the(i)); 
    629                         A(0, 4) = b*sin(p_the(i)); 
    630                         A(1, 2) = -b*cos(p_the(i)); 
    631                         A(1, 3) = b*(p_ome(i))*sin(p_the(i)); 
    632                         A(1, 4) = -b*cos(p_the(i)); 
    633                         A(2, 0) = -e*sin(p_the(i)); 
    634                         A(2, 1) = e*cos(p_the(i)); 
    635                         A(2, 3) = -e*(p_isa(i)*cos(p_the(i)) + p_isb(i)*sin(p_the(i)));*/ 
     665                        //set variable matrices elements (A matrix only)                         
    636666                        A(0, 1) = Dt*p_ome(i); 
    637667                        A(0, 2) = Dt*p_isq(i); 
     
    647677                 
    648678                L = lq.getL(); 
    649                 //icond(0) = isa; 
    650                 //icond(1) = isb; 
    651                 icond(0) = isa*cos(the) + isb*sin(the); 
    652                 icond(1) = isb*cos(the) - isa*sin(the); 
    653                 icond(2) = ome - Ww; 
    654                 icond(3) = the; 
    655                 icond(4) = Ww; 
    656                 icond(5) = 1; 
    657                 vec tmp = L*icond;                   
    658                  
    659                 //uab = tmp(0,1); 
     679                 
     680                icondpd(0) = isa*cos(the) + isb*sin(the); 
     681                icondpd(1) = isb*cos(the) - isa*sin(the); 
     682                icondpd(2) = ome - Ww; 
     683                icondpd(3) = the; 
     684                icondpd(4) = Ww; 
     685                icondpd(5) = u_old(0); 
     686                icondpd(6) = u_old(1); 
     687                icondpd(7) = 1; 
     688                         
     689                tmp = L*icondpd;                         
     690                                 
    660691                udq = tmp(0,1); 
    661692                 
     
    664695                uab(1) = udq(1)*cos(the) + udq(0)*sin(the); 
    665696                 
    666                 if(uab(0) > MAXu) uab(0) = MAXu; 
    667                 else if(uab(0) < -MAXu) uab(0) = -MAXu; 
    668                 if(uab(1) > MAXu) uab(1) = MAXu; 
    669                 else if(uab(1) < -MAXu) uab(1) = -MAXu; 
     697                if(MAXuflag == 1){ //square cut off 
     698                        if(uab(0) > MAXu) uab(0) = MAXu; 
     699                        else if(uab(0) < -MAXu) uab(0) = -MAXu; 
     700                        if(uab(1) > MAXu) uab(1) = MAXu; 
     701                        else if(uab(1) < -MAXu) uab(1) = -MAXu; 
     702                } 
     703                else if(MAXuflag == 2){ //circular cut off 
     704                        double uampl = sqrt(uab(0)*uab(0)+uab(1)*uab(1)); 
     705                        double uangl = atan2(uab(1), uab(0)); 
     706                        if (uampl > MAXu) uampl = MAXu; 
     707                        uab(0) = uampl*cos(uangl); 
     708                        uab(1) = uampl*sin(uangl); 
     709                } 
     710                //else{ //(MAXuflag == 0) //no cut off } 
     711                 
     712                u_old = uab; 
    670713                 
    671714                return uab; 
    672         }; 
     715        } 
     716         
    673717        void from_setting(const Setting &set){ 
    674718                PMSMCtrl::from_setting(set); 
    675719                UI::get(r,set, "r", UI::optional); 
    676720                UI::get(rec_hor,set, "h", UI::optional); 
     721                UI::get(MAXu,set, "MAXu", UI::optional); 
     722                UI::get(MAXuflag,set, "MAXuflag", UI::optional); 
     723                UI::get(rpd,set, "rpd", UI::optional); 
    677724        } 
    678725 
    679726        void validate(){ 
    680                 R(0,0)=R(1,1)=r; 
    681  
     727                R(0, 0) = R(1, 1) = r; 
     728                Rpd(0, 0) = Rpd(1, 1) = rpd;             
     729                Rpd(0, 2) = Rpd(1, 3) = -rpd;            
     730                 
    682731                p_isd.set_length(rec_hor+1); 
    683732                p_isq.set_length(rec_hor+1); 
     
    685734                p_the.set_length(rec_hor+1); 
    686735 
    687                 Array<quadraticfn> qloss(2); 
     736                Array<quadraticfn> qloss(3); 
    688737                qloss(0).Q.setCh(Q); 
    689                 qloss(0).rv = RV("x", 5, 1); 
     738                qloss(0).rv = RV("x", 5, 1);             
    690739                qloss(1).Q.setCh(R); 
    691                 qloss(1).rv = RV("u", 2, 0);             
     740                qloss(1).rv = RV("u", 2, 0); 
     741                qloss(2).Q.setCh(Rpd); 
     742                qloss(2).rv = RV("u", 2, 0); 
     743                qloss(2).rv.add(RV("u", 2, -1));                 
    692744                lq.Losses = qloss;               
    693745 
    694                                 //set lq 
    695                 lq.rv = RV("u", 2, 0);                   
    696                 lq.set_rvc(RV("x", 5, 0)); 
     746                //set lq 
     747                lq.rv = RV("u", 2, 0);           
     748                RV tmp = RV("x", 5, 0); 
     749                tmp.add(RV("u", 2, -1));         
     750                lq.set_rvc(tmp); 
     751                 
    697752                lq.horizon = rec_hor;    
    698753                 
     
    710765                lq.finalLoss.Q.setCh(Q); 
    711766                lq.finalLoss.rv = RV("x", 5, 1); 
    712                  
     767                                 
    713768                lq.validate(); 
    714769                                                 
    715770                uab.zeros(); 
    716                 udq.zeros(); 
    717  
     771                udq.zeros();             
    718772        } 
    719773};