Changeset 1237

Show
Ignore:
Timestamp:
10/29/10 16:17:33 (14 years ago)
Author:
peroutka
Message:
 
Files:
1 modified

Legend:

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

    r1235 r1237  
    196196    int *U_ij; 
    197197    int *x_i; 
     198    int dzs; 
     199 
    198200    a = U; // iyth row of U 
    199201    for (iy=0; iy<dimy; iy++, a+=dimx) { 
     
    220222            } 
    221223        } 
    222         int dzs = (((long)difz[iy])<<15)/alpha;  // apply scaling to innovations 
     224        dzs = (((long)difz[iy])<<15)/alpha;  // apply scaling to innovations 
    223225        // no shift due to gamma 
    224226        for (i=0,x_i=xp,b_i=b; i<dimx; i++,x_i++,b_i++) { 
     
    245247    int irows,jrows; 
    246248    long sigma; // in qAU+15!! 
     249    long z; 
    247250 
    248251    for (i=0,Dold_i=Dold,D_i=D;i<rows;i++,Dold_i++,D_i++) { 
     
    263266 
    264267    for (i=rows-1, Dold_i=Dold+i, D_i=D+i; 
    265             true; i--, Dold_i--,D_i--) { // stop if i==0 at the END! 
     268            1; i--, Dold_i--,D_i--) { // stop if i==0 at the END! 
    266269        irows=i*rows; 
    267270        sigma = 0; 
     
    274277            sigma += (((long)(*G_ik)**G_ik)>>16)**(Q+j+j*rows); 
    275278 
    276         }         
    277  
    278                 if (sigma>(1<<(qAU+15))) { 
     279        } 
     280 
     281                if (sigma>((long)1<<(qAU+15))) { 
    279282                        *D_i = 32767; 
    280                         *(Dold+i)-=*(Q+i+irows); 
     283//                      *(Dold+i)-=*(Q+i+irows); 
    281284                } else { 
    282285                        *D_i=sigma>>qAU; 
     
    291294                    k<rows; k++, PSIU_ik++, PSIU_jk++, Dold_k++) { 
    292295 
    293                                 sigma += (((long(*PSIU_ik)**PSIU_jk)>>qAU)**Dold_k); 
     296                                sigma += ((((long)(*PSIU_ik)**PSIU_jk)>>qAU)**Dold_k); 
    294297            } 
    295298 
     
    299302            } 
    300303 
    301             long z=(sigma/(*D_i))<<(15-qAU); // shift to q15 
     304            z=(sigma/(*D_i))<<(15-qAU); // shift to q15 
    302305            if (z>32767) z=32767; 
    303306            if (z<-32768) z=-32768; 
     
    372375        double xd(double(x)/32768.); 
    373376        return round(sqrt(xd)*32768); 
    374          
     377 
    375378    //sqrt(x) == 1/2*2^(1/2)+1/2*2^(1/2)*(x-1/2)-1/4*2^(1/2)*(x-1/2)^2 
    376379    //         = k1 + k1*(x-0.5) - k2*(x-0.5)(x-0.5); 
     
    393396void householder(int *Ch /*= int *PSICh*/, int *Q, unsigned int dimx) { 
    394397    int k,j,i; 
    395     int sigma,alpha,beta; 
     398    int alpha,beta; 
     399    long sigma; 
    396400    int B[25];//beware 
    397401    int w[5]; 
     
    399403 
    400404    // copy Q to B 
    401     for (i=0;i<dimx*dimx;i++) { 
     405    for (i=0;i<dimx*dimx;i++) 
     406    { 
    402407        B[i]=Q[i]; 
    403408    } 
    404409 
    405     for (k=dimx-1; k>=0; k--) { 
     410    for (k=dimx-1; k>=0; k--) 
     411    { 
    406412        sigma=0; 
    407         for (j=0;j<dimx;j++) { 
    408             sigma+=(long(B[k*dimx+j])*B[k*dimx+j])>>15; 
    409         } 
    410         for (j=0;j<=k;j++) { 
    411             sigma+=(long(Ch[k*dimx+j])*Ch[k*dimx+j])>>15; 
     413        for (j=0;j<dimx;j++) 
     414        { 
     415            sigma+=(long)B[k*dimx+j]*B[k*dimx+j]; 
     416        } 
     417        for (j=0;j<=k;j++) 
     418        { 
     419            sigma+=(long)Ch[k*dimx+j]*Ch[k*dimx+j]; 
    412420        } 
    413421        /*               double sigf=double(sigma)/(1<<15); 
    414422                         double alpf = sqrt(sigf);*/ 
    415                 if (sigma>16384) sigma=16384; 
    416         alpha=int_sqrt(sigma); 
     423//              if (sigma>16384) sigma=16384; 
     424//        alpha=int_sqrt(sigma); 
     425          alpha = (int)(sqrt((double)sigma)+0.5);   // predelat pro DSP 
    417426        // alpha = alpf*(1<<15); 
    418427        // 
     
    420429        for (j=0;j<dimx;j++) { 
    421430            w[j]=B[k*dimx+j]; 
    422             sigma+=(long(w[j])*w[j])>>15; 
     431            sigma+=(long)w[j])*w[j]; 
    423432        } 
    424433        for (j=0; j<=k;j++) { 
     
    428437                v[j]=Ch[k*dimx+j]; 
    429438            } 
    430             sigma+=(long(v[j])*v[j])>>15; 
    431         } 
    432         alpha=sigma>>1; 
    433                 if (alpha==0) alpha =1; 
     439            sigma+=(long)v[j]*v[j]; 
     440        } 
     441         
     442        alpha=sigma>>16; 
     443        if (alpha==0) alpha =1; 
     444 
    434445        for (i=0;i<=k;i++) { 
    435446            sigma=0; 
    436447            for (j=0;j<dimx;j++) { 
    437                 sigma+=(long(B[i*dimx+j])*w[j])>>15; 
     448                sigma+=(long)B[i*dimx+j]*w[j]; 
    438449            } 
    439450            for (j=0;j<=k;j++) { 
    440                 sigma+=(long(Ch[i*dimx+j])*v[j])>>15; 
    441             } 
    442             for (j=0;j<dimx;j++) { 
    443                 B[i*dimx+j]-=(long(sigma)*w[j]/alpha); 
     451                sigma+=(long)Ch[i*dimx+j]*v[j]; 
     452            } 
     453 
     454            sigma = sigma >> 15;               // navrat do Q15 
     455 
     456            for (j=0;j<dimx;j++)  
     457            { 
     458                B[i*dimx+j]-=(sigma*w[j])/alpha; 
    444459            }; 
    445             for (j=0;j<=k;j++) { 
    446                 Ch[i*dimx+j]-=(long(sigma)*v[j]/alpha); 
     460             
     461            for (j=0;j<=k;j++) 
     462            { 
     463                Ch[i*dimx+j]-=(sigma*v[j])/alpha; 
    447464            } 
    448465        } 
     
    457474    int w[5]; 
    458475 
    459     for (iy=0; iy<dimy; iy++) { 
     476    for (iy=0; iy<dimy; iy++) 
     477    { 
    460478        alpha=R[iy]; 
    461479        delta = difz[iy]; 
    462480 
    463         for (j=0;j<dimx;j++) { 
     481        for (j=0;j<dimx;j++) 
     482        { 
    464483            sigma=Ch[iy*dimx+j]; 
    465484            beta=alpha; 
    466             alpha+=(long(sigma)*sigma)>>15; 
     485            alpha+=((long)sigma*sigma)>>15; 
    467486//                      double ab=(double)alpha*beta/32768./32768.; 
    468487//                      double s_ab=sqrt(ab); 
    469             gamma=int_sqrt(((long)alpha*beta)>>15); 
     488            gamma=sqrt((double)((long)alpha*beta))+0.5;            // predelat v DSP 
    470489            //gamma = round(s_ab*(1<<15)); 
    471             eta=(long (beta)<<15) / gamma; 
     490//            eta=((long)beta<<15) / gamma; 
    472491            //zeta=(long(sigma)<<15)/ gamma; 
    473492            w[j]=0; 
    474493            for (i=0;i<=j;i++) { 
    475494                tau=Ch[i*dimx+j]; 
    476                 Ch[i*dimx+j]=((long(eta)*Ch[i*dimx+j])>>15) -(long(sigma)*w[i])/gamma; 
    477                 w[i]+=(long(tau)*sigma)>>15; 
     495                Ch[i*dimx+j]=((long)beta*Ch[i*dimx+j] -(long)sigma*w[i])/gamma; 
     496                w[i]+=((long)tau*sigma)>>15; 
    478497            } 
    479498        } 
     
    481500        //epsilon=(long(difz)<<15) / (alpha); // q15*q13/q13 = q15 
    482501        for (i=0;i<dimx;i++) { 
    483             xp[i]+=(long(w[i])*delta)/alpha; 
     502            xp[i]+=((long)w[i]*delta)/alpha; 
    484503        } 
    485504    } 
     
    490509        int i,j,k; 
    491510        int rho,s,c,tau; 
    492          
     511 
    493512        int A[25];//beware 
    494513        // copy Q to A 
     
    496515                A[i]=Q[i]; 
    497516        } 
    498          
    499          
     517 
     518 
    500519        for (i=dimx-1; i>=0; i--){ 
    501520                for (j=0; j<dimx; j++) {