Next: Relation between gcds in [x]
Up: Advanced Computer Algebra: The resultant
Previous: Advanced Computer Algebra: The resultant
We saw in the first chapter that running the Euclidean
Algorithm in
[x] can lead to a significant expression swell.
Let us try to estimate how coefficients grow.
That is, we want to estimate the maximal space
needed to store one coefficient of an intermediate polynomial.
Let N be the number of bits of a machine word.
Definition 1
For an integer
a
data:image/s3,"s3://crabby-images/7e863/7e8639b6ee19b2a752a78ce1dbc84678dcef9756" alt="$ \mbox{${\mathbb Z}$}$"
we define
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
a) the
length of
a as the minimum number of words to encode
a.
Hence for
a data:image/s3,"s3://crabby-images/2c385/2c38541be95e2b0c3fb7b589b39b2bb2fc33bb96" alt="$ \neq$"
0 we have
(a) = log2(a)/N + 1 and (0) = 0 |
(1) |
For a rational number
a =
b/
c with
b,
c
data:image/s3,"s3://crabby-images/7e863/7e8639b6ee19b2a752a78ce1dbc84678dcef9756" alt="$ \mbox{${\mathbb Z}$}$"
and
gcd(
c,
d )= 1
we define
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
a), the
length of
a, as the maximum
among
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
b) and
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
c).
Definition 2
For a polynomial
a
data:image/s3,"s3://crabby-images/1ffbd/1ffbdb27cc0d38eba3c5a631b5d996c4db6245ce" alt="$ \mbox{${\mathbb Q}$}$"
[
x] of degree
n data:image/s3,"s3://crabby-images/76c4d/76c4df69dc5146b785c8ced8715c5f5f69086554" alt="$ \geq$"
0
such that all coefficients have denominator
b and such that the
numerators
an,
an-1,...,
a1,
a0 have gcd 1
then we define the
length of
a as
(a) = max( (b), ( (ai))) |
(2) |
Remark 1
A polynomial
a
[x] of degree n
0
can be represented with
words.
Proposition 2
Let
a,
b be univariate polynomials over
data:image/s3,"s3://crabby-images/7e863/7e8639b6ee19b2a752a78ce1dbc84678dcef9756" alt="$ \mbox{${\mathbb Z}$}$"
in
x.
We assume that
a and
b are monic and that
deg(
a) = deg(
b) + 1 holds.
Let
q and
r be the quotient and the remainder of
a w.r.t.
b.
Then we have
Proof.
We define
a = xn + an-1xn-1 + ... + a0 and b = xn-1 + bn-2xn-2 + ... + b0 |
(5) |
It is not hard to see that
Then
Thus
(bq) max( (a), (b)) + 1 + (b) + (deg(q) + 1) |
(8) |
Recall that
Since
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
bq)
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
a) we obtain
(r) |
data:image/s3,"s3://crabby-images/aefc1/aefc167f1b503e34b2e59041dd747ace8587e487" alt="$\displaystyle \leq$" |
max( (a), (b)) + 1 + (b) + (deg(q) + 1) + 1 |
|
data:image/s3,"s3://crabby-images/aefc1/aefc167f1b503e34b2e59041dd747ace8587e487" alt="$\displaystyle \leq$" |
(a) + 2 (b) + 3 |
|
(10) |
Indeed
max(
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
a),
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
b))
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
a) +
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(
b)
and
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(deg(
q) + 1) =
data:image/s3,"s3://crabby-images/ff457/ff457147a2ad9380928ab0fa9eb4636a691c31a3" alt="$ \lambda$"
(2)
data:image/s3,"s3://crabby-images/41f68/41f683fdd86dc1807bb3ba348a83e0cbd75affe0" alt="$ \leq$"
1.
Remark 2
A similar result as Proposition 2
holds for monic polynomials
a, b
[x] such that
deg(a) = deg(b) + 1.
See [vzGG99].
These results provide us with an exponential upper bound for the
coefficient of the gcd computed by the Euclidean Algorithm.
But in fact a polynomial bound can be established.
Moreover there is an efficient modular approach for computing gcds in
[x] and
[x]
as we shall see in the next sections.
Next: Relation between gcds in [x]
Up: Advanced Computer Algebra: The resultant
Previous: Advanced Computer Algebra: The resultant
Marc Moreno Maza
2003-06-06