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/e9cb7/e9cb71cabdb5a31b0bbea7da20f4c0ff9c681a30" alt="$ \mbox{${\mathbb Z}$}$"
we define
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" 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/02eaf/02eaf0db28dc09bcadc1a20b2ce3b87dcdd46436" 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/e9cb7/e9cb71cabdb5a31b0bbea7da20f4c0ff9c681a30" alt="$ \mbox{${\mathbb Z}$}$"
and
gcd(
c,
d )= 1
we define
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
a), the
length of
a, as the maximum
among
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
b) and
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
c).
Definition 2
For a polynomial
a
data:image/s3,"s3://crabby-images/3ffa1/3ffa12c7bc4d4c7b87b63e96602a3fc0edb4be41" alt="$ \mbox{${\mathbb Q}$}$"
[
x] of degree
n data:image/s3,"s3://crabby-images/1f3cf/1f3cf1e8de789d4aeb5d61443c373f93d7924449" 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/e9cb7/e9cb71cabdb5a31b0bbea7da20f4c0ff9c681a30" 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/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
bq)
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
a) we obtain
(r) |
data:image/s3,"s3://crabby-images/9d954/9d95446188d2a4409041164c628f7eaad63feeff" alt="$\displaystyle \leq$" |
max( (a), (b)) + 1 + (b) + (deg(q) + 1) + 1 |
|
data:image/s3,"s3://crabby-images/9d954/9d95446188d2a4409041164c628f7eaad63feeff" alt="$\displaystyle \leq$" |
(a) + 2 (b) + 3 |
|
(10) |
Indeed
max(
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
a),
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
b))
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
a) +
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(
b)
and
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(deg(
q) + 1) =
data:image/s3,"s3://crabby-images/e0d65/e0d65f388c9b631b4d35be3c0f7702aa432af647" alt="$ \lambda$"
(2)
data:image/s3,"s3://crabby-images/9c1c3/9c1c3f6a2a194620acce5749e63d6ad385043e23" 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
2004-04-27