Show
Ignore:
Timestamp:
03/14/11 09:32:33 (14 years ago)
Author:
smidl
Message:

zmeny v experimentech

Location:
applications/pmsm/simulator_zdenek/ekf_example
Files:
4 modified

Legend:

Unmodified
Added
Removed
  • applications/pmsm/simulator_zdenek/ekf_example/ekf_obj.cpp

    r1245 r1294  
    505505{ 
    506506        // Tuning of matrix Q 
    507         Q[0]=prevod(.01,15);       // 0.05 
     507        Q[0]=prevod(.001,15);       // 0.05 
    508508        Q[5]=Q[0]; 
    509509        Q[10]=prevod(0.0005,15);      // 1e-3 
    510         Q[15]=prevod(0.001,15);      // 1e-3 
     510        Q[15]=prevod(0.0001,15);      // 1e-3 
    511511 
    512512        Uf[0]=0x7FFF;// !       // 0.05 
     
    603603        mmultACh(PSI,Chf,PSICh,4,4); 
    604604        //thorton(int16 *U, int16 *D, int16 *PSIU, int16 *Q, int16 *G, int16 *Dold, unsigned int16 dimx); 
    605         householder(PSICh,Q,4); 
    606         //givens(PSICh,Q,4); 
     605        //householder(PSICh,Q,4); 
     606        givens_fast(PSICh,Q,4); 
    607607        // COPY  
    608608        for (int16 ii=0; ii<16; ii++){Chf[ii]=PSICh[ii];} 
     
    629629        //int16 xb[4]; xb[0]=x_est[0]<<2; xb[1]=x_est[1]<<2;  xb[2]=x_est[2]<<2;  xb[3]=x_est[3];   
    630630 
    631         carlson(difz,x_est,Chf,dR,2,4); 
     631        carlson_fast(difz,x_est,Chf,dR,2,4); 
    632632        //x_est[0] = xb[0]>>2; x_est[1]=xb[1]>>2; x_est[2]=xb[2]>>2; x_est[3]=xb[3]; 
    633633         
     
    649649        Q[0]=prevod(.01,15);       // 0.05 
    650650        Q[5]=Q[0]; 
    651         Q[10]=prevod(0.01,15);      // 1e-3 
    652         Q[15]=prevod(0.01,15);      // 1e-3 
     651        Q[10]=prevod(0.0005,15);      // 1e-3 
     652        Q[15]=prevod(0.001,15);      // 1e-3 
    653653         
    654654        Chf[0]=0x3FFF;// !       // 0.05 
     
    661661                 
    662662        // Tuning of matrix R 
    663         R[0]=prevod(0.1,15);         // 0.05 
     663        R[0]=prevod(0.05,15);         // 0.05 
    664664        R[3]=R[0]; 
    665665         
  • applications/pmsm/simulator_zdenek/ekf_example/ekf_obj.h

    r1264 r1294  
    106106 
    107107//! EKF for testing q44 
    108 class EKFtest: public EKFfull{ 
     108class EKFtest: public EKF_UD{ 
    109109        void bayes ( const vec &yt, const vec &cond ) { 
    110                 EKFfull::bayes(yt,cond); 
    111                 mat &P = est._R(); 
    112                 if (P(3,3)>3.14)  
    113                         P(3,3)=3.14;             
     110                EKF_UD::bayes(yt,cond); 
     111                vec D =  prior()._R()._D(); 
     112                 
     113                if (D(3)>10) D(3) = 10; 
     114                 
     115                prior()._R().__D()=D; 
    114116        } 
    115117}; 
  • applications/pmsm/simulator_zdenek/ekf_example/matrix_vs.cpp

    r1245 r1294  
    221221    if (x>6554) { 
    222222        int16 xm05=x-16384; 
    223         tmp = ((long)k1*xm05)>>15; 
    224         tmp-=(((long(k2)*xm05)>>15)*xm05)>>15; 
     223        tmp = ((int32)k1*xm05)>>15; 
     224        tmp-=(((int32(k2)*xm05)>>15)*xm05)>>15; 
    225225        tmp +=k1; 
    226226    } else { 
    227227        tmp = 4*x; 
    228         tmp-=long(8*x)*x>>15; 
     228        tmp-=int32(8*x)*x>>15; 
    229229    } 
    230230    return tmp; 
     
    251251        for (j=0;j<dimx;j++) 
    252252        { 
    253             sigma+=((long)B[k*dimx+j]*B[k*dimx+j]); 
     253            sigma+=((int32)B[k*dimx+j]*B[k*dimx+j]); 
    254254        } 
    255255        for (j=0;j<=k;j++) 
    256256        { 
    257             sigma+=((long)Ch[k*dimx+j]*Ch[k*dimx+j]); 
     257            sigma+=((int32)Ch[k*dimx+j]*Ch[k*dimx+j]); 
    258258        } 
    259259         
    260260        //alpha in qCh 
    261         alpha = (int)(sqrt((double)sigma)+0.5);   // predelat pro DSP 
     261        alpha = (int16)(sqrt((double)sigma)+0.5);   // predelat pro DSP 
    262262 
    263263                sigma=0; 
    264264        for (j=0;j<dimx;j++) { 
    265265            w[j]=B[k*dimx+j]; 
    266             sigma+=(long)w[j]*w[j]; 
     266            sigma+=(int32)w[j]*w[j]; 
    267267        } 
    268268        for (j=0; j<=k;j++) { 
     
    272272                v[j]=Ch[k*dimx+j]; 
    273273            } 
    274             sigma+=(long)v[j]*v[j]; 
     274            sigma+=(int32)v[j]*v[j]; 
    275275        } 
    276276         
     
    281281            sigma=0; 
    282282            for (j=0;j<dimx;j++) { 
    283                 sigma+=((long)B[i*dimx+j]*w[j]); 
     283                sigma+=((int32)B[i*dimx+j]*w[j]); 
    284284            } 
    285285            for (j=0;j<=k;j++) { 
    286                 sigma+=(long)Ch[i*dimx+j]*v[j]; 
     286                sigma+=(int32)Ch[i*dimx+j]*v[j]; 
    287287            } 
    288288 
     
    338338            sigma=Ch[iy*dimx+j]; 
    339339            beta=alpha; 
    340             alpha+=((long)sigma*sigma)>>15; 
     340            alpha+=((int32)sigma*sigma)>>15; 
    341341//                      double ab=(double)alpha*beta/32768./32768.; 
    342342//                      double s_ab=sqrt(ab); 
    343             gamma=(int)(sqrt((double)((long)alpha*beta))+0.5);            // predelat v DSP 
     343            gamma=(int16)(sqrt((double)((int32)alpha*beta))+0.5);            // predelat v DSP 
    344344            //gamma = round(s_ab*(1<<15)); 
    345345//            eta=((long)beta<<15) / gamma; 
     
    348348            for (i=0;i<=j;i++) { 
    349349                tau=Ch[i*dimx+j]; 
    350                                 tmp_long=((long)beta*Ch[i*dimx+j] -(long)sigma*w[i])/gamma; 
     350                                tmp_long=((int32)beta*Ch[i*dimx+j] -(int32)sigma*w[i])/gamma; 
    351351                                if (tmp_long>32767) { 
    352352                                        Ch[i*dimx+j]=32767; 
     
    359359                                } 
    360360                                 
    361                 w[i]+=((long)tau*sigma)>>15; 
     361                w[i]+=((int32)tau*sigma)>>15; 
    362362            } 
    363363        } 
     
    365365        //epsilon=(long(difz)<<15) / (alpha); // q15*q13/q13 = q15 
    366366        for (i=0;i<dimx;i++) { 
    367             xp[i]+=((long)w[i]*delta)/alpha; 
     367            xp[i]+=((int32)w[i]*delta)/alpha; 
    368368        } 
    369369    } 
     
    385385        for (i=dimx-1; i>=0; i--){ 
    386386                for (j=0; j<dimx; j++) { 
    387                         tmp_long=(long)Ch[i*dimx+i]*Ch[i*dimx+i]+long(A[i*dimx+j])*A[i*dimx+j]; 
     387                        tmp_long=(int32)Ch[i*dimx+i]*Ch[i*dimx+i]+int32(A[i*dimx+j])*A[i*dimx+j]; 
    388388                        if (tmp_long>0){ 
    389389                                rho=sqrt(double(tmp_long)); 
    390                                 s=(long(A[i*dimx+j])<<15)/rho; 
    391                                 c=(long(Ch[i*dimx+i])<<15)/rho; 
     390                                s=(int32(A[i*dimx+j])<<15)/rho; 
     391                                c=(int32(Ch[i*dimx+i])<<15)/rho; 
    392392                                for (k=0;k<=i; k++){ 
    393                                         tau=(long(c)*A[k*dimx+j]-long(s)*Ch[k*dimx+i])>>15; 
    394                                         Ch[k*dimx +i]=(long(s)*A[k*dimx+j]+long(c)*Ch[k*dimx+i])>>15; 
     393                                        tau=(int32(c)*A[k*dimx+j]-int32(s)*Ch[k*dimx+i])>>15; 
     394                                        Ch[k*dimx +i]=(int32(s)*A[k*dimx+j]+int32(c)*Ch[k*dimx+i])>>15; 
    395395                                        A[k*dimx +j]=tau; 
    396396                                } 
     
    399399 
    400400                for (j=0; j<i; j++){ 
    401                         tmp_long=(long(Ch[i*dimx+i])*Ch[i*dimx+i]+long(Ch[i*dimx+j])*Ch[i*dimx+j]); 
     401                        tmp_long=(int32(Ch[i*dimx+i])*Ch[i*dimx+i]+int32(Ch[i*dimx+j])*Ch[i*dimx+j]); 
    402402                        if (tmp_long>0){ 
    403403                                rho=sqrt((double)(tmp_long)); 
    404                                 s=(long(Ch[i*dimx+j])<<15)/rho; 
    405                                 c=(long(Ch[i*dimx+i])<<15)/rho; 
     404                                s=(int32(Ch[i*dimx+j])<<15)/rho; 
     405                                c=(int32(Ch[i*dimx+i])<<15)/rho; 
    406406                                for (k=0; k<=i; k++){ 
    407                                         tau=(long(c)*Ch[k*dimx+j]-long(s)*Ch[k*dimx+i])>>15; 
    408                                         Ch[k*dimx+i]=(long(s)*Ch[k*dimx+j]+long(c)*Ch[k*dimx+i])>>15; 
     407                                        tau=(int32(c)*Ch[k*dimx+j]-int32(s)*Ch[k*dimx+i])>>15; 
     408                                        Ch[k*dimx+i]=(int32(s)*Ch[k*dimx+j]+int32(c)*Ch[k*dimx+i])>>15; 
    409409                                        Ch[k*dimx+j]=tau; 
    410410                                } 
     
    443443        } 
    444444} 
     445 
     446 
     447void givens_fast(int16 *Ch, int16 *Q, unsigned int16 dimx) 
     448{ 
     449        int16 i,j,k; 
     450        int16 rho,s,c,tau; 
     451        int32  tmp_long; 
     452         
     453        int16 A[25];//beware 
     454         
     455        int16 *A_ij, *Q_i, *Ch_ki, *Ch_kj, *Ch_ii, *Ch_ij, *A_kj; 
     456         
     457        A_ij=A; 
     458        Q_i=Q; 
     459        // copy Q to A 
     460        for (i=0;i<dimx*dimx;i++) 
     461        { 
     462                //              A[i]=Q[i]>>(15-qCh); 
     463                *A_ij++=(*Q_i++)>>(15-qCh); 
     464        } 
     465         
     466        for (i=dimx-1; i>=0; i--) 
     467        { 
     468                Ch_ii=Ch+i*dimx+i; 
     469                A_ij=A+i*dimx; 
     470                 
     471                for (j=0; j<dimx; j++)  
     472                { 
     473                        //                      tmp_long=(long)Ch[i*dimx+i]*Ch[i*dimx+i]+(long)A[i*dimx+j]*A[i*dimx+j]; 
     474                         
     475                        tmp_long=(int32)*Ch_ii**Ch_ii+(int32)*A_ij**A_ij; 
     476                         
     477                        if (tmp_long>0) 
     478                        { 
     479                                //                              rho=qsqrt(tmp_long);                   // verze pro DSP 
     480                                rho=(int16)(sqrt((double)tmp_long));     // verze pro PC 
     481                                s=((int32)*A_ij<<15)/rho; 
     482                                c=((int32)*Ch_ii<<15)/rho; 
     483                                 
     484                                Ch_ki=Ch+i; 
     485                                A_kj=A+j; 
     486                                 
     487                                for (k=0;k<=i; k++) 
     488                                { 
     489                                        tau=((int32)c**A_kj-(int32)s**Ch_ki)>>15; 
     490                                        *Ch_ki=((int32)s**A_kj+(int32)c**Ch_ki)>>15; 
     491                                        *A_kj=tau; 
     492                                         
     493                                        Ch_ki+=dimx; 
     494                                        A_kj+=dimx; 
     495                                } 
     496                        } 
     497                        A_ij++; 
     498                } 
     499                 
     500                Ch_ij = Ch+i*dimx; 
     501                 
     502                for (j=0; j<i; j++) 
     503                { 
     504                        tmp_long=(int32)*Ch_ii**Ch_ii+(int32)*Ch_ij**Ch_ij; 
     505                         
     506                        if (tmp_long>0) 
     507                        { 
     508                                //                      rho=qsqrt(tmp_long);                     // verze pro DSP 
     509                                rho=(int16)(sqrt((double)tmp_long));       // verze pro PC 
     510                                s=((int32)*Ch_ij<<15)/rho; 
     511                                c=((int32)*Ch_ii<<15)/rho; 
     512                                 
     513                                Ch_kj = Ch + j; 
     514                                Ch_ki = Ch + i; 
     515                                 
     516                                for (k=0; k<=i; k++) 
     517                                { 
     518                                        tau=((int32)c**Ch_kj-(int32)s**Ch_ki)>>15; 
     519                                        *Ch_ki =((int32)s**Ch_kj+(int32)c**Ch_ki)>>15; 
     520                                        *Ch_kj=tau; 
     521                                         
     522                                        Ch_kj += dimx; 
     523                                        Ch_ki += dimx; 
     524                                } 
     525                        } 
     526                        Ch_ij++; 
     527                } 
     528        } 
     529} 
     530 
     531void carlson_fast(int16 *difz, int16 *xp, int16 *Ch, int16 *R, unsigned int16 dimy, unsigned int16 dimx ) { 
     532        int16 alpha,beta,gamma; 
     533        int16 delta, eta,epsilon,zeta,sigma,tau; 
     534        int16 i,j,iy; 
     535        int16 w[5]; 
     536        int32 tmp_long; 
     537         
     538        int16 *Ch_ij, *w_i, *x_i; 
     539         
     540         
     541        for (iy=0; iy<dimy; iy++) 
     542        { 
     543                alpha=R[iy]; 
     544                delta = difz[iy]; 
     545                 
     546                for (j=0;j<dimx;j++) 
     547                { 
     548                        sigma=Ch[iy*dimx+j]; 
     549                        beta=alpha; 
     550                        //            alpha+=((long)sigma*sigma)>>15; 
     551                        alpha=(((int32)alpha<<15)+(int32)sigma*sigma)>>15;                              // vyssi presnost 
     552                        //            gamma= qsqrt(((long)alpha*beta));                          // verze pro DSP 
     553                        gamma= (int16)(sqrt((double)((int32)alpha*beta)));              // verze pro PC 
     554                         
     555                        w[j]=0; 
     556                         
     557                        Ch_ij=Ch+j; 
     558                        w_i=w; 
     559                         
     560                        for (i=0;i<=j;i++) 
     561                        { 
     562                                //                tau=Ch[i*dimx+j]; 
     563                                tau=*Ch_ij; 
     564                                //                              tmp_long=((long)beta*Ch[i*dimx+j] -(long)sigma*w[i])/gamma; 
     565                                tmp_long=((int32)beta**Ch_ij -(int32)sigma**w_i)/gamma; 
     566                                 
     567                                if (tmp_long>32767) 
     568                                        tmp_long=32767; 
     569                                if (tmp_long<-32768) 
     570                                        tmp_long=-32768; 
     571                                *Ch_ij=tmp_long; 
     572                                 
     573                                //                w_i+=((long)tau*sigma)>>15; 
     574                                *w_i=(((int32)*w_i<<15)+(int32)tau*sigma)>>15; 
     575                                 
     576                                w_i++; 
     577                                Ch_ij+=dimx; 
     578                        } 
     579                } 
     580                 
     581                x_i=xp; 
     582                w_i=w; 
     583                for (i=0;i<dimx;i++) { 
     584                        //            xp[i]+=((long)w[i]*delta)/alpha; 
     585                        //            *x_i+=((long)*w_i*delta)/alpha; 
     586                        *x_i=((int32)*x_i*alpha+(int32)*w_i*delta)/alpha;               // vyssi presnost 
     587                        x_i++; 
     588                        w_i++; 
     589                } 
     590        } 
     591} 
     592 
  • applications/pmsm/simulator_zdenek/ekf_example/matrix_vs.h

    r1245 r1294  
    1515#define qCh 14 
    1616 
    17 #define int16 int 
    18 #define int32 long 
     17#define int16 short 
     18#define int32 int 
    1919 
    2020/* Matrix multiply Full matrix by upper diagonal matrix with unit diagonal; */ 
     
    4444/* perform Carlson update of Ch matrix using difz, R and xp, for size dimx*/ 
    4545extern void carlson(int16 *difz, int16 *xp, int16 *Ch, int16 *R, unsigned int16 dimy, unsigned int16 dimx ); 
     46 
     47/* perform Givens update of Ch matrix using PSI*Ch , Q, */ 
     48extern void givens_fast(int16 *Ch /*= int16 *PSICh*/, int16 *Q, unsigned int16 dimx); 
     49 
     50/* perform Carlson update of Ch matrix using difz, R and xp, for size dimx*/ 
     51extern void carlson_fast(int16 *difz, int16 *xp, int16 *Ch, int16 *R, unsigned int16 dimy, unsigned int16 dimx );