[BACK]Return to H.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2018 / engine

Diff for /OpenXM_contrib2/asir2018/engine/H.c between version 1.1 and 1.3

version 1.1, 2018/09/19 05:45:07 version 1.3, 2020/10/06 06:31:19
Line 45 
Line 45 
  * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,   * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
  * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.   * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
  *   *
  * $OpenXM$   * $OpenXM: OpenXM_contrib2/asir2018/engine/H.c,v 1.2 2018/09/28 08:20:28 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "inline.h"  #include "inline.h"
Line 474  void hsq(int index,int count,P f,int *nindex,DCP *dcp)
Line 474  void hsq(int index,int count,P f,int *nindex,DCP *dcp)
   register int **pp,**fpp;    register int **pp,**fpp;
   register int *px,*py;    register int *px,*py;
   int **wpp;    int **wpp;
   int n,dr,tmp,m,b,e,np,dt;    int n,dr,m,b,e,np,dt;
     unsigned int tmp;
   LUM fpa,wb0,wb1,lcpa,tpa,tlum;    LUM fpa,wb0,wb1,lcpa,tpa,tlum;
   struct oDUM *dct;    struct oDUM *dct;
   UM wt,wq0,wq,wr,wm,wm0,wa,ws,wb;    UM wt,wq0,wq,wr,wm,wm0,wa,ws,wb;
Line 969  void ptolum(int q,int bound,P f,LUM fl)
Line 970  void ptolum(int q,int bound,P f,LUM fl)
   for ( dc = DC(f), pp = COEF(fl); dc; dc = NEXT(dc) ) {    for ( dc = DC(f), pp = COEF(fl); dc; dc = NEXT(dc) ) {
     absz((Z)COEF(dc),&z);      absz((Z)COEF(dc),&z);
     d = ztonadic(q,z,&w);      d = ztonadic(q,z,&w);
     c = pp[QTOS(DEG(dc))];      c = pp[ZTOS(DEG(dc))];
     for ( i = 0; i < d; i++ ) c[i] = w[i];      for ( i = 0; i < d; i++ ) c[i] = w[i];
     for ( ; i < bound; i++ ) c[i] = 0;      for ( ; i < bound; i++ ) c[i] = 0;
     if ( sgnz((Z)COEF(dc)) < 0 )      if ( sgnz((Z)COEF(dc)) < 0 )
Line 1006  void modfctrp(P p,int mod,int flag,DCP *dcp)
Line 1007  void modfctrp(P p,int mod,int flag,DCP *dcp)
   if ( (n = DEG(mp)) < 0 ) {    if ( (n = DEG(mp)) < 0 ) {
     *dcp = 0; return;      *dcp = 0; return;
   } else if ( n == 0 ) {    } else if ( n == 0 ) {
     cm = dmar(cm,COEF(mp)[0],0,mod); STOQ(cm,q);      cm = dmar(cm,COEF(mp)[0],0,mod); STOZ(cm,q);
     NEWDC(dc); COEF(dc) = (P)q; DEG(dc) = ONE;      NEWDC(dc); COEF(dc) = (P)q; DEG(dc) = ONE;
     NEXT(dc) = 0; *dcp = dc;      NEXT(dc) = 0; *dcp = dc;
     return;      return;
Line 1068  void modfctrp(P p,int mod,int flag,DCP *dcp)
Line 1069  void modfctrp(P p,int mod,int flag,DCP *dcp)
         }          }
       udc = udc1; break;        udc = udc1; break;
   }    }
   NEWDC(dc0); STOQ(cm,q); COEF(dc0) = (P)q; DEG(dc0) = ONE; dc = dc0;    NEWDC(dc0); STOZ(cm,q); COEF(dc0) = (P)q; DEG(dc0) = ONE; dc = dc0;
   for ( n = 0; udc[n].f; n++ ) {    for ( n = 0; udc[n].f; n++ ) {
     NEWDC(NEXT(dc)); dc = NEXT(dc);      NEWDC(NEXT(dc)); dc = NEXT(dc);
     STOQ(udc[n].n,DEG(dc)); umtop(VR(p),udc[n].f,&COEF(dc));      STOZ(udc[n].n,DEG(dc)); umtop(VR(p),udc[n].f,&COEF(dc));
   }    }
   NEXT(dc) = 0; *dcp = dc0;    NEXT(dc) = 0; *dcp = dc0;
 }  }
Line 1320  void canzas(int mod,UM f,int d,UM *base,UM *r)
Line 1321  void canzas(int mod,UM f,int d,UM *base,UM *r)
     s = W_UMALLOC(DEG(f)); u = W_UMALLOC(DEG(f));      s = W_UMALLOC(DEG(f)); u = W_UMALLOC(DEG(f));
     w = W_UMALLOC(DEG(f)); g = W_UMALLOC(DEG(f));      w = W_UMALLOC(DEG(f)); g = W_UMALLOC(DEG(f));
     o = W_UMALLOC(0); DEG(o) = 0; COEF(o)[0] = 1;      o = W_UMALLOC(0); DEG(o) = 0; COEF(o)[0] = 1;
     STOQ(mod,n1); STOQ(d,z); pwrz(n1,z,&n2); subz(n2,ONE,&n3);      STOZ(mod,n1); STOZ(d,z); pwrz(n1,z,&n2); subz(n2,ONE,&n3);
     STOQ(2,n4); divz(n3,n4,&n5);      STOZ(2,n4); divz(n3,n4,&n5);
     while ( 1 ) {      while ( 1 ) {
       randum(mod,2*d,t); spwrum0(mod,f,t,n5,s);        randum(mod,2*d,t); spwrum0(mod,f,t,n5,s);
       subum(mod,s,o,u); cpyum(f,w); Gcdum(mod,w,u,g);        subum(mod,s,o,u); cpyum(f,w); Gcdum(mod,w,u,g);
Line 1381  void spwrum0(int mod,UM m,UM f,Z e,UM r)
Line 1382  void spwrum0(int mod,UM m,UM f,Z e,UM r)
   } else if ( UNIZ(e) )    } else if ( UNIZ(e) )
     cpyum(f,r);      cpyum(f,r);
   else {    else {
     STOQ(2,two);      STOZ(2,two);
     divqrz(e,two,&e1,&rem);      divqrz(e,two,&e1,&rem);
     t = W_UMALLOC(2*DEG(m)); spwrum0(mod,m,f,e1,t);      t = W_UMALLOC(2*DEG(m)); spwrum0(mod,m,f,e1,t);
     s = W_UMALLOC(2*DEG(m)); q = W_UMALLOC(2*DEG(m));      s = W_UMALLOC(2*DEG(m)); q = W_UMALLOC(2*DEG(m));

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.3

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>