Sums of Two Squares
In this section we apply continued fractions to prove
the following theorem.
Theorem 5.6
A positive integer
is a sum of two squares if and only if all
prime factors of
such that
have even
exponent in the prime factorization of
.
We first consider some examples. Notice that
is a sum
of two squares, but
is not a sum of two squares. Since
is
divisible by
(because
is divisible by
),
but not by
(since
is not),
Theorem 5.6.1 implies that
is not a sum of two
squares. The theorem also implies that
is a sum of two squares.
SAGE Example 5.6
We use SAGE to write a short program that
naively determines
whether or not an integer
data:image/s3,"s3://crabby-images/c5bc4/c5bc4bc772cebb80c5e3b6a5f75b2344ea6a9243" alt="$ n$"
is a sum of two squares, and if
so returns
data:image/s3,"s3://crabby-images/c019f/c019f388cac7b641ae27e865d8409bfc44ce2c8f" alt="$ a, b$"
such that
data:image/s3,"s3://crabby-images/32300/323001d26af21d7c67d3b5d1a7c61d3319998b8e" alt="$ a^2 + b^2 = n$"
.
sage: def sum_of_two_squares_naive(n):
... for i in range(int(sqrt(n))):
... if is_square(n - i^2):
... return i, (Integer(n-i^2)).sqrt()
... return "%s is not a sum of two squares"%n
We next use our function in a couple of cases.
sage: sum_of_two_squares_naive(23)
'23 is not a sum of two squares'
sage: sum_of_two_squares_naive(389)
(10, 17)
sage: sum_of_two_squares_naive(2007)
'2007 is not a sum of two squares'
sage: sum_of_two_squares_naive(2008)
'2008 is not a sum of two squares'
sage: sum_of_two_squares_naive(2009)
(28, 35)
sage: 28^2 + 35^2
2009
sage: sum_of_two_squares_naive(2*3^4*5*7^2*13)
(189, 693)
Definition 5.6 (Primitive)
A representation
data:image/s3,"s3://crabby-images/f0cca/f0ccab0650bff0c2e5c744379f50fdede0f5119c" alt="$ n=x^2 + y^2$"
is
primitive
if
data:image/s3,"s3://crabby-images/f7ff0/f7ff0af9f875c9d4cba0417271d8d9920bf6b785" alt="$ x$"
and
data:image/s3,"s3://crabby-images/bd281/bd281ed353c0af54ebb5caed32c7a58c75cb09bb" alt="$ y$"
are coprime.
Lemma 5.6
If
is divisible by a prime
, then
has no primitive representations.
Proof.
Suppose
data:image/s3,"s3://crabby-images/c5bc4/c5bc4bc772cebb80c5e3b6a5f75b2344ea6a9243" alt="$ n$"
has a primitive representation,
data:image/s3,"s3://crabby-images/f0cca/f0ccab0650bff0c2e5c744379f50fdede0f5119c" alt="$ n=x^2 + y^2$"
, and
let
data:image/s3,"s3://crabby-images/878c9/878c9d0aefee3fb4d63f6b04b1d456e38186a27c" alt="$ p$"
be any prime factor of
data:image/s3,"s3://crabby-images/c5bc4/c5bc4bc772cebb80c5e3b6a5f75b2344ea6a9243" alt="$ n$"
. Then
data:image/s3,"s3://crabby-images/4a8c7/4a8c7d104c0cf182028e51118b7dd01fa2fe6301" alt="$\displaystyle p \mid x^2 + y^2$"
and
so
data:image/s3,"s3://crabby-images/94a5e/94a5eea4a2f4243a68098dae961892ec7e5950bf" alt="$ p\nmid x$"
and
data:image/s3,"s3://crabby-images/4cbd1/4cbd15f44a2a090711b52dc2d9b8ad5b0512f127" alt="$ p\nmid y$"
.
Since
data:image/s3,"s3://crabby-images/e1257/e1257f342ba3d2a973e93aa33a97fb5ccb217d09" alt="$ \mathbb{Z}/p\mathbb{Z}{}$"
is a field we may divide by
data:image/s3,"s3://crabby-images/8b46c/8b46c301b11a4ceaabd6823364cd7bae1272d757" alt="$ y^2$"
in the equation
data:image/s3,"s3://crabby-images/f9307/f9307600082076028dd2f4edd4624cdd1f795815" alt="$ x^2 + y^2 \equiv 0\pmod{p}$"
to see that
data:image/s3,"s3://crabby-images/275e2/275e27d4ec86c2924aaef4cb3c0e6c902d47f780" alt="$ (x/y)^2 \equiv -1\pmod{p}.
$"
Thus the Legendre symbol
data:image/s3,"s3://crabby-images/5a2f2/5a2f29482e15e439425b7d97f48b5f3a42ebd08a" alt="$ \left(\frac{-1}{p}\right)$"
equals
data:image/s3,"s3://crabby-images/5bc8a/5bc8a334db930997e3b8d410f0c34c9c451fff02" alt="$ +1$"
.
However, by Proposition
4.2.1,
so
data:image/s3,"s3://crabby-images/67776/677769589ec2e36a870edc60921411da3c2bf6e6" alt="$ \left(\frac{-1}{p}\right)=1$"
if and only if
data:image/s3,"s3://crabby-images/b6c2b/b6c2b830359acb761d642fcf421ebf59ed5237ce" alt="$ (p-1)/2$"
is even, which is
to say
data:image/s3,"s3://crabby-images/6c5f7/6c5f7d82a477369b914e53dadc3f79b6e3b83244" alt="$ p\equiv 1\pmod{4}$"
.
Proof.
[Proof of Theorem
5.6.1
data:image/s3,"s3://crabby-images/73b87/73b870314ecdf3267d8dc8669c293545e988ca09" alt="$ \left(\Longrightarrow\right)$"
]
Suppose that
data:image/s3,"s3://crabby-images/dfaf2/dfaf2155add17c5efaefae2e5448457f37384075" alt="$ p\equiv 3 \pmod{4}$"
is a prime, that
data:image/s3,"s3://crabby-images/002f6/002f61efc0a337f6b7428b7d215d8c544e811ea8" alt="$ p^r\mid n$"
but
data:image/s3,"s3://crabby-images/1b7f6/1b7f65cbe51b89509538a267955a0faf0e6328ac" alt="$ p^{r+1}\nmid n$"
with
data:image/s3,"s3://crabby-images/10b7e/10b7e013f05727508ce934f857d7439e4dfbc68d" alt="$ r$"
odd, and that
data:image/s3,"s3://crabby-images/f0cca/f0ccab0650bff0c2e5c744379f50fdede0f5119c" alt="$ n=x^2 + y^2$"
. Letting
data:image/s3,"s3://crabby-images/3ff81/3ff81b22e704053c1b26f4555ebdcc96f8144af3" alt="$ d=\gcd(x,y)$"
, we have
data:image/s3,"s3://crabby-images/1a54c/1a54cad4cf6ca4957a851b23bde0aefd5449ebd4" alt="$\displaystyle x = dx', \quad y = dy',$"
and
with
data:image/s3,"s3://crabby-images/3cd3b/3cd3bff6580f935c15a36a1d636c72677bc792b5" alt="$ \gcd(x',y')=1$"
and
Because
data:image/s3,"s3://crabby-images/10b7e/10b7e013f05727508ce934f857d7439e4dfbc68d" alt="$ r$"
is odd,
data:image/s3,"s3://crabby-images/51368/513685bb1c91ede9fb4f8f4411be10cdd51e2d19" alt="$ p\mid n'$"
, so Lemma
5.6.4
implies that
data:image/s3,"s3://crabby-images/f9a58/f9a58694cc550e8f5485b25f1b9ca1e3d268d2de" alt="$ \gcd(x',y')>1$"
, a contradiction.
To prepare for our proof of
, we reduce
the problem to the case when
is prime. Write
where
has no prime factors
. It suffices to show
that
is a sum of two squares, since
data:image/s3,"s3://crabby-images/d23d1/d23d14c38e252b9ce4439080418fbaecae5d989b" alt="$\displaystyle (x_1^2 + y_1^2)(x_2^2+y_2^2) = (x_1x_2-y_1y_2)^2 + (x_1y_2+x_2y_1)^2,$" |
(5.6.1) |
so a product of two numbers that are sums of two squares is also
a sum of two squares.
Since
is a sum of two squares, it suffices to show
that any prime
is a sum of two squares.
Proof.
Consider the continued fraction
![$ [a_0, a_1, \ldots]$](img1897.png)
of
data:image/s3,"s3://crabby-images/f7ff0/f7ff0af9f875c9d4cba0417271d8d9920bf6b785" alt="$ x$"
.
By Corollary
5.2.11, for each
Since
data:image/s3,"s3://crabby-images/df484/df48491c55da1588f4dc02d7c10c0ca1859b6031" alt="$ q_{m+1}\geq q_m + 1$"
and
data:image/s3,"s3://crabby-images/31609/316098a0e341f32ab7c663d3a493e04fc634422d" alt="$ q_0=1$"
,
either there exists an
data:image/s3,"s3://crabby-images/daf97/daf97feb6cc3618d628b85779068d74ab635a5e4" alt="$ m$"
such that
data:image/s3,"s3://crabby-images/ea86d/ea86d8e58e9b09b116df2dbf34aa1e90ebac7fc9" alt="$ q_m\leq n < q_{m+1}$"
, or the
continued fraction
expansion of
data:image/s3,"s3://crabby-images/f7ff0/f7ff0af9f875c9d4cba0417271d8d9920bf6b785" alt="$ x$"
is finite and
data:image/s3,"s3://crabby-images/c5bc4/c5bc4bc772cebb80c5e3b6a5f75b2344ea6a9243" alt="$ n$"
is larger
than the denominator of the rational number
data:image/s3,"s3://crabby-images/f7ff0/f7ff0af9f875c9d4cba0417271d8d9920bf6b785" alt="$ x$"
, in which case
we take
data:image/s3,"s3://crabby-images/7c45a/7c45a5d5946e757dfac6f32cff1fe5cfa06c88f9" alt="$ \frac{a}{b}=x$"
and are done. In the first
case,
so
data:image/s3,"s3://crabby-images/47d48/47d481bae961e44380972aa41dfe848cbdabf8bd" alt="$ \displaystyle \frac{a}{b} = \frac{p_m}{q_m}$"
satisfies the conclusion of
the lemma.
Proof.
[Proof of Theorem
5.6.1
data:image/s3,"s3://crabby-images/e25d4/e25d449b701fb0b7a88b7b305bc7f1278c3556d5" alt="$ \left(\Longleftarrow\right)$"
]
As discussed above, it suffices to prove that any prime
data:image/s3,"s3://crabby-images/6c5f7/6c5f7d82a477369b914e53dadc3f79b6e3b83244" alt="$ p\equiv 1\pmod{4}$"
is a sum of two squares. Since
data:image/s3,"s3://crabby-images/6c5f7/6c5f7d82a477369b914e53dadc3f79b6e3b83244" alt="$ p\equiv 1\pmod{4}$"
,
so Proposition
4.2.1 implies that
data:image/s3,"s3://crabby-images/186db/186db8bbdf4fe4cd792fec49fd80b1f6085555c6" alt="$ -1$"
is a square modulo
data:image/s3,"s3://crabby-images/878c9/878c9d0aefee3fb4d63f6b04b1d456e38186a27c" alt="$ p$"
; i.e., there exists
data:image/s3,"s3://crabby-images/b8b7a/b8b7ac9bcc1c67d1518ed9f2958b888615d7917e" alt="$ r\in\mathbb{Z}$"
such
that
data:image/s3,"s3://crabby-images/9c6d7/9c6d71bf87ff0ac34d4065af86f9bc3309224cf0" alt="$ r^2\equiv -1\pmod{p}$"
.
Lemma
5.6.5, with
data:image/s3,"s3://crabby-images/62e0c/62e0cf718ef2507ccf2301e820a60f7a93950df6" alt="$ n=\lfloor \sqrt{p}\rfloor$"
and
data:image/s3,"s3://crabby-images/ce8b4/ce8b4ff4189ef76cd5150bc447854ffdb327d3eb" alt="$ x=-\frac{r}{p}$"
,
implies that there are integers
data:image/s3,"s3://crabby-images/c019f/c019f388cac7b641ae27e865d8409bfc44ce2c8f" alt="$ a, b$"
such that
data:image/s3,"s3://crabby-images/7fb90/7fb90bd52faa564128e262448ec2eeb9671a3797" alt="$ 0<b<\sqrt{p}$"
and
Letting
data:image/s3,"s3://crabby-images/43ebd/43ebd07d10607278d1c1b3d0be12bd4f82285d88" alt="$ c = rb + pa$"
, we have that
so
But
data:image/s3,"s3://crabby-images/b8725/b87259da4ea626f8e2235548faef1f162d5bcce3" alt="$ c \equiv rb\pmod{p}$"
, so
Thus
data:image/s3,"s3://crabby-images/194f1/194f171521cfe1c21b14cec99fa3d6ce25f380bd" alt="$ b^2 + c^2 = p$"
.
Remark 5.6
Our proof of Theorem
5.6.1 leads to an efficient
algorithm to compute a representation of any
data:image/s3,"s3://crabby-images/6c5f7/6c5f7d82a477369b914e53dadc3f79b6e3b83244" alt="$ p\equiv 1\pmod{4}$"
as a sum of two squares.
SAGE Example 5.6
We next use SAGE and Theorem
5.6.1 to
give an efficient algorithm for writing a prime
data:image/s3,"s3://crabby-images/6c5f7/6c5f7d82a477369b914e53dadc3f79b6e3b83244" alt="$ p\equiv 1\pmod{4}$"
as a sum of two squares. First we implement the algorithm
that comes out of the proof of the theorem.
sage: def sum_of_two_squares(p):
... p = Integer(p)
... assert p%4 == 1, "p must be 1 modulo 4"
... r = Mod(-1,p).sqrt().lift()
... v = continued_fraction(-r/p)
... n = floor(sqrt(p))
... for x in v.convergents():
... c = r*x.denominator() + p*x.numerator()
... if -n <= c and c <= n:
... return (abs(x.denominator()),abs(c))
Next we use the algorithm to write the first
data:image/s3,"s3://crabby-images/4f52c/4f52c75d3de14a3efe4967bd0b5f98d0a644bf10" alt="$ 10$"
-digit
prime
data:image/s3,"s3://crabby-images/90937/90937af69bab46a03dbdd1448590ead3817be0d3" alt="$ \equiv 1\pmod{4}$"
as a sum of two squares:
sage: p = next_prime(next_prime(10^10))
sage: sum_of_two_squares(p)
(55913, 82908)
The above calculation was essentially instantanoues.
If instead we use the naive algorithm from before,
it takes several seconds to write
data:image/s3,"s3://crabby-images/878c9/878c9d0aefee3fb4d63f6b04b1d456e38186a27c" alt="$ p$"
as a sum of two squares.
sage: sum_of_two_squares_naive(p)
(55913, 82908)
William
2007-06-01