version 1.6, 2000/12/13 05:37:31 |
version 1.9, 2000/12/14 09:36:17 |
|
|
* 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/lib/bfct,v 1.5 2000/12/11 02:00:42 noro Exp $ |
* $OpenXM: OpenXM_contrib2/asir2000/lib/bfct,v 1.8 2000/12/14 09:13:37 noro Exp $ |
*/ |
*/ |
/* requires 'primdec' */ |
/* requires 'primdec' */ |
|
|
|
|
def ann(F) |
def ann(F) |
{ |
{ |
V = vars(F); |
V = vars(F); |
W = append([y1,y2,t],V); |
|
N = length(V); |
N = length(V); |
B = [1-y1*y2,t-y1*F]; |
D = newvect(N); |
|
|
|
for ( I = 0; I < N; I++ ) |
|
D[I] = [deg(F,V[I]),V[I]]; |
|
qsort(D,compare_first); |
|
for ( V = [], I = N-1; I >= 0; I-- ) |
|
V = cons(D[I][1],V); |
|
|
for ( I = N-1, DV = []; I >= 0; I-- ) |
for ( I = N-1, DV = []; I >= 0; I-- ) |
DV = cons(strtov("d"+rtostr(V[I])),DV); |
DV = cons(strtov("d"+rtostr(V[I])),DV); |
|
|
|
W = append([y1,y2,t],V); |
DW = append([dy1,dy2,dt],DV); |
DW = append([dy1,dy2,dt],DV); |
|
|
|
B = [1-y1*y2,t-y1*F]; |
for ( I = 0; I < N; I++ ) { |
for ( I = 0; I < N; I++ ) { |
B = cons(DV[I]+y1*diff(F,V[I])*dt,B); |
B = cons(DV[I]+y1*diff(F,V[I])*dt,B); |
} |
} |
|
|
return G4; |
return G4; |
} |
} |
|
|
def indicial1(F) |
def indicial1(F,V) |
{ |
{ |
V = vars(F); |
|
W = append([y1,t],V); |
W = append([y1,t],V); |
N = length(V); |
N = length(V); |
B = [t-y1*F]; |
B = [t-y1*F]; |
|
|
B = cons(DV[I]+y1*diff(F,V[I])*dt,B); |
B = cons(DV[I]+y1*diff(F,V[I])*dt,B); |
} |
} |
dp_nelim(1); |
dp_nelim(1); |
G0 = dp_weyl_gr_main(B,append(W,DW),0,0,6); |
/* we use homogenization (heuristically determined) */ |
|
G0 = dp_weyl_gr_main(B,append(W,DW),1,0,6); |
G1 = map(subst,G0,y1,1); |
G1 = map(subst,G0,y1,1); |
Mat = newmat(2,2,[[-1,1],[0,1]]); |
Mat = newmat(2,2,[[-1,1],[0,1]]); |
G2 = map(psi,G1,t,dt); |
G2 = map(psi,G1,t,dt); |
Line 140 def compare_first(A,B) |
|
Line 150 def compare_first(A,B) |
|
|
|
def bfct(F) |
def bfct(F) |
{ |
{ |
G4 = indicial1(F); |
|
V = vars(F); |
V = vars(F); |
N = length(V); |
N = length(V); |
D = newvect(N); |
D = newvect(N); |
|
|
for ( I = 0; I < N; I++ ) |
for ( I = 0; I < N; I++ ) |
D[I] = [deg(F,V[I]),V[I]]; |
D[I] = [deg(F,V[I]),V[I]]; |
qsort(D,compare_first); |
qsort(D,compare_first); |
|
|
for ( I = N-1, DV = []; I >= 0; I-- ) |
for ( I = N-1, DV = []; I >= 0; I-- ) |
DV = cons(strtov("d"+rtostr(V[I])),DV); |
DV = cons(strtov("d"+rtostr(V[I])),DV); |
V1 = cons(s,V); DV1 = cons(ds,DV); |
V1 = cons(s,V); DV1 = cons(ds,DV); |
G0 = dp_weyl_gr_main(G4,append(V1,DV1),0,1,0); |
|
Minipoly = weyl_minipoly(G0,append(V1,DV1),0,s); |
G0 = indicial1(F,reverse(V)); |
|
G1 = dp_weyl_gr_main(G0,append(V1,DV1),0,1,0); |
|
Minipoly = weyl_minipoly(G1,append(V1,DV1),0,s); |
return Minipoly; |
return Minipoly; |
} |
} |
|
|
Line 238 def weyl_gennf(G,TL,V,O) |
|
Line 250 def weyl_gennf(G,TL,V,O) |
|
NF = remove_cont(NF); |
NF = remove_cont(NF); |
H = cons(NF,H); |
H = cons(NF,H); |
} |
} |
print(""); |
if ( dp_gr_print() ) print(""); |
TNF = time()[0]-T0; |
TNF = time()[0]-T0; |
if ( dp_gr_print() ) |
if ( dp_gr_print() ) |
print("gennf(TAB="+rtostr(TTAB)+" NF="+rtostr(TNF)+")"); |
print("gennf(TAB="+rtostr(TTAB)+" NF="+rtostr(TNF)+")"); |
Line 291 def weyl_nf_mod(B,G,PS,Mod) |
|
Line 303 def weyl_nf_mod(B,G,PS,Mod) |
|
|
|
def weyl_hen_ttob(T,NF,LHS,V,MOD) |
def weyl_hen_ttob(T,NF,LHS,V,MOD) |
{ |
{ |
if ( length(T) == 1 ) |
|
return car(T); |
|
T0 = time()[0]; M = etom(weyl_leq_nf(T,NF,LHS,V)); TE = time()[0] - T0; |
T0 = time()[0]; M = etom(weyl_leq_nf(T,NF,LHS,V)); TE = time()[0] - T0; |
T0 = time()[0]; U = henleq(M,MOD); TH = time()[0] - T0; |
T0 = time()[0]; U = henleq(M,MOD); TH = time()[0] - T0; |
if ( dp_gr_print() ) { |
if ( dp_gr_print() ) { |