|
Calling Sequence
|
|
GreatestCommonDivisor(a, b, options)
GreatestCommonDivisor(a, b, 'ca', 'cb', options)
Gcd(a, b, options)
Gcd(a, b, 'ca', 'cb', options)
|
|
Parameters
|
|
a,b
|
-
|
polynomials with algebraic number coefficients
|
ca,cb
|
-
|
names; will be assigned the cofactors
|
options
|
-
|
(optional) equation(s) of the form keyword = value, where keyword is either 'symbolic', 'makeindependent', or 'characteristic'
|
|
|
|
|
Options
|
|
•
|
If the option 'symbolic'=true is given and a RootOf whose minimal polynomial factors nontrivially is detected, GreatestCommonDivisor will reduce it to a RootOf of lower degree by picking one of the factors arbitrarily. This will eliminate the possibility of a "reducible RootOf detected" error. The default is 'symbolic'=false.
|
•
|
If the option characteristic=p is given, where p is a nonnegative integer, the gcd is computed over an extension of the ring of integers modulo p. The default is characteristic=0 and means that the gcd is computed over an extension of the rational numbers.
|
•
|
Note that if p is positive but not a prime, then is not a field, and the greatest common divisor may not exist or may not be unique. GreatestCommonDivisor will attempt to compute a gcd anyway. If it does not succeed because it encounters an integer that has no inverse modulo p, it issues the error "zero divisor modulo p detected".
|
•
|
If the option 'makeindependent'=true is given, then GreatestCommonDivisor will always try to find a field representation for algebraic numbers in the input, regardless of how many algebraic objects the input contains. If the input contains many RootOfs, then this can be a very expensive calculation. If 'makeindependent'=false is given, then no independence checking is performed. The default is 'makeindependent'=FAIL, in which case algebraic dependencies will only be checked for if there are or fewer algebraic objects in the input.
|
|
|
Description
|
|
•
|
The GreatestCommonDivisor command computes the greatest common divisor of two (multivariate) polynomials whose coefficients contain radicals or RootOfs representing algebraic numbers.
|
•
|
The inputs a and b can be polynomials disguised as rational functions, in which case they are normalized first using Algebraic[Normal].
|
•
|
The inputs may even contain non-algebraic subexpressions such as that are neither variables, numbers, or algebraic objects. These will be frozen and temporarily replaced by new local variables.
|
•
|
This command preserves partial factorizations in the input and expands polynomials only if necessary.
|
•
|
All non-constant factors in the gcd returned are monic with respect to a block-lexicographic ordering of the variables, where all global variables are considered larger than all local ones. If all variables have different names, then this ordering is session-independent.
|
•
|
All radicals and powers of RootOfs in the gcd returned are reduced with respect to their respective minimal polynomials. That is, every radical is of the form , where is a rational number, and every integer exponent in a power of the form satisfies .
|
•
|
Note that GreatestCommonDivisor cannot be used to compute the gcd of two constants, e.g., in the ring of integers of an algebraic number field. It returns for the gcd of two nonzero constants.
|
•
|
If the set of radicals and RootOfs in the inputs cannot be embedded into a field algebraically, the greatest common divisor may not always exist or may not be unique. GreatestCommonDivisor will try to find a field representation if there are at most algebraic objects in the input (unless option 'makeindependent' is given; see below), and otherwise attempt to compute a greatest common divisor anyway. If it does not succeed, it issues the error "reducible RootOf detected", unless the option 'symbolic'=true is given (see below).
|
•
|
If the optional arguments 'ca' and 'cb' are given, they are assigned the values of the cofactors and , respectively, where is the gcd.
|
•
|
The cofactors are normalized as follows:
|
–
|
The leading coefficients, with respect to the same block-lexicographic ordering as described above, of all non-constant factors are positive integers (except possibly if there is only one non-constant factor).
|
–
|
There are at most two constant factors, and at most one of them is not a rational number.
|
–
|
All factors that are not rational numbers have integer content equal to , except possibly if there is only one non-constant factor.
|
–
|
All radicals and powers of RootOfs are reduced with respect to their respective minimal polynomials, as described above.
|
|
|
Examples
|
|
Introductory examples:
>
|
|
>
|
|
>
|
|
>
|
|
| (3) |
| (4) |
>
|
|
Polynomials disguised as rational functions are accepted, but true rational functions are not. Neither are algebraic functions or floating point numbers in the coefficients:
>
|
|
>
|
|
>
|
|
>
|
|
Non-algebraic subexpressions are frozen and replaced by new variables:
>
|
|
Partial factorizations in the inputs are preserved:
>
|
|
>
|
|
| (8) |
>
|
|
| (9) |
The gcd of two nonzero constants is always :
>
|
|
There is no way for GreatestCommonDivisor to know whether without an index represents or . Option 'symbolic'=true picks in this case:
>
|
|
>
|
|
>
|
|
An example where the gcd can be computed even though there is a non-indexed reducible RootOf:
>
|
|
>
|
|
Using option 'characteristic', gcds over finite fields can be computed:
>
|
|
>
|
|
>
|
|
In contrast to characteristic , the complex number , radicals, and indexed RootOfs are not uniquely defined in positive characteristic, and they are treated as if they were non-indexed RootOfs:
>
|
|
>
|
|
The gcd cannot always be computed in composite characteristic:
>
|
|
>
|
|
With option 'makeindependent'=true, the input will be checked for algebraic dependencies even if there are more than algebraic objects in the input:
>
|
|
| (20) |
>
|
|
| (21) |
>
|
|
| (22) |
>
|
|
| (23) |
>
|
|
| (24) |
>
|
|
| (25) |
>
|
|
Error, (in Algebraic:-GreatestCommonDivisor) reducible RootOf detected. Substitutions are {RootOf(_Z^3+4,index = 1) = 1/2*RootOf(_Z^3-4,index = 1)^2*RootOf(_Z^3+2,index = 1), RootOf(_Z^3+4,index = 1) = RootOf(RootOf(_Z^3-4,index = 1)^2*RootOf(_Z^3+2,index = 1)*_Z-2*RootOf(_Z^3-4,index = 1)^2+2*_Z^2+4*RootOf(_Z^3+2,index = 1))}
| |
>
|
|
| (26) |
With option 'makeindependent'=false, the input will never be checked for algebraic dependencies:
>
|
|
| (27) |
>
|
|
Error, (in Algebraic:-GreatestCommonDivisor) reducible RootOf detected. Substitutions are {RootOf(_Z^3-2,index = 1) = 1/3*RootOf(_Z^3-6,index = 1)*RootOf(_Z^3-3,index = 1)^2, RootOf(_Z^3-2,index = 1) = RootOf(RootOf(_Z^3-6,index = 1)*RootOf(_Z^3-3,index = 1)^2*_Z+RootOf(_Z^3-6,index = 1)^2*RootOf(_Z^3-3,index = 1)+3*_Z^2)}
| |
|
|
|