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

Diff for /OpenXM_contrib2/asir2018/engine/nd.c between version 1.36 and 1.38

version 1.36, 2020/09/27 04:35:04 version 1.38, 2020/10/26 02:41:05
Line 1 
Line 1 
 /* $OpenXM: OpenXM_contrib2/asir2018/engine/nd.c,v 1.35 2020/08/26 06:40:36 noro Exp $ */  /* $OpenXM: OpenXM_contrib2/asir2018/engine/nd.c,v 1.37 2020/10/06 06:31:19 noro Exp $ */
   
 #include "nd.h"  #include "nd.h"
   
Line 66  static int *nd_poly_weight,*nd_module_weight;
Line 66  static int *nd_poly_weight,*nd_module_weight;
 static NODE nd_tracelist;  static NODE nd_tracelist;
 static NODE nd_alltracelist;  static NODE nd_alltracelist;
 static int nd_gentrace,nd_gensyz,nd_nora,nd_newelim,nd_intersect,nd_lf;  static int nd_gentrace,nd_gensyz,nd_nora,nd_newelim,nd_intersect,nd_lf;
   static int nd_f4_td,nd_sba_f4step,nd_sba_pot,nd_sba_largelcm;
 static int *nd_gbblock;  static int *nd_gbblock;
 static NODE nd_nzlist,nd_check_splist;  static NODE nd_nzlist,nd_check_splist;
 static int nd_splist;  static int nd_splist;
Line 1256  INLINE int ndl_find_reducer_s(UINT *dg,SIG sig)
Line 1257  INLINE int ndl_find_reducer_s(UINT *dg,SIG sig)
       quo->pos = nd_psh[i]->sig->pos;        quo->pos = nd_psh[i]->sig->pos;
       ret = comp_sig(sig,quo);        ret = comp_sig(sig,quo);
       if ( ret > 0 ) { singular = 0; break; }        if ( ret > 0 ) { singular = 0; break; }
       if ( ret == 0 ) { fprintf(asir_out,"s"); fflush(asir_out); singular = 1; }        if ( ret == 0 ) { /* fprintf(asir_out,"s"); fflush(asir_out); */ singular = 1; }
     }      }
   }    }
   if ( singular ) return -1;    if ( singular ) return -1;
Line 2561  int small_lcm(ND_pairs l)
Line 2562  int small_lcm(ND_pairs l)
   static DL lcm,mul,quo;    static DL lcm,mul,quo;
   static int nvar;    static int nvar;
   
     if ( nd_sba_largelcm ) return 0;
   if ( nvar < nd_nvar ) {    if ( nvar < nd_nvar ) {
     nvar = nd_nvar; NEWDL(lcm,nvar); NEWDL(quo,nvar); NEWDL(mul,nvar);      nvar = nd_nvar; NEWDL(lcm,nvar); NEWDL(quo,nvar); NEWDL(mul,nvar);
   }    }
Line 3203  ND_pairs nd_newpairs( NODE g, int t )
Line 3205  ND_pairs nd_newpairs( NODE g, int t )
   
 int comp_sig(SIG s1,SIG s2)  int comp_sig(SIG s1,SIG s2)
 {  {
 #if 0    if ( nd_sba_pot ) {
   if ( s1->pos > s2->pos ) return 1;      if ( s1->pos > s2->pos ) return 1;
   else if ( s1->pos < s2->pos ) return -1;      else if ( s1->pos < s2->pos ) return -1;
   else return (*cmpdl)(nd_nvar,s1->dl,s2->dl);      else return (*cmpdl)(nd_nvar,s1->dl,s2->dl);
 #else    } else {
   static DL m1,m2;      static DL m1,m2;
   static int nvar;      static int nvar;
   int ret;      int ret;
   
   if ( nvar != nd_nvar ) {      if ( nvar != nd_nvar ) {
     nvar = nd_nvar; NEWDL(m1,nvar); NEWDL(m2,nvar);        nvar = nd_nvar; NEWDL(m1,nvar); NEWDL(m2,nvar);
       }
       _adddl(nd_nvar,s1->dl,nd_sba_hm[s1->pos],m1);
       _adddl(nd_nvar,s2->dl,nd_sba_hm[s2->pos],m2);
       ret = (*cmpdl)(nd_nvar,m1,m2);
       if ( ret != 0 ) return ret;
       else if ( s1->pos > s2->pos ) return 1;
       else if ( s1->pos < s2->pos ) return -1;
       else return 0;
   }    }
 #if 0  
   _copydl(nd_nvar,nd_sba_hm[s1->pos],m1);  
   _copydl(nd_nvar,nd_sba_hm[s2->pos],m2);  
   _addtodl(nd_nvar,s1->dl,m1);  
   _addtodl(nd_nvar,s2->dl,m2);  
 #else  
   _adddl(nd_nvar,s1->dl,nd_sba_hm[s1->pos],m1);  
   _adddl(nd_nvar,s2->dl,nd_sba_hm[s2->pos],m2);  
 #endif  
   ret = (*cmpdl)(nd_nvar,m1,m2);  
   if ( ret != 0 ) return ret;  
   else if ( s1->pos > s2->pos ) return 1;  
   else if ( s1->pos < s2->pos ) return -1;  
   else return 0;  
 #endif  
 }  }
   
 int _create_spair_s(int i1,int i2,ND_pairs sp,SIG sig1,SIG sig2)  int _create_spair_s(int i1,int i2,ND_pairs sp,SIG sig1,SIG sig2)
