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/38c64/38c642b24a58d464653328e3aca9f42019f2003d" alt="$ n$"
is a sum of two squares, and if
so returns
data:image/s3,"s3://crabby-images/09da3/09da3b2af9a6b1efb9b7874cc27ed66be5aa751b" alt="$ a, b$"
such that
data:image/s3,"s3://crabby-images/bf463/bf463f3a90d09ccdb05b4d40c94cb3854f929bab" 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/b7b1f/b7b1fed9a3bd0c29f6c285fc1c96417c134007f7" alt="$ n=x^2 + y^2$"
is
primitive
if
data:image/s3,"s3://crabby-images/0a320/0a320f137d9311699386ee439d90614c424a57e3" alt="$ x$"
and
data:image/s3,"s3://crabby-images/acf06/acf06e202ed420b9b6b8a9b167ac7e262fb216ce" 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/38c64/38c642b24a58d464653328e3aca9f42019f2003d" alt="$ n$"
has a primitive representation,
data:image/s3,"s3://crabby-images/b7b1f/b7b1fed9a3bd0c29f6c285fc1c96417c134007f7" alt="$ n=x^2 + y^2$"
, and
let
data:image/s3,"s3://crabby-images/56c61/56c61b4f72ec86661c34b86478fae7dc83441d29" alt="$ p$"
be any prime factor of
data:image/s3,"s3://crabby-images/38c64/38c642b24a58d464653328e3aca9f42019f2003d" alt="$ n$"
. Then
data:image/s3,"s3://crabby-images/a3668/a3668f070b5ea5ff7afc927532bec19d0c772066" alt="$\displaystyle p \mid x^2 + y^2$"
and
so
data:image/s3,"s3://crabby-images/9cea2/9cea2214cdcdeb5510679fb6e307cce379b03932" alt="$ p\nmid x$"
and
data:image/s3,"s3://crabby-images/fa24e/fa24e3cde7b4223bc03c2a99d6b93755471bcefe" alt="$ p\nmid y$"
.
Since
data:image/s3,"s3://crabby-images/d5b01/d5b01ad7e50b80e71a0113abb9144fbfe701ca5f" alt="$ \mathbb{Z}/p\mathbb{Z}{}$"
is a field we may divide by
data:image/s3,"s3://crabby-images/9fa4f/9fa4fdf04172a2da5f2cdd9e9fa932927e364cf2" alt="$ y^2$"
in the equation
data:image/s3,"s3://crabby-images/cf7f8/cf7f8fb0a99f41a04238fa8b65a3ba7f9af35dd3" alt="$ x^2 + y^2 \equiv 0\pmod{p}$"
to see that
data:image/s3,"s3://crabby-images/8d166/8d166785a8808a43f7f02b6de445eb5e596849ee" alt="$ (x/y)^2 \equiv -1\pmod{p}.
$"
Thus the Legendre symbol
data:image/s3,"s3://crabby-images/f76ee/f76eebab3c6dd500860f8baae5a0a77672ade5be" alt="$ \left(\frac{-1}{p}\right)$"
equals
data:image/s3,"s3://crabby-images/e82d5/e82d59df0ac6603d3f0521b91e8f7248c0f692c1" alt="$ +1$"
.
However, by Proposition
4.2.1,
so
data:image/s3,"s3://crabby-images/f0559/f05598274a7528ecfff1b7367a003892a2ca3a05" alt="$ \left(\frac{-1}{p}\right)=1$"
if and only if
data:image/s3,"s3://crabby-images/39ded/39ded02d0ab548ada593016041db5c905350dda1" alt="$ (p-1)/2$"
is even, which is
to say
data:image/s3,"s3://crabby-images/08882/08882ee88991c71d89de12d7c67296b1386d200d" alt="$ p\equiv 1\pmod{4}$"
.
Proof.
[Proof of Theorem
5.6.1
data:image/s3,"s3://crabby-images/da62c/da62cab425d1d4f0ed77c8e3bdf1ae8be83ce621" alt="$ \left(\Longrightarrow\right)$"
]
Suppose that
data:image/s3,"s3://crabby-images/f6ae2/f6ae2556907e493c57f3ef8e3d93d30303b7a444" alt="$ p\equiv 3 \pmod{4}$"
is a prime, that
data:image/s3,"s3://crabby-images/ebb1c/ebb1c8db78cfd3e482cbd6ca7c18cb2ddc60205d" alt="$ p^r\mid n$"
but
data:image/s3,"s3://crabby-images/4cf4e/4cf4e07811d47b87befeb186ff93a729be69d7f9" alt="$ p^{r+1}\nmid n$"
with
data:image/s3,"s3://crabby-images/ffaa3/ffaa3f72d5fc2796615fe8d14fe69a1992613147" alt="$ r$"
odd, and that
data:image/s3,"s3://crabby-images/b7b1f/b7b1fed9a3bd0c29f6c285fc1c96417c134007f7" alt="$ n=x^2 + y^2$"
. Letting
data:image/s3,"s3://crabby-images/3f478/3f478b3939889e6ab2e924871cf0d0cdfb961c83" alt="$ d=\gcd(x,y)$"
, we have
data:image/s3,"s3://crabby-images/27b01/27b0187083c126c1619b75bd69b0698ac53d3a1f" alt="$\displaystyle x = dx', \quad y = dy',$"
and
with
data:image/s3,"s3://crabby-images/461fa/461fad2cd3ea514323626cd1309b66aef7820916" alt="$ \gcd(x',y')=1$"
and
Because
data:image/s3,"s3://crabby-images/ffaa3/ffaa3f72d5fc2796615fe8d14fe69a1992613147" alt="$ r$"
is odd,
data:image/s3,"s3://crabby-images/cddc9/cddc90db4ec073dca3f09f5f9b7aa209005853bc" alt="$ p\mid n'$"
, so Lemma
5.6.4
implies that
data:image/s3,"s3://crabby-images/cd6d1/cd6d1c3884c19c66d0710b5696d7f595da14b375" 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/cdbf5/cdbf5778e1d987efe2928d500e4b3292b75d6a61" 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/0a320/0a320f137d9311699386ee439d90614c424a57e3" alt="$ x$"
.
By Corollary
5.2.11, for each
Since
data:image/s3,"s3://crabby-images/b22e5/b22e5850b61e2f418be7c52aff9258a935a3a3da" alt="$ q_{m+1}\geq q_m + 1$"
and
data:image/s3,"s3://crabby-images/058ee/058eefbe1406988bcfa04eff92f5af62b22ff780" alt="$ q_0=1$"
,
either there exists an
data:image/s3,"s3://crabby-images/253eb/253eb2c21563c2db208d024b8b1ac8d38fc2be9a" alt="$ m$"
such that
data:image/s3,"s3://crabby-images/2770c/2770ca3903ed11f3241ae39588eea2109e8b4ed0" alt="$ q_m\leq n < q_{m+1}$"
, or the
continued fraction
expansion of
data:image/s3,"s3://crabby-images/0a320/0a320f137d9311699386ee439d90614c424a57e3" alt="$ x$"
is finite and
data:image/s3,"s3://crabby-images/38c64/38c642b24a58d464653328e3aca9f42019f2003d" alt="$ n$"
is larger
than the denominator of the rational number
data:image/s3,"s3://crabby-images/0a320/0a320f137d9311699386ee439d90614c424a57e3" alt="$ x$"
, in which case
we take
data:image/s3,"s3://crabby-images/40888/40888e8217ded407f5180e80409972180cbcf010" alt="$ \frac{a}{b}=x$"
and are done. In the first
case,
so
data:image/s3,"s3://crabby-images/78fbc/78fbc9cd060932f2f8af8b7947dcd6e7a3f05b60" 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/22fe8/22fe8df145585146860c3b8bfe8945949a140469" alt="$ \left(\Longleftarrow\right)$"
]
As discussed above, it suffices to prove that any prime
data:image/s3,"s3://crabby-images/08882/08882ee88991c71d89de12d7c67296b1386d200d" alt="$ p\equiv 1\pmod{4}$"
is a sum of two squares. Since
data:image/s3,"s3://crabby-images/08882/08882ee88991c71d89de12d7c67296b1386d200d" alt="$ p\equiv 1\pmod{4}$"
,
so Proposition
4.2.1 implies that
data:image/s3,"s3://crabby-images/1e56b/1e56bf9eb716f60ec69cc4953537c0d4ec2f5d1a" alt="$ -1$"
is a square modulo
data:image/s3,"s3://crabby-images/56c61/56c61b4f72ec86661c34b86478fae7dc83441d29" alt="$ p$"
; i.e., there exists
data:image/s3,"s3://crabby-images/b9c63/b9c63c4c04bdef1763e44f1cdbc7c1d58f2995b0" alt="$ r\in\mathbb{Z}$"
such
that
data:image/s3,"s3://crabby-images/755f8/755f86a29decbee0833a3c0f173d89f9af7c8254" alt="$ r^2\equiv -1\pmod{p}$"
.
Lemma
5.6.5, with
data:image/s3,"s3://crabby-images/2b066/2b066d45466870ccecc3aaed8e1b0f6cf5025f8d" alt="$ n=\lfloor \sqrt{p}\rfloor$"
and
data:image/s3,"s3://crabby-images/610e2/610e24b033ded71ecc4b3aad8f751e4a03266538" alt="$ x=-\frac{r}{p}$"
,
implies that there are integers
data:image/s3,"s3://crabby-images/09da3/09da3b2af9a6b1efb9b7874cc27ed66be5aa751b" alt="$ a, b$"
such that
data:image/s3,"s3://crabby-images/e6c5d/e6c5dbb7d7fa6fcc087530ffb39e1fc17456899e" alt="$ 0<b<\sqrt{p}$"
and
Letting
data:image/s3,"s3://crabby-images/66be0/66be031c5e3063768c2e5aebc5b3bfa8b556f683" alt="$ c = rb + pa$"
, we have that
so
But
data:image/s3,"s3://crabby-images/15599/15599103e5a914891b5abadea585360d156743c4" alt="$ c \equiv rb\pmod{p}$"
, so
Thus
data:image/s3,"s3://crabby-images/1630e/1630e037db470d999c208ade9eb372f49c19679b" 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/08882/08882ee88991c71d89de12d7c67296b1386d200d" 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/08882/08882ee88991c71d89de12d7c67296b1386d200d" 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/bd0bb/bd0bbef84ba8de5ac561a085601529561da9f4f0" alt="$ 10$"
-digit
prime
data:image/s3,"s3://crabby-images/116dd/116ddf68445992f6e78bf5ab5339957ff857d1b3" 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/56c61/56c61b4f72ec86661c34b86478fae7dc83441d29" alt="$ p$"
as a sum of two squares.
sage: sum_of_two_squares_naive(p)
(55913, 82908)
William
2007-06-01