Divide - Maple Help
For the best experience, we recommend viewing online help using Google Chrome or Microsoft Edge.

Online Help

Algebraic

  

Divide

  

exact divisibility check for polynomials with algebraic number coefficients

 

Calling Sequence

Parameters

Options

Description

Examples

Calling Sequence

Divide(a, b, options)

Divide(a, b, 'q', options)

Parameters

a,b

-

polynomials with algebraic number coefficients

q

-

(optional) name; will be assigned the value of the quotient  if a is divisible by b 

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, then Divide 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 divisibility is computed over an extension of the ring  of integers modulo p. The default is 'characteristic'=0 and means that the divisibility is computed over an extension of the rational numbers.

• 

Note that if p is positive but not a prime, then  is not a field, so Divide may not be able to determine whether a is divisible by b or not. 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 Divide 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 Divide command determines if a given polynomial a is exactly divisible by the polynomial b.  Formally, a is divisible by b if there exists a polynomial q such that .  a and b may be polynomials in one or more variables.

• 

The inputs a and b may contain algebraic number coefficients. These may be represented by radicals or with the RootOf notation (see type,algnum, type,radnum). In general, algebraic numbers will be returned in the same representation as they were received in. Nested radicals and RootOfs are also supported.

• 

The division property must hold in the domain K[x], where:

– 

x is the set of names in a and b which do not appear inside a RootOf or a radical.

– 

K is an algebraic field generated over the rationals and any algebraic number coefficients occurring in a and b (unless the option 'characteristic' is given; see below).

• 

Note that this function does not determine divisibility over the integers, as by default, all division is computed over the field of rationals, so true will be returned if two non-zero constants are given as input. For integer division, use iquo and irem.

• 

If the optional argument q is included and a is divisible by b, then q will be assigned the value of the quotient .  It is always guaranteed that . If a is not divisible by b, then q will not be assigned any value.

• 

Non-algebraic sub-expressions such as  that are neither variables, rational numbers, or algebraic objects are frozen and temporarily replaced by new local variables, which are not considered to be constant in what follows.

• 

The inputs a and b can even be polynomials disguised as rational functions, in which case they are normalized first using Algebraic[Normal].  

• 

If the quotient q is assigned a value, it will be normalized as follows:

– 

All non-constant factors in q 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.

– 

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 algebraic numbers occurring in the result are reduced modulo their minimal polynomial (see Reduce), and all arguments of functions, if any, are normalized recursively (see Normal).

• 

If the set of radicals and RootOfs in the input cannot be embedded into a field algebraically, then Divide may not be able to determine divisibility.  Divide 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 proceed anyway. If unsuccessful, a "reducible RootOf detected" error will be returned. (unless the option 'symbolic'=true is given; see below).

• 

This function does not support input containing floats or radical functions such as .

Examples

Introductory examples:

(1)

(2)

(3)

(4)

Note that q is not assigned a value when the output is false:

(5)

The input may contain both radicals and RootOfs, and Divide will embed the coefficients into an algebraic field, if possible:

(6)

(7)

(8)

Nested and mixed radicals and RootOfs are handled as well:

(9)

(10)

This function does not compute divisibility over the integers.  Use iquo and irem for computing integer quotients and remainders:

(11)

(12)

A polynomial will always be divisible by any non-zero integer:

(13)

Error, (in Algebraic:-Divide) numeric exception: division by zero

Non-algebraic sub-expressions such as  and other functions will be frozen and treated as variables:

(14)

(15)

However, whenever possible, such expressions will be converted to algebraic numbers.  This will result in an error if the second argument becomes zero or a zero divisor:

(16)

(17)

(18)

Error, (in Algebraic:-Divide) numeric exception: division by zero

Non-algebraic sub-expressions may end up becoming algebraic after recursive normalizing takes place:

(19)

Rational functions are usually not accepted, but if possible, Divide will normalize them into a polynomial form:

Error, (in Algebraic:-Divide) polynom(s) with radalgnum coefficients expected

Error, (in Algebraic:-Divide) polynom(s) with radalgnum coefficients expected

(20)

If it is outputted, q will also be reduced and normalized:

(21)

Algebraic functions such as  are not accepted:

Error, (in Algebraic:-Divide) polynom(s) with radalgnum coefficients expected

Floats are not accepted.

Error, (in Algebraic:-Divide) polynom(s) with radalgnum coefficients expected

When a non-indexed RootOf is given in the input, sometimes divisibility can still be determined if the quotient can be expressed in terms of the RootOf(s) in the input:

(22)

However, in the following case, Divide is unable to determine divisibility because it must know whether  represents  or  when no index is given.  In such a case, it will not throw an error, (as GreatestCommonDivisor does), but instead return false. This is because there does not exist a polynomial  with coefficients in the given algebraic extension such that  is true in all possible cases (as there was in the previous example). For this reason, it is best to use indexed RootOfs whenever possible:

(23)

(24)

(25)

If the second argument contains a zero divisor, an error will be returned. In this case, option 'symbolic'=true can be used to force Divide to select one of the substitutions and complete the computation:

Error, (in Algebraic:-Divide) numeric exception: division by zero

(26)

Error, (in Algebraic:-Divide) reducible RootOf detected. Substitutions are {RootOf(_Z^2-_Z) = 0, RootOf(_Z^2-_Z) = 1}

(27)

Using option 'characteristic', divisibility can be checked over finite fields:

(28)

(29)

(30)

In composite characteristic, Divide cannot always determine divisibility, and will return an error if it encounters a zero divisor:

(31)

Error, (in Algebraic:-Divide) zero divisor modulo 10 detected

With option 'makeindependent'=true, the input will be checked for algebraic dependencies even if there are more than  algebraic objects in the input:

(32)

(33)

(34)

(35)

(36)

(37)

(38)

(39)

With option 'makeindependent'=false, the input will never be checked for algebraic dependencies:

(40)

(41)

See Also

Algebraic

Algebraic[PseudoDivision]

Algebraic[Quotient]

Algebraic[Remainder]

Divide

 


Download Help Document