=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/engine/nd.c,v retrieving revision 1.55 retrieving revision 1.58 diff -u -p -r1.55 -r1.58 --- OpenXM_contrib2/asir2000/engine/nd.c 2003/09/03 07:33:35 1.55 +++ OpenXM_contrib2/asir2000/engine/nd.c 2003/09/05 07:00:37 1.58 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM_contrib2/asir2000/engine/nd.c,v 1.54 2003/08/31 07:42:23 noro Exp $ */ +/* $OpenXM: OpenXM_contrib2/asir2000/engine/nd.c,v 1.57 2003/09/05 05:02:53 noro Exp $ */ #include "ca.h" #include "inline.h" @@ -121,6 +121,7 @@ static int nmv_adv; static int nd_dcomp; extern int Top,Reverse,dp_nelim,do_weyl; +extern int *current_weyl_weight_vector; /* fundamental macros */ #define TD(d) (d[0]) @@ -185,6 +186,7 @@ if(!(r)){NEWND_pairs(r);(c)=(r);}else{NEWND_pairs(NEXT /* macro for increasing pointer to NMV */ #define NMV_ADV(m) (m = (NMV)(((char *)m)+nmv_adv)) +#define NMV_PREV(m) (m = (NMV)(((char *)m)-nmv_adv)) /* external functions */ void GC_gcollect(); @@ -225,6 +227,7 @@ NODE nd_gb_trace(int m); /* ndl functions */ int ndl_weight(unsigned int *d); int ndl_weight_mask(unsigned int *d,int i); +void ndl_set_blockweight(unsigned int *d); void ndl_dehomogenize(unsigned int *p); void ndl_reconstruct(int obpe,EPOS oepos,unsigned int *d,unsigned int *r); INLINE int ndl_reducible(unsigned int *d1,unsigned int *d2); @@ -272,6 +275,7 @@ void nd_reconstruct_direct(int mod,NDV *ps,int len); void nd_setup(int mod,int trace,NODE f); void nd_setup_parameters(); BlockMask nd_create_blockmask(struct order_spec *ord); +EPOS nd_create_epos(struct order_spec *ord); int nd_get_exporigin(struct order_spec *ord); /* ND functions */ @@ -282,7 +286,6 @@ ND nd_remove_head(ND p); int nd_length(ND p); void nd_append_red(unsigned int *d,int i); unsigned int *ndv_compute_bound(NDV p); -unsigned int *dp_compute_bound(DP p); ND nd_copy(ND p); ND nd_add(int mod,ND p1,ND p2); ND nd_add_q(ND p1,ND p2); @@ -291,7 +294,6 @@ INLINE int nd_length(ND p); /* NDV functions */ ND weyl_ndv_mul_nm(int mod,NM m0,NDV p); void weyl_mul_nm_nmv(int n,int mod,NM m0,NMV m1,NM *tab,int tlen); -void weyl_mul_nm_nmv_q(int n,NM m0,NMV m1,NM *tab,int tlen); void ndv_mul_c(int mod,NDV p,int mul); void ndv_mul_c_q(NDV p,Q mul); void ndv_realloc(NDV p,int obpe,int oadv,EPOS oepos); @@ -540,6 +542,16 @@ void ndl_lcm(unsigned int *d1,unsigned *d2,unsigned in } } +void ndl_set_blockweight(unsigned int *d) { + int l,j; + + if ( nd_blockmask ) { + l = nd_blockmask->n; + for ( j = 0; j < l; j++ ) + d[j+1] = ndl_weight_mask(d,j); + } +} + int ndl_weight(unsigned int *d) { unsigned int t,u; @@ -610,6 +622,24 @@ int ndl_block_compare(unsigned int *d1,unsigned int *d return 0; } +/* TDH -> WW -> TD-> RL */ + +int ndl_ww_lex_compare(unsigned int *d1,unsigned int *d2) +{ + int i,m,e1,e2; + + if ( TD(d1) > TD(d2) ) return 1; + else if ( TD(d1) < TD(d2) ) return -1; + m = nd_nvar>>1; + for ( i = 0, e1 = e2 = 0; i < m; i++ ) { + e1 += current_weyl_weight_vector[i]*(GET_EXP(d1,m+i)-GET_EXP(d1,i)); + e2 += current_weyl_weight_vector[i]*(GET_EXP(d2,m+i)-GET_EXP(d2,i)); + } + if ( e1 > e2 ) return 1; + else if ( e1 < e2 ) return -1; + return ndl_lex_compare(d1,d2); +} + INLINE int ndl_equal(unsigned int *d1,unsigned int *d2) { int i; @@ -1764,8 +1794,6 @@ ND_pairs crit_B( ND_pairs d, int s ) return head; } -/* XXX : check is necessary */ - ND_pairs crit_M( ND_pairs d1 ) { ND_pairs e,d2,d3,dd,p; @@ -1960,6 +1988,7 @@ void nd_setup(int mod,int trace,NODE f) unsigned int *d; RHist r; NDV a; + MP t; nd_found = 0; nd_notfirst = 0; nd_create = 0; @@ -1968,15 +1997,17 @@ void nd_setup(int mod,int trace,NODE f) nd_ps_trace = (NDV *)MALLOC(nd_pslen*sizeof(NDV)); nd_psh = (RHist *)MALLOC(nd_pslen*sizeof(RHist)); nd_bound = (unsigned int **)MALLOC(nd_pslen*sizeof(unsigned int *)); - for ( max = 0, i = 0, s = f; i < nd_psn; i++, s = NEXT(s) ) { - nd_bound[i] = d = dp_compute_bound((DP)BDY(s)); - for ( j = 0; j < nd_nvar; j++ ) - max = MAX(d[j],max); - } + if ( !nd_red ) nd_red = (RHist *)MALLOC(REDTAB_LEN*sizeof(RHist)); bzero(nd_red,REDTAB_LEN*sizeof(RHist)); + for ( max = 0, s = f; s; s = NEXT(s) ) + for ( t = BDY((DP)BDY(s)); t; t = NEXT(t) ) { + d = t->dl->d; + for ( j = 0; j < nd_nvar; j++ ) max = MAX(d[j],max); + } + if ( max < 2 ) nd_bpe = 2; else if ( max < 4 ) nd_bpe = 4; else if ( max < 64 ) nd_bpe = 6; @@ -1990,12 +2021,12 @@ void nd_setup(int mod,int trace,NODE f) NEWRHist(r); a = dptondv(mod,(DP)BDY(f)); ndv_removecont(mod,a); SG(r) = HTD(a); ndl_copy(HDL(a),DL(r)); - nd_ps[i] = a; if ( trace ) { a = dptondv(0,(DP)BDY(f)); ndv_removecont(0,a); nd_ps_trace[i] = a; } + nd_bound[i] = ndv_compute_bound(a); nd_psh[i] = r; } } @@ -2141,7 +2172,7 @@ void nd_gr_trace(LIST f,LIST v,int trace,int homo,stru void dltondl(int n,DL dl,unsigned int *r) { unsigned int *d; - int i,j,l,s,ord_l,ord_o; + int i,j,l,s,ord_l; struct order_pair *op; d = dl->d; @@ -2150,24 +2181,14 @@ void dltondl(int n,DL dl,unsigned int *r) l = nd_blockmask->n; op = nd_blockmask->order_pair; for ( j = 0, s = 0; j < l; j++ ) { - ord_o = op[j].order; ord_l = op[j].length; - if ( !ord_o ) - for ( i = 0; i < ord_l; i++ ) - PUT_EXP(r,s+ord_l-i-1,d[s+i]); - else - for ( i = 0; i < ord_l; i++ ) - PUT_EXP(r,s+i,d[s+i]); - s += ord_l; + for ( i = 0; i < ord_l; i++, s++ ) PUT_EXP(r,s,d[s]); } TD(r) = ndl_weight(r); for ( j = 0; j < l; j++ ) r[j+1] = ndl_weight_mask(r,j); } else { - if ( nd_isrlex ) - for ( i = 0; i < n; i++ ) PUT_EXP(r,n-1-i,d[i]); - else - for ( i = 0; i < n; i++ ) PUT_EXP(r,i,d[i]); + for ( i = 0; i < n; i++ ) PUT_EXP(r,i,d[i]); TD(r) = ndl_weight(r); } } @@ -2176,7 +2197,7 @@ DL ndltodl(int n,unsigned int *ndl) { DL dl; int *d; - int i,j,l,s,ord_l,ord_o; + int i,j,l,s,ord_l; struct order_pair *op; NEWDL(dl,n); @@ -2186,23 +2207,11 @@ DL ndltodl(int n,unsigned int *ndl) l = nd_blockmask->n; op = nd_blockmask->order_pair; for ( j = 0, s = 0; j < l; j++ ) { - ord_o = op[j].order; ord_l = op[j].length; - if ( !ord_o ) - for ( i = 0; i < ord_l; i++ ) - d[s+i] = GET_EXP(ndl,s+ord_l-i-1); - else - for ( i = 0; i < ord_l; i++ ) - d[s+i] = GET_EXP(ndl,s+i); - s += ord_l; + for ( i = 0; i < ord_l; i++, s++ ) d[s] = GET_EXP(ndl,s); } } else { - if ( nd_isrlex ) - for ( i = 0; i < n; i++ ) - d[i] = GET_EXP(ndl,n-1-i); - else - for ( i = 0; i < n; i++ ) - d[i] = GET_EXP(ndl,i); + for ( i = 0; i < n; i++ ) d[i] = GET_EXP(ndl,i); } return dl; } @@ -2256,7 +2265,7 @@ DP ndtodp(int mod,ND p) void ndl_print(unsigned int *dl) { int n; - int i,j,l,ord_o,ord_l,s,s0; + int i,j,l,ord_l,s,s0; struct order_pair *op; n = nd_nvar; @@ -2265,20 +2274,12 @@ void ndl_print(unsigned int *dl) l = nd_blockmask->n; op = nd_blockmask->order_pair; for ( j = 0, s = s0 = 0; j < l; j++ ) { - ord_o = op[j].order; ord_l = op[j].length; - if ( !ord_o ) - for ( i = 0, s0 += ord_l; i < ord_l; i++, s++ ) - printf(s==n-1?"%d":"%d,",GET_EXP(dl,s0-i-1)); - else - for ( i = 0; i < ord_l; i++, s++ ) - printf(s==n-1?"%d":"%d,",GET_EXP(dl,s)); + for ( i = 0; i < ord_l; i++, s++ ) + printf(s==n-1?"%d":"%d,",GET_EXP(dl,s)); } } else { - if ( nd_isrlex ) - for ( i = 0; i < n; i++ ) printf(i==n-1?"%d":"%d,",GET_EXP(dl,n-1-i)); - else - for ( i = 0; i < n; i++ ) printf(i==n-1?"%d":"%d,",GET_EXP(dl,i)); + for ( i = 0; i < n; i++ ) printf(i==n-1?"%d":"%d,",GET_EXP(dl,i)); } printf(">>"); } @@ -2509,36 +2510,11 @@ void nd_append_red(unsigned int *d,int i) nd_red[h] = m; } -unsigned int *dp_compute_bound(DP p) -{ - unsigned int *d,*d1,*d2,*t; - MP m; - int i,l; - - if ( !p ) - return 0; - d1 = (unsigned int *)ALLOCA(nd_nvar*sizeof(unsigned int)); - d2 = (unsigned int *)ALLOCA(nd_nvar*sizeof(unsigned int)); - m = BDY(p); - d = DL(m)->d; - for ( i = 0; i < nd_nvar; i++ ) d1[i] = d[i]; - for ( m = NEXT(BDY(p)); m; m = NEXT(m) ) { - d = DL(m)->d; - for ( i = 0; i < nd_nvar; i++ ) - d2[i] = d[i] > d1[i] ? d[i] : d1[i]; - t = d1; d1 = d2; d2 = t; - } - l = (nd_nvar+31); - t = (unsigned int *)MALLOC_ATOMIC(l*sizeof(unsigned int)); - for ( i = 0; i < nd_nvar; i++ ) t[i] = d1[i]; - for ( ; i < l; i++ ) t[i] = 0; - return t; -} - unsigned int *ndv_compute_bound(NDV p) { unsigned int *d1,*d2,*t; - int i,l,len; + unsigned int u; + int i,j,k,l,len,ind; NMV m; if ( !p ) @@ -2553,8 +2529,13 @@ unsigned int *ndv_compute_bound(NDV p) } l = nd_nvar+31; t = (unsigned int *)MALLOC_ATOMIC(l*sizeof(unsigned int)); - for ( i = 0; i < nd_nvar; i++ ) t[i] = GET_EXP(d1,i); - for ( ; i < l; i++ ) t[i] = 0; + for ( i = nd_exporigin, ind = 0; i < nd_wpd; i++ ) { + u = d1[i]; + k = (nd_epw-1)*nd_bpe; + for ( j = 0; j < nd_epw; j++, k -= nd_bpe, ind++ ) + t[ind] = (u>>k)&nd_mask0; + } + for ( ; ind < l; ind++ ) t[ind] = 0; return t; } @@ -2573,18 +2554,15 @@ int nd_get_exporigin(struct order_spec *ord) } void nd_setup_parameters() { - int i,n,elen; + int i,j,n,elen,ord_o,ord_l,l,s; + struct order_pair *op; nd_epw = (sizeof(unsigned int)*8)/nd_bpe; elen = nd_nvar/nd_epw+(nd_nvar%nd_epw?1:0); nd_exporigin = nd_get_exporigin(nd_ord); nd_wpd = nd_exporigin+elen; - nd_epos = (EPOS)MALLOC_ATOMIC(nd_nvar*sizeof(struct oEPOS)); - for ( i = 0; i < nd_nvar; i++ ) { - nd_epos[i].i = nd_exporigin + i/nd_epw; - nd_epos[i].s = (nd_epw-(i%nd_epw)-1)*nd_bpe; - } + if ( nd_bpe < 32 ) { nd_mask0 = (1<>oepos[a].s)&omask0) #define PUT_EXP_OLD(r,a,e) ((r)[oepos[a].i] |= ((e)<i1,DL(m)) ) return 0; + if ( ndl_check_bound2(p->i1,DL(m)) ) + return 0; t1 = ndv_mul_nm(mod,m,p1); if ( mod ) CM(m) = mod-HCM(p1); else chsgnq(HCQ(p1),&CQ(m)); @@ -2839,12 +2805,10 @@ ND weyl_ndv_mul_nm(int mod,NM m0,NDV p) { tab = (NM *)ALLOCA(tlen*sizeof(NM)); psum = (NM *)ALLOCA(tlen*sizeof(NM)); for ( i = 0; i < tlen; i++ ) psum[i] = 0; - for ( i = l-1, m1 = BDY(p)+nmv_adv*(l-1); i >= 0; i--, m1 -= nmv_adv ) { + m1 = (NMV)(((char *)BDY(p))+nmv_adv*(l-1)); + for ( i = l-1; i >= 0; i--, NMV_PREV(m1) ) { /* m0(NM) * m1(NMV) => tab(NM) */ - if ( mod ) - weyl_mul_nm_nmv(mod,n,m0,m1,tab,tlen); - else - weyl_mul_nm_nmv_q(n,m0,m1,tab,tlen); + weyl_mul_nm_nmv(n,mod,m0,m1,tab,tlen); for ( j = 0; j < tlen; j++ ) { if ( tab[j] ) { NEXT(tab[j]) = psum[j]; psum[j] = tab[j]; @@ -2857,14 +2821,19 @@ ND weyl_ndv_mul_nm(int mod,NM m0,NDV p) { MKND(n,psum[i],j,s); r = nd_add(mod,r,s); } - if ( s ) SG(s) = SG(p)+TD(d0); - return s; + if ( r ) SG(r) = SG(p)+TD(d0); + return r; } +/* product of monomials */ +/* XXX block order is not handled correctly */ + void weyl_mul_nm_nmv(int n,int mod,NM m0,NMV m1,NM *tab,int tlen) { - int i,n2,j,s,curlen,homo,h,a,b,k,l,min; - unsigned int *d0,*d1,*d,*ctab; + int i,n2,j,s,curlen,homo,h,a,b,k,l,u,min; + unsigned int *d0,*d1,*d,*dt,*ctab; + Q *ctab_q; + Q q,q1; unsigned int c0,c1,c; NM *p; NM m,t; @@ -2873,7 +2842,10 @@ void weyl_mul_nm_nmv(int n,int mod,NM m0,NMV m1,NM *ta if ( !m0 || !m1 ) return; d0 = DL(m0); d1 = DL(m1); n2 = n>>1; NEWNM(m); d = DL(m); - c0 = CM(m0); c1 = CM(m1); DMAR(c1,c,0,mod,c); CM(m) = c; + if ( mod ) { + c0 = CM(m0); c1 = CM(m1); DMAR(c0,c1,0,mod,c); CM(m) = c; + } else + mulq(CQ(m0),CQ(m1),&CQ(m)); for ( i = 0; i < nd_wpd; i++ ) d[i] = 0; homo = n&1 ? 1 : 0; if ( homo ) { @@ -2881,144 +2853,71 @@ void weyl_mul_nm_nmv(int n,int mod,NM m0,NMV m1,NM *ta h = GET_EXP(d0,n-1)+GET_EXP(d1,n-1); PUT_EXP(DL(m),n-1,h); TD(DL(m)) = h; - /* XXX other weights */ + if ( nd_blockmask ) ndl_set_blockweight(DL(m)); } tab[0] = m; - curlen = 1; - s = MUL_WEIGHT(a,i)+MUL_WEIGHT(b,n2+i); NEWNM(m); d = DL(m); - for ( i = 0; i < n2; i++ ) { + for ( i = 0, curlen = 1; i < n2; i++ ) { a = GET_EXP(d0,i); b = GET_EXP(d1,n2+i); k = GET_EXP(d0,n2+i); l = GET_EXP(d1,i); /* xi^a*(Di^k*xi^l)*Di^b */ a += l; b += k; + s = MUL_WEIGHT(a,i)+MUL_WEIGHT(b,n2+i); if ( !k || !l ) { for ( j = 0; j < curlen; j++ ) - if ( m = tab[j] ) { - d = DL(m); - PUT_EXP(d,i,a); PUT_EXP(d,n2+i,b); TD(d) += s; - /* XXX other weights */ + if ( t = tab[j] ) { + dt = DL(t); + PUT_EXP(dt,i,a); PUT_EXP(dt,n2+i,b); TD(dt) += s; + if ( nd_blockmask ) ndl_set_blockweight(dt); } curlen *= k+1; continue; } min = MIN(k,l); - ctab = (unsigned int *)ALLOCA((min+1)*sizeof(unsigned int)); - mkwcm(k,l,mod,ctab); - for ( j = 0; j < nd_wpd; i++ ) d[j] = 0; - p = tab+curlen; - for ( j = 1; j <= min; j++ ) { - PUT_EXP(d,i,a-j); PUT_EXP(d,n2+i,b-j); - h = s-(MUL_WEIGHT(a-j,i)+MUL_WEIGHT(b-j,n2+i)); - if ( homo ) { - TD(d) = s; - PUT_EXP(d,n-1,h); - } else TD(d) = h; - /* XXX other weights */ - c = ctab[j]; - for ( k = 0; k < curlen; k++, p++ ) { - NEWNM(t); - ndl_add(DL(tab[k]),d,DL(t)); - c0 = CM(tab[k]); DMAR(c0,c,0,mod,c1); CM(t) = c1; - *p = t; - } + if ( mod ) { + ctab = (unsigned int *)ALLOCA((min+1)*sizeof(unsigned int)); + mkwcm(k,l,mod,ctab); + } else { + ctab_q = (Q *)ALLOCA((min+1)*sizeof(Q)); + mkwc(k,l,ctab_q); } - /* destructive for j = 0 */ - PUT_EXP(d,i,a); PUT_EXP(d,n2+i,b); - h = s-(MUL_WEIGHT(a,i)+MUL_WEIGHT(b,n2+i)); - if ( homo ) { - TD(d) = s; - PUT_EXP(d,n-1,h); - } else TD(d) = h; - /* XXX other weights */ - c = ctab[0]; - p = tab; - for ( k = 0; k < curlen; k++, p++ ) { - ndl_addto(DL(tab[k]),d); - c0 = CM(tab[k]); DMAR(c0,c,0,mod,c1); CM(tab[k]) = c1; - } - curlen *= k+1; - } - FREENM(m); -} - -void weyl_mul_nm_nmv_q(int n,NM m0,NMV m1,NM *tab,int tlen) -{ - int i,n2,j,s,curlen,homo,h,a,b,k,l,min; - unsigned int *d0,*d1,*d; - Q *ctab; - Q c0,c1,c; - NM *p; - NM m,t; - - for ( i = 0; i < tlen; i++ ) tab[i] = 0; - if ( !m0 || !m1 ) return; - d0 = DL(m0); d1 = DL(m1); n2 = n>>1; - NEWNM(m); d = DL(m); - mulq(CQ(m0),CQ(m1),&CQ(m)); - for ( i = 0; i < nd_wpd; i++ ) d[i] = 0; - homo = n&1 ? 1 : 0; - if ( homo ) { - /* offset of h-degree */ - h = GET_EXP(d0,n-1)+GET_EXP(d1,n-1); - PUT_EXP(DL(m),n-1,h); - TD(DL(m)) = h; - /* XXX other weights */ - } - tab[0] = m; - curlen = 1; - s = MUL_WEIGHT(a,i)+MUL_WEIGHT(b,n2+i); - NEWNM(m); d = DL(m); - for ( i = 0; i < n2; i++ ) { - a = GET_EXP(d0,i); b = GET_EXP(d1,n2+i); - k = GET_EXP(d0,n2+i); l = GET_EXP(d1,i); - /* xi^a*(Di^k*xi^l)*Di^b */ - a += l; b += k; - if ( !k || !l ) { - for ( j = 0; j < curlen; j++ ) - if ( m = tab[j] ) { - d = DL(m); - PUT_EXP(d,i,a); PUT_EXP(d,n2+i,b); TD(d) += s; - /* XXX other weights */ - } - curlen *= k+1; - continue; - } - min = MIN(k,l); - ctab = (Q *)ALLOCA((min+1)*sizeof(Q)); - mkwc(k,l,ctab); - for ( j = 0; j < nd_wpd; i++ ) d[j] = 0; - p = tab+curlen; - for ( j = 1; j <= min; j++ ) { + for ( j = min; j >= 0; j-- ) { + for ( u = 0; u < nd_wpd; u++ ) d[u] = 0; PUT_EXP(d,i,a-j); PUT_EXP(d,n2+i,b-j); - h = s-(MUL_WEIGHT(a-j,i)+MUL_WEIGHT(b-j,n2+i)); + h = MUL_WEIGHT(a-j,i)+MUL_WEIGHT(b-j,n2+i); if ( homo ) { TD(d) = s; - PUT_EXP(d,n-1,h); + PUT_EXP(d,n-1,s-h); } else TD(d) = h; - /* XXX other weights */ - c = ctab[j]; - for ( k = 0; k < curlen; k++, p++ ) { - NEWNM(t); - ndl_add(DL(tab[k]),d,DL(t)); - mulq(CQ(tab[k]),c,&CQ(t)); - *p = t; + if ( nd_blockmask ) ndl_set_blockweight(d); + if ( mod ) c = ctab[j]; + else q = ctab_q[j]; + p = tab+curlen*j; + if ( j == 0 ) { + for ( u = 0; u < curlen; u++, p++ ) { + if ( tab[u] ) { + ndl_addto(DL(tab[u]),d); + if ( mod ) { + c0 = CM(tab[u]); DMAR(c0,c,0,mod,c1); CM(tab[u]) = c1; + } else { + mulq(CQ(tab[u]),q,&q1); CQ(tab[u]) = q1; + } + } + } + } else { + for ( u = 0; u < curlen; u++, p++ ) { + if ( tab[u] ) { + NEWNM(t); + ndl_add(DL(tab[u]),d,DL(t)); + if ( mod ) { + c0 = CM(tab[u]); DMAR(c0,c,0,mod,c1); CM(t) = c1; + } else + mulq(CQ(tab[u]),q,&CQ(t)); + *p = t; + } + } } } - /* destructive for j = 0 */ - PUT_EXP(d,i,a); PUT_EXP(d,n2+i,b); - h = s-(MUL_WEIGHT(a,i)+MUL_WEIGHT(b,n2+i)); - if ( homo ) { - TD(d) = s; - PUT_EXP(d,n-1,h); - } else TD(d) = h; - /* XXX other weights */ - c = ctab[0]; - p = tab; - for ( k = 0; k < curlen; k++, p++ ) { - ndl_addto(DL(tab[k]),d); - mulq(CQ(tab[k]),c,&CQ(tab[k])); - } curlen *= k+1; } FREENM(m); @@ -3072,7 +2971,6 @@ void ndv_realloc(NDV p,int obpe,int oadv,EPOS oepos) int len,i,k; #define NMV_OPREV(m) (m = (NMV)(((char *)m)-oadv)) -#define NMV_PREV(m) (m = (NMV)(((char *)m)-nmv_adv)) if ( p ) { m = BDY(p); len = LEN(p); @@ -3259,6 +3157,12 @@ void nd_init_ord(struct order_spec *ord) nd_isrlex = 0; ndl_compare_function = ndl_lex_compare; break; + case 11: + /* XXX */ + nd_dcomp = 0; + nd_isrlex = 1; + ndl_compare_function = ndl_ww_lex_compare; + break; default: error("nd_gr : unsupported order"); } @@ -3297,4 +3201,51 @@ BlockMask nd_create_blockmask(struct order_spec *ord) for ( j = 0; j < l; j++, s++ ) PUT_EXP(t,s,nd_mask0); } return bm; +} + +EPOS nd_create_epos(struct order_spec *ord) +{ + int i,j,l,s,ord_l,ord_o; + EPOS epos; + struct order_pair *op; + + epos = (EPOS)MALLOC_ATOMIC(nd_nvar*sizeof(struct oEPOS)); + switch ( ord->id ) { + case 0: + if ( nd_isrlex ) { + for ( i = 0; i < nd_nvar; i++ ) { + epos[i].i = nd_exporigin + (nd_nvar-1-i)/nd_epw; + epos[i].s = (nd_epw-((nd_nvar-1-i)%nd_epw)-1)*nd_bpe; + } + } else { + for ( i = 0; i < nd_nvar; i++ ) { + epos[i].i = nd_exporigin + i/nd_epw; + epos[i].s = (nd_epw-(i%nd_epw)-1)*nd_bpe; + } + } + break; + case 1: + /* block order */ + l = ord->ord.block.length; + op = ord->ord.block.order_pair; + for ( j = 0, s = 0; j < l; j++ ) { + ord_o = op[j].order; + ord_l = op[j].length; + if ( !ord_o ) + for ( i = 0; i < ord_l; i++ ) { + epos[s+i].i = nd_exporigin + (s+ord_l-i-1)/nd_epw; + epos[s+i].s = (nd_epw-((s+ord_l-i-1)%nd_epw)-1)*nd_bpe; + } + else + for ( i = 0; i < ord_l; i++ ) { + epos[s+i].i = nd_exporigin + (s+i)/nd_epw; + epos[s+i].s = (nd_epw-((s+i)%nd_epw)-1)*nd_bpe; + } + s += ord_l; + } + break; + case 2: + error("nd_create_epos : matrix order is not supported yet."); + } + return epos; }