[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.23 and 1.25

version 1.23, 2003/01/04 09:06:15 version 1.25, 2003/01/18 02:38:56
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.22 2002/12/27 07:37:57 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/builtin/dp-supp.c,v 1.24 2003/01/15 04:53:03 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 403  void dp_prim(DP p,DP *rp)
Line 425  void dp_prim(DP p,DP *rp)
                 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 break;                          } else break;
                 /* compute GCD over the finite fieid */                  /* compute GCD over the finite fieid */
Line 413  void dp_prim(DP p,DP *rp)
Line 435  void dp_prim(DP p,DP *rp)
                         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;                          NEXT(mr) = 0; MKDP(p->nv,mr0,p1); p1->sugar = p->sugar;
                           dp_monic_sf(p1,rp);
                 }                  }
                 return;                  return;
         } else if ( dp_fcoeffs )          } else if ( dp_fcoeffs )
Line 1261  void dp_nf_tab_mod(DP p,LIST *tab,int mod,DP *rp)
Line 1284  void dp_nf_tab_mod(DP p,LIST *tab,int mod,DP *rp)
                         i++;                          i++;
                 mulmdc(CO,mod,(DP)BDY(NEXT(BDY(tab[i]))),m->c,&t);                  mulmdc(CO,mod,(DP)BDY(NEXT(BDY(tab[i]))),m->c,&t);
                 addmd(CO,mod,s,t,&u); s = u;                  addmd(CO,mod,s,t,&u); s = u;
           }
           *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;          *rp = s;
 }  }

Legend:
Removed from v.1.23  
changed lines
  Added in v.1.25

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