Show
Ignore:
Timestamp:
10/26/10 14:28:53 (14 years ago)
Author:
smidl
Message:

fix shifts in thorton fast

Files:
1 modified

Legend:

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

    r1231 r1233  
    4242            tmp_sum=tmp_sum>>15; 
    4343            if (tmp_sum>32767) { 
    44                 //tmp_sum=32767; 
     44                                printf("Au - saturated\n"); 
    4545            } 
    4646            if (tmp_sum<-32768) { 
    47                 //tmp_sum=-32768; 
     47                                printf("Au - saturated\n"); 
    4848            } 
    4949//                      printf("Au - saturated\n"); 
     
    155155            sigma =0; 
    156156            for (k=0;k<rows;k++) { 
     157                                int tmp= (((long(PSIU[i*rows+k])*Dold[k]))>>(2*qAU-15)); 
     158                                if (tmp>32767) printf("!"); 
    157159                                sigma += (((long(PSIU[i*rows+k])*Dold[k]))>>(2*qAU-15))*PSIU[j*rows+k]; 
    158160            } 
     
    265267        sigma = 0; 
    266268        for (k=0, PSIU_ik=PSIU+irows,Dold_k=Dold; 
    267                 k<rows; k++, PSIU_ik++,Dold_k++) {//Dold_i= 
    268                 sigma += (((long)(*PSIU_ik)**Dold_k)>>(2*qAU-15))*(*PSIU_ik); 
     269                k<rows; k++, PSIU_ik++,Dold_k++) { 
     270                sigma += (((long)(*PSIU_ik)**Dold_k)>>(qAU))*(*PSIU_ik)<<(15-qAU); 
    269271        } 
    270272        sigma += *(Q+i+irows)<<15; 
     
    286288                    k<rows; k++, PSIU_ik++, PSIU_jk++, Dold_k++) { 
    287289 
    288                                 sigma += ((((long)*PSIU_ik)**Dold_k)>>(2*qAU-15))**PSIU_jk; 
    289             } 
    290  
    291             for (k=i,G_ik=G+irows+i,G_jk=G+jrows+i,Q_kk=Q+k*rows+k; 
     290                                sigma += (((long(*PSIU_ik)**Dold_k)>>qAU)**PSIU_jk)<<(15-qAU); 
     291            } 
     292 
     293            for (k=i+1,G_ik=G+irows+i,G_jk=G+jrows+i,Q_kk=Q+k*rows+k; 
    292294                    k<rows;k++,G_ik++,G_jk++,Q_kk+=rows+1) { 
    293295                sigma += ((((long)*G_ik)**G_jk)>>13)**Q_kk; 
     
    338340        for (j=0;j<dimx;j++) { 
    339341            beta   = alpha; 
    340             lambda = -(((long)a[j])<<15)/beta; 
    341             alpha  += (((long)(a[j])*b[j])>>15); 
    342             D[j] = (((((long)beta)<<15)/alpha)*D[j])>>15; //gamma is long 
     342            lambda = -(long(a[j])<<15)/beta; 
     343            alpha  += ((long(a[j])*b[j])>>15); 
     344            D[j] = (((long(beta)<<15)/alpha)*D[j])>>15; //gamma is long 
    343345            if (D[j]==0) D[j]=1; 
    344346 
     
    350352            } 
    351353        } 
    352         int dzs = (((long)difz[iy])<<15)/alpha;  // apply scaling to innovations 
     354        int dzs = (long(difz[iy])<<15)/alpha;  // apply scaling to innovations 
    353355        // no shift due to gamma 
    354356        for (i=0; i<dimx; i++) { 
    355             xp[i]  += ((long)dzs*b[i])>>15; // multiply by unscaled Kalman gain 
     357            xp[i]  += (long(dzs*b[i]))>>15; // multiply by unscaled Kalman gain 
    356358        } 
    357359