[BACK]Return to dp-supp.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / builtin

Diff for /OpenXM_contrib2/asir2000/builtin/dp-supp.c between version 1.22 and 1.28

version 1.22, 2002/12/27 07:37:57 version 1.28, 2004/02/05 08:28:53
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_contrib2/asir2000/builtin/dp-supp.c,v 1.21 2002/01/28 00:54:41 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/dp-supp.c,v 1.27 2004/02/03 23:31:57 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "base.h"  #include "base.h"
Line 387  int have_sf_coef(P p)
Line 387  int have_sf_coef(P p)
         }          }
 }  }
   
   void head_coef(P p,Num *c)
   {
           if ( !p )
                   *c = 0;
           else if ( NUM(p) )
                   *c = (Num)p;
           else
                   head_coef(COEF(DC(p)),c);
   }
   
   void dp_monic_sf(DP p,DP *rp)
   {
           Num c;
   
           if ( !p )
                   *rp = 0;
           else {
                   head_coef(BDY(p)->c,&c);
                   divsdc(CO,p,(P)c,rp);
           }
   }
   
 void dp_prim(DP p,DP *rp)  void dp_prim(DP p,DP *rp)
 {  {
         P t,g;          P t,g;
Line 399  void dp_prim(DP p,DP *rp)
Line 421  void dp_prim(DP p,DP *rp)
   
         if ( !p )          if ( !p )
                 *rp = 0;                  *rp = 0;
         else if ( dp_fcoeffs ) {          else if ( dp_fcoeffs == N_GFS ) {
                 for ( m = BDY(p); m; m = NEXT(m) ) {                  for ( m = BDY(p); m; m = NEXT(m) )
                         if ( OID(m->c) == O_N ) {                          if ( OID(m->c) == O_N ) {
                                 /* GCD of coeffs = 1 */                                  /* GCD of coeffs = 1 */
                                 *rp = p;                                  dp_monic_sf(p,rp);
                                 return;                                  return;
                         } else if ( have_sf_coef(m->c) ) {                          } else break;
                                 /* compute GCD over the finite fieid */                  /* compute GCD over the finite fieid */
                                 for ( m = BDY(p), n = 0; m; m = NEXT(m), n++ );                  for ( m = BDY(p), n = 0; m; m = NEXT(m), n++ );
                                 w = (P *)ALLOCA(n*sizeof(P));                  w = (P *)ALLOCA(n*sizeof(P));
                                 for ( m = BDY(p), i = 0; i < n; m = NEXT(m), i++ )                  for ( m = BDY(p), i = 0; i < n; m = NEXT(m), i++ )
                                         w[i] = m->c;                          w[i] = m->c;
                                 gcdsf(CO,w,n,&g);                  gcdsf(CO,w,n,&g);
                                 if ( NUM(g) )                  if ( NUM(g) )
                                         *rp = p;                          dp_monic_sf(p,rp);
                                 else {                  else {
                                         for ( mr0 = 0, m = BDY(p); m; m = NEXT(m) ) {                          for ( mr0 = 0, m = BDY(p); m; m = NEXT(m) ) {
                                                 NEXTMP(mr0,mr); divsp(CO,m->c,g,&mr->c); mr->dl = m->dl;                                  NEXTMP(mr0,mr); divsp(CO,m->c,g,&mr->c); mr->dl = m->dl;
                                         }  
                                         NEXT(mr) = 0; MKDP(p->nv,mr0,*rp); (*rp)->sugar = p->sugar;  
                                 }  
                                 return;  
                         }                          }
                           NEXT(mr) = 0; MKDP(p->nv,mr0,p1); p1->sugar = p->sugar;
                           dp_monic_sf(p1,rp);
                 }                  }
                 /* all coeffs are poly over Q */                  return;
           } else if ( dp_fcoeffs )
                 *rp = p;                  *rp = p;
         } else if ( NoGCD )          else if ( NoGCD )
                 dp_ptozp(p,rp);                  dp_ptozp(p,rp);
         else {          else {
                 dp_ptozp(p,&p1); p = p1;                  dp_ptozp(p,&p1); p = p1;
Line 728  void dp_red(DP p0,DP p1,DP p2,DP *head,DP *rest,P *dnp
Line 749  void dp_red(DP p0,DP p1,DP p2,DP *head,DP *rest,P *dnp
         Q c,c1,c2;          Q c,c1,c2;
         N gn,tn;          N gn,tn;
         P g,a;          P g,a;
           P p[2];
   
         n = p1->nv; d1 = BDY(p1)->dl; d2 = BDY(p2)->dl;          n = p1->nv; d1 = BDY(p1)->dl; d2 = BDY(p2)->dl;
         NEWDL(d,n); d->td = d1->td - d2->td;          NEWDL(d,n); d->td = d1->td - d2->td;
         for ( i = 0; i < n; i++ )          for ( i = 0; i < n; i++ )
                 d->d[i] = d1->d[i]-d2->d[i];                  d->d[i] = d1->d[i]-d2->d[i];
         c1 = (Q)BDY(p1)->c; c2 = (Q)BDY(p2)->c;          c1 = (Q)BDY(p1)->c; c2 = (Q)BDY(p2)->c;
         if ( dp_fcoeffs ) {          if ( dp_fcoeffs == N_GFS ) {
                   p[0] = (P)c1; p[1] = (P)c2;
                   gcdsf(CO,p,2,&g);
                   divsp(CO,(P)c1,g,&a); c1 = (Q)a; divsp(CO,(P)c2,g,&a); c2 = (Q)a;
           } else if ( dp_fcoeffs ) {
                 /* do nothing */                  /* do nothing */
         } else if ( INT(c1) && INT(c2) ) {          } else if ( INT(c1) && INT(c2) ) {
                 gcdn(NM(c1),NM(c2),&gn);                  gcdn(NM(c1),NM(c2),&gn);
Line 1262  void dp_nf_tab_mod(DP p,LIST *tab,int mod,DP *rp)
Line 1288  void dp_nf_tab_mod(DP p,LIST *tab,int mod,DP *rp)
         *rp = s;          *rp = s;
 }  }
   
   void dp_nf_tab_f(DP p,LIST *tab,DP *rp)
   {
           DP s,t,u;
           MP m;
           DL h;
           int i,n;
   
           if ( !p ) {
                   *rp = p; return;
           }
           n = p->nv;
           for ( s = 0, i = 0, m = BDY(p); m; m = NEXT(m) ) {
                   h = m->dl;
                   while ( !dl_equal(n,h,BDY((DP)BDY(BDY(tab[i])))->dl ) )
                           i++;
                   muldc(CO,(DP)BDY(NEXT(BDY(tab[i]))),m->c,&t);
                   addd(CO,s,t,&u); s = u;
           }
           *rp = s;
   }
   
 /*  /*
  * setting flags   * setting flags
  *   *
  */   */
   
 int create_order_spec(Obj obj,struct order_spec *spec)  int create_order_spec(VL vl,Obj obj,struct order_spec **specp)
 {  {
         int i,j,n,s,row,col;          int i,j,n,s,row,col;
           struct order_spec *spec;
         struct order_pair *l;          struct order_pair *l;
         NODE node,t,tn;          NODE node,t,tn;
         MAT m;          MAT m;
         pointer **b;          pointer **b;
         int **w;          int **w;
   
           if ( vl && obj && OID(obj) == O_LIST )
                   return create_composite_order_spec(vl,(LIST)obj,specp);
   
           *specp = spec = (struct order_spec *)MALLOC(sizeof(struct order_spec));
         if ( !obj || NUM(obj) ) {          if ( !obj || NUM(obj) ) {
                 spec->id = 0; spec->obj = obj;                  spec->id = 0; spec->obj = obj;
                 spec->ord.simple = QTOS((Q)obj);                  spec->ord.simple = QTOS((Q)obj);
Line 1307  int create_order_spec(Obj obj,struct order_spec *spec)
Line 1359  int create_order_spec(Obj obj,struct order_spec *spec)
                 return 0;                  return 0;
 }  }
   
   void print_composite_order_spec(struct order_spec *spec)
   {
           int nv,n,len,i,j,k,start;
           struct weight_or_block *worb;
   
           nv = spec->nv;
           n = spec->ord.composite.length;
           worb = spec->ord.composite.w_or_b;
           for ( i = 0; i < n; i++, worb++ ) {
                   len = worb->length;
                   printf("[ ");
                   switch ( worb->type ) {
                           case IS_DENSE_WEIGHT:
                                   for ( j = 0; j < len; j++ )
                                           printf("%d ",worb->body.dense_weight[j]);
                                   for ( ; j < nv; j++ )
                                           printf("0 ");
                                   break;
                           case IS_SPARSE_WEIGHT:
                                   for ( j = 0, k = 0; j < nv; j++ )
                                           if ( j == worb->body.sparse_weight[k].pos )
                                                   printf("%d ",worb->body.sparse_weight[k++].value);
                                           else
                                                   printf("0 ");
                                   break;
                           case IS_BLOCK:
                                   start = worb->body.block.start;
                                   for ( j = 0; j < start; j++ ) printf("0 ");
                                   switch ( worb->body.block.order ) {
                                           case 0:
                                                   for ( k = 0; k < len; k++, j++ ) printf("R ");
                                                   break;
                                           case 1:
                                                   for ( k = 0; k < len; k++, j++ ) printf("G ");
                                                   break;
                                           case 2:
                                                   for ( k = 0; k < len; k++, j++ ) printf("L ");
                                                   break;
                                   }
                                   for ( ; j < nv; j++ ) printf("0 ");
                                   break;
                   }
                   printf("]\n");
           }
   }
   
   /* order = [w_or_b, w_or_b, ... ] */
   /* w_or_b = w or b                */
   /* w = [1,2,...] or [x,1,y,2,...] */
   /* b = [@lex,x,y,...,z] etc       */
   
   int create_composite_order_spec(VL vl,LIST order,struct order_spec **specp)
   {
           NODE wb,t,p;
           struct order_spec *spec;
           VL tvl;
           int n,i,j,k,l,len;
           int *dw;
           struct sparse_weight *sw;
           struct weight_or_block *w_or_b;
           Obj a0;
           NODE a;
           V v;
           Symbol sym;
           int start;
   
           /* l = number of vars in vl */
           for ( l = 0, tvl = vl; tvl; tvl = NEXT(tvl), l++ );
           /* n = number of primitives in order */
           wb = BDY(order);
           n = length(wb);
           *specp = spec = (struct order_spec *)MALLOC(sizeof(struct order_spec));
           spec->id = 3;
           spec->obj = (Obj)order;
           spec->nv = l;
           spec->ord.composite.length = n;
           w_or_b = spec->ord.composite.w_or_b = (struct weight_or_block *)
                   MALLOC(sizeof(struct weight_or_block)*n);
           for ( t = wb, i = 0; t; t = NEXT(t), i++ ) {
                   a = BDY((LIST)BDY(t));
                   len = length(a);
                   a0 = (Obj)BDY(a);
                   if ( !a0 || OID(a0) == O_N ) {
                           /* a is a dense weight vector */
                           dw = (int *)MALLOC(sizeof(int)*len);
                           for ( j = 0, p = a; j < len; p = NEXT(p), j++ )
                                   dw[j] = QTOS((Q)BDY(p));
                           w_or_b[i].type = IS_DENSE_WEIGHT;
                           w_or_b[i].length = len;
                           w_or_b[i].body.dense_weight = dw;
                   } else if ( OID(a0) == O_P ) {
                           /* a is a sparse weight vector */
                           len >>= 1;
                           sw = (struct sparse_weight *)
                                   MALLOC(sizeof(struct sparse_weight)*len);
                           for ( j = 0, p = a; j < len; j++ ) {
                                   v = VR((P)BDY(p)); p = NEXT(p);
                                   for ( tvl = vl, k = 0; tvl && tvl->v != v;
                                           k++, tvl = NEXT(tvl) );
                                   if ( !tvl )
                                           error("invalid variable name");
                                   sw[j].pos = k;
                                   sw[j].value = QTOS((Q)BDY(p)); p = NEXT(p);
                           }
                           w_or_b[i].type = IS_SPARSE_WEIGHT;
                           w_or_b[i].length = len;
                           w_or_b[i].body.sparse_weight = sw;
                   } else if ( OID(a0) == O_SYMBOL ) {
                           /* a is a block */
                           sym = (Symbol)a0; a = NEXT(a); len--;
                           for ( start = 0, tvl = vl; tvl->v != VR((P)BDY(a));
                                   tvl = NEXT(tvl), start++ );
                           for ( p = NEXT(a), tvl = NEXT(tvl); p;
                                   p = NEXT(p), tvl = NEXT(tvl) )
                                   if ( tvl->v != VR((P)BDY(p)) ) break;
                           if ( p )
                                   error("a block must be contiguous");
                           w_or_b[i].type = IS_BLOCK;
                           w_or_b[i].length = len;
                           w_or_b[i].body.block.start = start;
                           if ( !strcmp(sym->name,"@grlex") )
                                   w_or_b[i].body.block.order = 0;
                           else if ( !strcmp(sym->name,"@glex") )
                                   w_or_b[i].body.block.order = 1;
                           else if ( !strcmp(sym->name,"@lex") )
                                   w_or_b[i].body.block.order = 2;
                           else
                                   error("invalid ordernam");
                   }
           }
           if ( 1 ) print_composite_order_spec(spec);
   }
   
 /*  /*
  * converters   * converters
  *   *
Line 1404  void dp_rat(DP p,DP *rp)
Line 1589  void dp_rat(DP p,DP *rp)
 }  }
   
   
 void homogenize_order(struct order_spec *old,int n,struct order_spec *new)  void homogenize_order(struct order_spec *old,int n,struct order_spec **newp)
 {  {
         struct order_pair *l;          struct order_pair *l;
         int length,nv,row,i,j;          int length,nv,row,i,j;
         int **newm,**oldm;          int **newm,**oldm;
           struct order_spec *new;
   
           *newp = new = (struct order_spec *)MALLOC(sizeof(struct order_spec));
         switch ( old->id ) {          switch ( old->id ) {
                 case 0:                  case 0:
                         switch ( old->ord.simple ) {                          switch ( old->ord.simple ) {
Line 1649  void _print_mp(int nv,MP m)
Line 1836  void _print_mp(int nv,MP m)
         }          }
         fprintf(stderr,"\n");          fprintf(stderr,"\n");
 }  }
   
   static int cmp_mp_nvar;
   
   int comp_mp(MP *a,MP *b)
   {
           return -(*cmpdl)(cmp_mp_nvar,(*a)->dl,(*b)->dl);
   }
   
   void dp_sort(DP p,DP *rp)
   {
           MP t,mp,mp0;
           int i,n;
           DP r;
           MP *w;
   
           if ( !p ) {
                   *rp = 0;
                   return;
           }
           for ( t = BDY(p), n = 0; t; t = NEXT(t), n++ );
           w = (MP *)ALLOCA(n*sizeof(MP));
           for ( t = BDY(p), i = 0; i < n; t = NEXT(t), i++ )
                   w[i] = t;
           cmp_mp_nvar = NV(p);
           qsort(w,n,sizeof(MP),(int (*)(const void *,const void *))comp_mp);
           mp0 = 0;
           for ( i = n-1; i >= 0; i-- ) {
                   NEWMP(mp); mp->dl = w[i]->dl; C(mp) = C(w[i]);
                   NEXT(mp) = mp0; mp0 = mp;
           }
           MKDP(p->nv,mp0,r);
           r->sugar = p->sugar;
           *rp = r;
   }
   

Legend:
Removed from v.1.22  
changed lines
  Added in v.1.28

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