Line 7999  NODE nd_f4(int m,int checkonly,int **indp)
Line 7994  NODE nd_f4(int m,int checkonly,int **indp)
         if ( nflist ) nd_last_nonzero = f4red;          if ( nflist ) nd_last_nonzero = f4red;
         for ( r = nflist; r; r = NEXT(r) ) {          for ( r = nflist; r; r = NEXT(r) ) {
             nf = (NDV)BDY(r);              nf = (NDV)BDY(r);
               if ( nd_f4_td ) SG(nf) = nd_tdeg(nf);
             ndv_removecont(m,nf);              ndv_removecont(m,nf);
             if ( !m && nd_nalg ) {              if ( !m && nd_nalg ) {
                 ND nf1;                  ND nf1;
Line 9568  NODE conv_ilist_s(int demand,int trace,int **indp)
Line 9564  NODE conv_ilist_s(int demand,int trace,int **indp)
   
 void parse_nd_option(NODE opt)  void parse_nd_option(NODE opt)
 {  {
     NODE t,p,u;    NODE t,p,u;
   int i,s,n;    int i,s,n;
     char *key;    char *key;
     Obj value;    Obj value;
   
     nd_gentrace = 0; nd_gensyz = 0; nd_nora = 0; nd_gbblock = 0;    nd_gentrace = 0; nd_gensyz = 0; nd_nora = 0; nd_gbblock = 0;
   nd_newelim = 0; nd_intersect = 0; nd_nzlist = 0;    nd_newelim = 0; nd_intersect = 0; nd_nzlist = 0;
   nd_splist = 0; nd_check_splist = 0;    nd_splist = 0; nd_check_splist = 0;
     nd_sugarweight = 0;    nd_sugarweight = 0; nd_f4red =0; nd_rank0 = 0;
     nd_f4red =0;    nd_f4_td = 0; nd_sba_f4step = 2; nd_sba_pot = 0; nd_sba_largelcm = 0;
     nd_rank0 = 0;    for ( t = opt; t; t = NEXT(t) ) {
     for ( t = opt; t; t = NEXT(t) ) {      p = BDY((LIST)BDY(t));
         p = BDY((LIST)BDY(t));      key = BDY((STRING)BDY(p));
         key = BDY((STRING)BDY(p));      value = (Obj)BDY(NEXT(p));
         value = (Obj)BDY(NEXT(p));      if ( !strcmp(key,"gentrace") )
         if ( !strcmp(key,"gentrace") )        nd_gentrace = value?1:0;
             nd_gentrace = value?1:0;      else if ( !strcmp(key,"gensyz") )
         else if ( !strcmp(key,"gensyz") )        nd_gensyz = value?1:0;
             nd_gensyz = value?1:0;      else if ( !strcmp(key,"nora") )
         else if ( !strcmp(key,"nora") )        nd_nora = value?1:0;
             nd_nora = value?1:0;      else if ( !strcmp(key,"gbblock") ) {
         else if ( !strcmp(key,"gbblock") ) {        if ( value && OID(value) == O_LIST ) {
             if ( value && OID(value) == O_LIST ) {  
         u = BDY((LIST)value);          u = BDY((LIST)value);
               nd_gbblock = MALLOC((2*length(u)+1)*sizeof(int));          nd_gbblock = MALLOC((2*length(u)+1)*sizeof(int));
         for ( i = 0; u; u = NEXT(u) ) {          for ( i = 0; u; u = NEXT(u) ) {
           p = BDY((LIST)BDY(u));            p = BDY((LIST)BDY(u));
           s = nd_gbblock[i++] = ZTOS((Q)BDY(p));            s = nd_gbblock[i++] = ZTOS((Q)BDY(p));
           nd_gbblock[i++] = s+ZTOS((Q)BDY(NEXT(p)))-1;            nd_gbblock[i++] = s+ZTOS((Q)BDY(NEXT(p)))-1;
         }          }
         nd_gbblock[i] = -1;          nd_gbblock[i] = -1;
             } else        } else
               nd_gbblock = 0;          nd_gbblock = 0;
     } else if ( !strcmp(key,"newelim") )      } else if ( !strcmp(key,"newelim") )
             nd_newelim = value?1:0;              nd_newelim = value?1:0;
     else if ( !strcmp(key,"intersect") )      else if ( !strcmp(key,"intersect") )
Line 9610  void parse_nd_option(NODE opt)
Line 9605  void parse_nd_option(NODE opt)
     else if ( !strcmp(key,"lf") )      else if ( !strcmp(key,"lf") )
             nd_lf = value?1:0;              nd_lf = value?1:0;
     else if ( !strcmp(key,"trace") ) {      else if ( !strcmp(key,"trace") ) {
            if ( value ) {        if ( value ) {
                u = BDY((LIST)value);          u = BDY((LIST)value);
            nd_nzlist = BDY((LIST)ARG2(u));          nd_nzlist = BDY((LIST)ARG2(u));
            nd_bpe = ZTOS((Q)ARG3(u));          nd_bpe = ZTOS((Q)ARG3(u));
            }        }
     } else if ( !strcmp(key,"f4red") ) {      } else if ( !strcmp(key,"f4red") ) {
        nd_f4red = ZTOS((Q)value);        nd_f4red = ZTOS((Q)value);
     } else if ( !strcmp(key,"rank0") ) {      } else if ( !strcmp(key,"rank0") ) {
             nd_rank0 = value?1:0;        nd_rank0 = value?1:0;
     } else if ( !strcmp(key,"splist") ) {      } else if ( !strcmp(key,"splist") ) {
             nd_splist = value?1:0;        nd_splist = value?1:0;
     } else if ( !strcmp(key,"check_splist") ) {      } else if ( !strcmp(key,"check_splist") ) {
       nd_check_splist = BDY((LIST)value);        nd_check_splist = BDY((LIST)value);
     } else if ( !strcmp(key,"sugarweight") ) {      } else if ( !strcmp(key,"sugarweight") ) {
       u = BDY((LIST)value);        u = BDY((LIST)value);
             n = length(u);        n = length(u);
             nd_sugarweight = MALLOC(n*sizeof(int));        nd_sugarweight = MALLOC(n*sizeof(int));
       for ( i = 0; i < n; i++, u = NEXT(u) )        for ( i = 0; i < n; i++, u = NEXT(u) )
                 nd_sugarweight[i] = ZTOS((Q)BDY(u));          nd_sugarweight[i] = ZTOS((Q)BDY(u));
       } else if ( !strcmp(key,"f4_td") ) {
         nd_f4_td = value?1:0;
       } else if ( !strcmp(key,"sba_f4step") ) {
         nd_sba_f4step = value?ZTOS((Q)value):0;
       } else if ( !strcmp(key,"sba_pot") ) {
         nd_sba_pot = value?1:0;
       } else if ( !strcmp(key,"sba_largelcm") ) {
         nd_sba_largelcm = value?1:0;
     }      }
     }    }
 }  }
   
 ND mdptond(DP d);  ND mdptond(DP d);
Line 10910  NODE nd_sba_f4(int m,int **indp)
Line 10913  NODE nd_sba_f4(int m,int **indp)
   while ( d ) {    while ( d ) {
     for ( t = d, ms = SG(d); t; t = NEXT(t) )      for ( t = d, ms = SG(d); t; t = NEXT(t) )
       if ( SG(t) < ms ) ms = SG(t);        if ( SG(t) < ms ) ms = SG(t);
     if ( ms == psugar && f4step >= 2 ) {      if ( ms == psugar && f4step >= nd_sba_f4step ) {
 again:  again:
       l = d; d = d->next;        l = d; d = d->next;
       if ( small_lcm(l) ) {        if ( small_lcm(l) ) {
Line 10977  again2:
Line 10980  again2:
       if ( bucket->m < 0 ) continue;        if ( bucket->m < 0 ) continue;
       col = nd_symbolic_preproc_s(bucket,0,&s0vect,&rp0);        col = nd_symbolic_preproc_s(bucket,0,&s0vect,&rp0);
       if ( !col ) {        if ( !col ) {
         for ( t = l; NEXT(t); t = NEXT(t) );          for ( t = l; NEXT(t); t = NEXT(t) )
           NEXT(t) = d; d = l;            ;
           NEXT(t) = d; d = l;
         d = nd_reconstruct(0,d);          d = nd_reconstruct(0,d);
         goto again2;          goto again2;
       }        }
Line 10987  again2:
Line 10991  again2:
       /* adding new bases */        /* adding new bases */
       for ( r = nflist; r; r = NEXT(r) ) {        for ( r = nflist; r; r = NEXT(r) ) {
         nfv = (NDV)BDY(r);          nfv = (NDV)BDY(r);
           if ( nd_f4_td ) SG(nfv) = nd_tdeg(nfv);
         ndv_removecont(m,nfv);          ndv_removecont(m,nfv);
         nh = ndv_newps(m,nfv,0);          nh = ndv_newps(m,nfv,0);
         d = update_pairs_s(d,nh,syzlist);          d = update_pairs_s(d,nh,syzlist);

Legend:
Removed from v.1.36  
changed lines
  Added in v.1.38

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