/usr/share/axiom-20170501/src/algebra/FACTEXT.spad is in axiom-source 20170501-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 | )abbrev package FACTEXT FactorisationOverPseudoAlgebraicClosureOfAlgExtOfRationalNumber
++ Author: Gaetan Hache
++ Date Created: September 1996
++ Date Last Updated: May, 2010, by Tim Daly
++ Description:
++ Part of the Package for Algebraic Function Fields in one variable PAFF
FactorisationOverPseudoAlgebraicClosureOfAlgExtOfRationalNumber(K) : SIG == CODE where
K : PseudoAlgebraicClosureOfAlgExtOfRationalNumberCategory
SUP ==> SparseUnivariatePolynomial
Q ==> PseudoAlgebraicClosureOfRationalNumber
NNI ==> NonNegativeInteger
UP ==> SUP(K)
UPUP ==> SUP(SUP(K))
FACTRNQ ==> FactorisationOverPseudoAlgebraicClosureOfRationalNumber(Q)
SIG ==> with
factor : (UP,K) -> Factored UP
factorSqFree : (UP,K) -> Factored UP
CODE ==> add
up2Rat: UP -> SUP(Q)
rat2up: SUP(Q) -> UP
factRat: UP -> Factored UP
liftPoly: (UP, K) -> UPUP
liftDefPoly: UP -> UPUP
norm: (UP, K) -> UP
factParPert: ( UP,K,K) -> Factored UP
trans: (UP, K) -> UP
swapCoefWithVar: ( UP , NNI) -> UPUP
frRat2frUP: Factored SUP(Q) -> Factored UP
factor(pol,a)==
polSF:= squareFree pol
reduce("*" , [ factorSqFree(fr.fctr,a)**(fr.xpnt pretend NNI) _
for fr in factorList polSF] , 1)
factorSqFree(pol,a)==
ratPol:SUP(Q)
aa:Q
ground? a =>
aa:= retract(a)@Q
ratPol:= up2Rat pol
frRat2frUP factor(ratPol,aa)$FACTRNQ::Factored UP
nPol:= norm(pol,a)
ta:=previousTower a
factN := factor( nPol , ta )
lfactnPol:= factorList factN
G:UP:=1
L: Factored UP:= 1
for fr in lfactnPol repeat
G:= gcd( [ pol , fr.fctr ] )
pol:= pol quo$UP G
if one? fr.xpnt then
L := L * flagFactor( G, 1 ,"prime")$Factored(UP)
else
L := L * factParPert( G, a, a )
L
factParPert(pol, a, b)==
polt:=trans(pol,b)
frpol:= factorList factor(polt,a)
sl:= [ fr.fctr for fr in frpol ]
slt:= [ trans(p , -b) for p in sl ]
nfrpol:= [ flagFactor( p, fr.xpnt , fr.flg )$Factored(UP) _
for p in slt for fr in frpol ]
reduce("*" , nfrpol)
frRat2frUP(fr)==
frpol:= factorList fr
sl:= [ fr.fctr for fr in frpol ]
slt:= [ rat2up p for p in sl ]
nfrpol:= [ flagFactor( p, fr.xpnt , fr.flg )$Factored(UP) _
for p in slt for fr in frpol ]
reduce("*" , nfrpol)
up2Rat(pol)==
zero?(pol) => 0
d:=degree pol
a:Q:= retract(leadingCoefficient pol)@Q
monomial(a,d)$SUP(Q) + up2Rat(reductum pol)
rat2up(pol)==
zero?(pol) => 0
d:=degree pol
a:K:=(leadingCoefficient pol) :: K
monomial(a,d)$UP + rat2up(reductum pol)
trans(pol,a)==
zero? pol => 0
lc:=leadingCoefficient pol
d:=degree pol
lc*(monomial(1,1)$UP + monomial(-a ,0)$UP)**d + trans(reductum pol ,a)
liftDefPoly(pol)==
zero?(pol) => 0
lc:= leadingCoefficient pol
d:= degree pol
monomial( monomial(lc,0)$UP , d )$UPUP + liftDefPoly reductum pol
norm(pol,a)==
lpol:=liftPoly(pol,a)
defPol:=definingPolynomial a
ldefPol:=liftDefPoly defPol
resultant(ldefPol,lpol)
swapCoefWithVar(coef,n)==
ground? coef =>
monomial( monomial( retract coef , n)$SUP(K) , 0)$UPUP
lcoef:=leadingCoefficient(coef)
d:=degree(coef)
monomial(monomial(lcoef,n)$SUP(K),d)$UPUP+_
swapCoefWithVar(reductum coef,n )
liftPoly(pol,a)==
zero? pol => 0
lcoef:=leadingCoefficient pol
n:=degree pol
liftCoef:= lift(lcoef,a)$K
swapCoefWithVar(liftCoef , n) + liftPoly( reductum pol , a )
|