| version 1.11, 2000/12/05 06:59:16 |
version 1.17, 2001/09/04 08:48:20 |
|
|
| * 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/engine/dist.c,v 1.10 2000/11/07 06:06:39 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/engine/dist.c,v 1.16 2001/05/02 09:03:53 noro Exp $ |
| */ |
*/ |
| #include "ca.h" |
#include "ca.h" |
| |
|
|
|
| #define ORD_BGRADREV 7 |
#define ORD_BGRADREV 7 |
| #define ORD_BLEXREV 8 |
#define ORD_BLEXREV 8 |
| #define ORD_ELIM 9 |
#define ORD_ELIM 9 |
| |
#define ORD_WEYL_ELIM 10 |
| |
#define ORD_HOMO_WW_DRL 11 |
| |
|
| int (*cmpdl)()=cmpdl_revgradlex; |
int (*cmpdl)()=cmpdl_revgradlex; |
| int (*primitive_cmpdl[3])() = {cmpdl_revgradlex,cmpdl_gradlex,cmpdl_lex}; |
int (*primitive_cmpdl[3])() = {cmpdl_revgradlex,cmpdl_gradlex,cmpdl_lex}; |
| Line 71 void comm_muld_tab(VL,int,struct cdl *,int,struct cdl |
|
| Line 73 void comm_muld_tab(VL,int,struct cdl *,int,struct cdl |
|
| |
|
| void mkwc(int,int,Q *); |
void mkwc(int,int,Q *); |
| |
|
| |
int cmpdl_weyl_elim(); |
| |
int cmpdl_homo_ww_drl(); |
| |
|
| int do_weyl; |
int do_weyl; |
| |
|
| int dp_nelim,dp_fcoeffs; |
int dp_nelim,dp_fcoeffs; |
|
|
| if ( !f ) |
if ( !f ) |
| return 0; |
return 0; |
| else if ( NUM(f) ) |
else if ( NUM(f) ) |
| return (NID((Num)f) == N_LM || NID((Num)f) == N_GF2N) ? 1 : 0; |
return (NID((Num)f) == N_LM |
| |
|| NID((Num)f) == N_GF2N |
| |
|| NID((Num)f) == N_GFPN |
| |
|| NID((Num)f) == N_GFS) ? 1 : 0; |
| else { |
else { |
| for ( dc = DC(f); dc; dc = NEXT(dc) ) |
for ( dc = DC(f); dc; dc = NEXT(dc) ) |
| if ( has_fcoef_p(COEF(dc)) ) |
if ( has_fcoef_p(COEF(dc)) ) |
| Line 141 struct order_spec *spec; |
|
| Line 149 struct order_spec *spec; |
|
| cmpdl = cmpdl_blexrev; break; |
cmpdl = cmpdl_blexrev; break; |
| case ORD_ELIM: |
case ORD_ELIM: |
| cmpdl = cmpdl_elim; break; |
cmpdl = cmpdl_elim; break; |
| |
case ORD_WEYL_ELIM: |
| |
cmpdl = cmpdl_weyl_elim; break; |
| |
case ORD_HOMO_WW_DRL: |
| |
cmpdl = cmpdl_homo_ww_drl; break; |
| case ORD_LEX: default: |
case ORD_LEX: default: |
| cmpdl = cmpdl_lex; break; |
cmpdl = cmpdl_lex; break; |
| } |
} |
|
|
| DP *pr; |
DP *pr; |
| { |
{ |
| int isconst = 0; |
int isconst = 0; |
| int n,i; |
int n,i,j,k; |
| VL tvl; |
VL tvl; |
| V v; |
V v; |
| DL d; |
DL d; |
| MP m; |
MP m; |
| DCP dc; |
DCP dc; |
| |
DCP *w; |
| DP r,s,t,u; |
DP r,s,t,u; |
| P x,c; |
P x,c; |
| |
|
|
|
| for ( i = 0, tvl = dvl, v = VR(p); |
for ( i = 0, tvl = dvl, v = VR(p); |
| tvl && tvl->v != v; tvl = NEXT(tvl), i++ ); |
tvl && tvl->v != v; tvl = NEXT(tvl), i++ ); |
| if ( !tvl ) { |
if ( !tvl ) { |
| for ( dc = DC(p), s = 0, MKV(v,x); dc; dc = NEXT(dc) ) { |
for ( dc = DC(p), k = 0; dc; dc = NEXT(dc), k++ ); |
| ptod(vl,dvl,COEF(dc),&t); pwrp(vl,x,DEG(dc),&c); |
w = (DCP *)ALLOCA(k*sizeof(DCP)); |
| |
for ( dc = DC(p), j = 0; j < k; dc = NEXT(dc), j++ ) |
| |
w[j] = dc; |
| |
|
| |
for ( j = k-1, s = 0, MKV(v,x); j >= 0; j-- ) { |
| |
ptod(vl,dvl,COEF(w[j]),&t); pwrp(vl,x,DEG(w[j]),&c); |
| muldc(vl,t,c,&r); addd(vl,r,s,&t); s = t; |
muldc(vl,t,c,&r); addd(vl,r,s,&t); s = t; |
| } |
} |
| *pr = s; |
*pr = s; |
| } else { |
} else { |
| for ( dc = DC(p), s = 0; dc; dc = NEXT(dc) ) { |
for ( dc = DC(p), k = 0; dc; dc = NEXT(dc), k++ ); |
| ptod(vl,dvl,COEF(dc),&t); |
w = (DCP *)ALLOCA(k*sizeof(DCP)); |
| NEWDL(d,n); d->td = QTOS(DEG(dc)); d->d[i] = d->td; |
for ( dc = DC(p), j = 0; j < k; dc = NEXT(dc), j++ ) |
| |
w[j] = dc; |
| |
|
| |
for ( j = k-1, s = 0; j >= 0; j-- ) { |
| |
ptod(vl,dvl,COEF(w[j]),&t); |
| |
NEWDL(d,n); d->td = QTOS(DEG(w[j])); d->d[i] = d->td; |
| NEWMP(m); m->dl = d; C(m) = (P)ONE; NEXT(m) = 0; MKDP(n,m,u); u->sugar = d->td; |
NEWMP(m); m->dl = d; C(m) = (P)ONE; NEXT(m) = 0; MKDP(n,m,u); u->sugar = d->td; |
| comm_muld(vl,t,u,&r); addd(vl,r,s,&t); s = t; |
comm_muld(vl,t,u,&r); addd(vl,r,s,&t); s = t; |
| } |
} |
|
|
| } |
} |
| } |
} |
| } |
} |
| |
#if 0 |
| if ( !dp_fcoeffs && has_fcoef(*pr) ) |
if ( !dp_fcoeffs && has_fcoef(*pr) ) |
| dp_fcoeffs = 1; |
dp_fcoeffs = 1; |
| |
#endif |
| } |
} |
| |
|
| void dtop(vl,dvl,p,pr) |
void dtop(vl,dvl,p,pr) |
|
|
| DP p; |
DP p; |
| P *pr; |
P *pr; |
| { |
{ |
| int n,i; |
int n,i,j,k; |
| DL d; |
DL d; |
| MP m; |
MP m; |
| |
MP *a; |
| P r,s,t,u,w; |
P r,s,t,u,w; |
| Q q; |
Q q; |
| VL tvl; |
VL tvl; |
|
|
| if ( !p ) |
if ( !p ) |
| *pr = 0; |
*pr = 0; |
| else { |
else { |
| for ( n = p->nv, m = BDY(p), s = 0; m; m = NEXT(m) ) { |
for ( k = 0, m = BDY(p); m; m = NEXT(m), k++ ); |
| |
a = (MP *)ALLOCA(k*sizeof(MP)); |
| |
for ( j = 0, m = BDY(p); j < k; m = NEXT(m), j++ ) |
| |
a[j] = m; |
| |
|
| |
for ( n = p->nv, j = k-1, s = 0; j >= 0; j-- ) { |
| |
m = a[j]; |
| t = C(m); |
t = C(m); |
| if ( NUM(t) && NID((Num)t) == N_M ) { |
if ( NUM(t) && NID((Num)t) == N_M ) { |
| mptop(t,&u); t = u; |
mptop(t,&u); t = u; |
|
|
| return -1; |
return -1; |
| else |
else |
| return cmpdl_revgradlex(n,d1,d2); |
return cmpdl_revgradlex(n,d1,d2); |
| |
} |
| |
|
| |
int cmpdl_weyl_elim(n,d1,d2) |
| |
int n; |
| |
DL d1,d2; |
| |
{ |
| |
int e1,e2,i; |
| |
|
| |
for ( i = 1, e1 = 0, e2 = 0; i <= dp_nelim; i++ ) { |
| |
e1 += d1->d[n-i]; e2 += d2->d[n-i]; |
| |
} |
| |
if ( e1 > e2 ) |
| |
return 1; |
| |
else if ( e1 < e2 ) |
| |
return -1; |
| |
else if ( d1->td > d2->td ) |
| |
return 1; |
| |
else if ( d1->td < d2->td ) |
| |
return -1; |
| |
else return -cmpdl_revlex(n,d1,d2); |
| |
} |
| |
|
| |
/* |
| |
a special ordering |
| |
1. total order |
| |
2. (-w,w) for the first 2*m variables |
| |
3. DRL for the first 2*m variables |
| |
*/ |
| |
|
| |
extern int *current_weight_vector; |
| |
|
| |
int cmpdl_homo_ww_drl(n,d1,d2) |
| |
int n; |
| |
DL d1,d2; |
| |
{ |
| |
int e1,e2,m,i; |
| |
int *p1,*p2; |
| |
|
| |
if ( d1->td > d2->td ) |
| |
return 1; |
| |
else if ( d1->td < d2->td ) |
| |
return -1; |
| |
|
| |
m = n>>1; |
| |
for ( i = 0, e1 = e2 = 0; i < m; i++ ) { |
| |
e1 += current_weight_vector[i]*(d1->d[m+i] - d1->d[i]); |
| |
e2 += current_weight_vector[i]*(d2->d[m+i] - d2->d[i]); |
| |
} |
| |
if ( e1 > e2 ) |
| |
return 1; |
| |
else if ( e1 < e2 ) |
| |
return -1; |
| |
|
| |
e1 = d1->td - d1->d[n-1]; |
| |
e2 = d2->td - d2->d[n-1]; |
| |
if ( e1 > e2 ) |
| |
return 1; |
| |
else if ( e1 < e2 ) |
| |
return -1; |
| |
|
| |
for ( i= n - 1, p1 = d1->d+n-1, p2 = d2->d+n-1; |
| |
i >= 0 && *p1 == *p2; i--, p1--, p2-- ); |
| |
return i < 0 ? 0 : (*p1 < *p2 ? 1 : -1); |
| } |
} |
| |
|
| int cmpdl_order_pair(n,d1,d2) |
int cmpdl_order_pair(n,d1,d2) |