China Post 3: The Euclidean algorithm
by t0rajir0u, Jul 28, 2008, 1:45 PM
Part of this post is more "textbook" than the flavor of my latest entries, especially the part dealing with continued fractions. This is largely due to the fact that it seems to me that certain facts in the basic theory are not, I think, as well-known as they deserve to be. Part of this post also rambles a lot; I think this is the longest one to date.
The basic idea of the extended Euclidean algorithm on integers is extraordinarily simple, and yet it is one of the fundamental properties of the integers that allow for unique prime factorization and its existence in an arbitrary ring of integers is still the easiest way to prove unique prime factorization there. As we will see, it has even more interesting consequences (which we will illustrate by reformulating its statement five times!) but first we shall work through a large example. (In the rest of this post the Euclidean algorithm always refers to the relatively prime case, since the case that
are not relatively prime is in theory handled by dividing by
. In practice, the Euclidean algorithm itself is used to compute
, but we ignore this issue.)
Suppose we wanted to compute solutions to
. The Euclidean algorithm dictates that we repeatedly divide, obtain a remainder, and divide by that remainder, giving
data:image/s3,"s3://crabby-images/8a905/8a90510024e9a99f1afc9ce02f6777c5b0a49f25" alt="$ 15284 = 3 \cdot 4889 + 617$"
data:image/s3,"s3://crabby-images/00abd/00abdf6f1e9f61758cf8daefc21d353e4f484bf2" alt="$ 4889 = 7 \cdot 617 + 570$"
data:image/s3,"s3://crabby-images/4daf3/4daf3b7ceaddd0638e0c48b0fbc4baa229c3363f" alt="$ 617 = 1 \cdot 570 + 47$"
data:image/s3,"s3://crabby-images/6e560/6e56015eb736b3bab49eaf158ac11baa1eab58a1" alt="$ 570 = 12 \cdot 47 + 6$"
data:image/s3,"s3://crabby-images/ba3df/ba3dfcb232870de500e92a5a9b53cc9a858d159c" alt="$ 47 = 7 \cdot 6 + 5$"
data:image/s3,"s3://crabby-images/45ba6/45ba6ff6c399169729edd05fe9aaee0b19743e12" alt="$ 6 = 1 \cdot 5 + 1$"
.
The next step of the extended Euclidean algorithm is to substitute expressions for each of our remainders as follows:
$ \begin{eqnarray*} 1 &=& 6 - 1 \cdot 5 \\ &=& 6 - 1 \cdot (47 - 7 \cdot 6) \\ &=& 8 \cdot 6 - 1 \cdot 47 \\ &=& 8 \cdot (570 - 12 \cdot 47) - 1 \cdot 47 \\ &=& 8 \cdot 570 - 97 \cdot 47 \\ &=& 8 \cdot 570 - 97 \cdot (617 - 1 \cdot 570) \\ &=& 105 \cdot 570 - 97 \cdot 617 \\ &=& 105 \cdot (4889 - 7 \cdot 617) - 97 \cdot 617 \\ &=& 105 \cdot 4889 - 832 \cdot 617 \\ &=& 105 \cdot 4889 - 832 (15284 - 3 \cdot 4889) \\ &=& 2601 \cdot 4889 - 832 \cdot 15284 \\ \end{eqnarray*}$.
So why does this algorithm really work? One way of motivating the Euclidean algorithm is the question of finding multiplicative inverses modulo some
. The question of finding the multiplicative inverse of
is exactly the question of solving the linear Diophantine equation
data:image/s3,"s3://crabby-images/e16e2/e16e22a683b4eeb0cd495968e282854ae0e27a51" alt="$ ax = 1 + my \Leftrightarrow$"
.
For example, the above calculation demonstrates that the multiplicative inverse of
is
. We interpret the equation as the question of finding a multiplicative inverse by taking it
. But why restrict ourselves? As a concrete example, to find the inverse of
we solved
.
We recover the inverse by taking
. But to solve this equation suppose we take
instead. Then
data:image/s3,"s3://crabby-images/c2c2b/c2c2b31255552930072616bfd8cdcbe9d2125ca3" alt="$ 617x \equiv 1 \bmod 4889$"
and we are finding the inverse of
instead. Note that this is exactly the first step of the first half of the Euclidean algorithm! Thus one motivation of the Euclidean algorithm is that we reduce a modular problem
(of finding the inverse of
) to the modular problem
(of finding the inverse of
), which is "smaller," and once we have reduced enough we backtrack to get a solution to the original problem (which is the content of the second half of the algorithm).
Generalizations of the Euclidean algorithm lead to the notion of a Euclidean domain, but for now let's dispense with the abstract stuff and ask ourselves, say, an algorithmic question: can we bound the number of steps required to execute the Euclidean on
as a function of
and
? In fact, we can, and very easily so! A straightforward bound is implied by
Lamé's Theorem: The pair
is the "smallest" pair of numbers requiring
steps for the Euclidean algorithm to execute. (We have added an extra step to the Euclidean algorithm here for reasons to be explained later.)
And you thought I couldn't sneak the Fibonacci numbers into this one!
We defer the proof of the above result because we wish to place this result in the proper context (although it is somewhat intuitive). To do so it is necessary first to streamline the Euclidean algorithm. The fundamental step where we replace
with
can be broken down into the two steps
data:image/s3,"s3://crabby-images/2ab4d/2ab4d34b3500d36f04d15b978ca1497524869fbb" alt="$ (a, b) \mapsto (a, b - a), a < b$"
or
.
In running the algorithm we merely always keep the larger of the two numbers on the right until we get the ordered pair
(equivalently, we could stop at
or even at
). The advantage of working with these steps is that they can be easily represented by the matrices
![$ \mathbf{A} = \left[ \begin{array}{cc} 1 & -1 \\ 0 & 1 \end{array} \right]$](//latex.artofproblemsolving.com/0/7/2/0723d6a0274bce7910d55a2749ef4e43ca83cd25.png)
![$ \mathbf{J} = \left[ \begin{array}{cc} 0 & 1 \\ 1 & 0 \end{array} \right]$](//latex.artofproblemsolving.com/5/c/5/5c529956659d02ee23fc0c29b2e9147f59d2180b.png)
(where we have identified the ordered pair
with the column matrix
for later convenience.) The Euclidean algorithm can then be formulated as follows.
Theorem (the Euclidean algorithm): Given two relatively prime integers
, there exists a unique finite sequence of natural numbers
such that
.
is precisely the sequence of quotients in the presentation of the Euclidean algorithm above. ("Unique" has to be understood in the proper sense because we can end the Euclidean algorithm in a few slightly different ways; we could choose to continue so that the last quotient is always
, for example, but this is not really necessary.)
It is then natural to ask what the nature of the matrix
is. The answer is also a direct consequence of the Euclidean algorithm. In particular, the following theorem occurs (with different notation) in the problem sets of 18.701 at MIT:
Theorem (the Euclidean algorithm, take 2): The special linear group
of integer matrices with determinant
is generated by
and
. (Note that
is its own inverse and transpose and that it has determinant
.)
Proof. The additional step necessary to execute the Euclidean algorithm on negative integers is
when
have opposite signs, which is just the matrix
.
is the step
, and it (and its inverse) can be taken as a replacement for the switching step (that is, depending on whichever of
is greater we subtract the smaller from the greater at each step). In other words, we now have four cases and four possible steps:
-data:image/s3,"s3://crabby-images/cfd9a/cfd9a89925cab68f14d6363449e5967d3286b13b" alt="$ (a, b) \mapsto (a, b-a), a, b \ge 0, a < b \text{ or } a, b \le 0, a > b (\mathbf{A})$"
-data:image/s3,"s3://crabby-images/d8b8b/d8b8bd165bc7cc6a1445b0ec526fc5a75ea4bfd5" alt="$ (a, b) \mapsto (a-b, b), a, b \ge 0, a > b \text{ or } a, b \le 0, a < b (\mathbf{JAJ})$"
-data:image/s3,"s3://crabby-images/688de/688de447997203daf3059d781e1e903a86b1a831" alt="$ (a, b) \mapsto (a, b+a), a < 0, b \ge 0 (\mathbf{A}^{-1})$"
-data:image/s3,"s3://crabby-images/cc055/cc05579d4c019d57c14f2d333463ccdc33f82cf2" alt="$ (a, b) \mapsto (a+b, b), a \ge 0, b < 0 (\mathbf{JA}^{-1} \mathbf{J})$"
Now, given
(hence with
), repeatedly apply the four transformations above, as in the first theorem, to to
$ \mathbf{M} \left[ \begin{array}{c} 1 & 0 \end{array} \right] = \left[ \begin{array}{c} b & a \end{array} \right]$.
We get an expression of the form
$ (\text{Some As and Js}) \mathbf{M} \left[ \begin{array}{c} 1 & 0 \end{array} \right] = \left[ \begin{array}{c} 1 \\ 0 \end{array} \right]$.
(Note that even without an explicit switching step
it is still possible to ensure that we end at
by running the algorithm until
is reached.)
is therefore a matrix with left column
. Because it still has determinant
(since
, and their inverses all have determinant
), its right column must be of the form
for some integer
. But this matrix is just
. Inverting gives the desired result.
Note that this is a slightly more general statement than the ordinary Euclidean algorithm because we have made no assumptions about the signs of the integers involved. The members of
generated by non-negative powers of
and
(where we take no inverses) form a semigroup, and these are the matrices that appear in our first formulation of the Euclidean algorithm. It is convenient at this point to adopt the notation
, in which case we can reword Take 1 into the following
Theorem (the Euclidean algorithm, take 3): Given relatively prime positive integers
, there exists a unique finite sequence of natural numbers
such that
.
Consequently,
is generated by
and
.
The use of the letter
was intentional -
is precisely the Fibonacci matrix! This observation leads to a quick and intuitive
Proof of Lamé's Theorem. In counting the number of steps in the Euclidean algorithm, we should be specific: we are counting the number of steps of the form
where
is the reduction of
. This is precisely the number of quotients
that occur in the process of running the Euclidean algorithm. We also need to be specific about what we mean by "size." Given two relatively prime integers
, simply define the size of the ordered pair to be
.
It is now straightforward that
strictly increases the size of a pair of relatively prime positive integers and
does nothing, and therefore that the smallest pair of relatively prime positive integers requiring
steps in the Euclidean algorithm is
![$ \left( \mathbf{F}_1 \right)^n \left[ \begin{array}{c} 1 \\ 0 \end{array} \right] = \left[ \begin{array}{c} F_{n+1} \\ F_n \end{array} \right]$](//latex.artofproblemsolving.com/7/9/5/795f0aa0897183eebd53e4cb6cb5015acbb66493.png)
exactly as desired. Beautiful!
There is a fascinating sense in which the Euclidean algorithm generalizes to irrational numbers. Suppose we interpreted the intermediate steps
in the Euclidean algorithm as points (particularly, lattice points) in the plane. When
are relatively prime (which is always the case here), we lose no information in identifying a point with its slope
. A linear transformation
(of the type we studied above) then becomes a fractional linear transformation (or Möbius transformation)
of the corresponding slope. A succinct description of the Euclidean algorithm is now possible as follows: one "step" in the Euclidean algorithm is the transformation
data:image/s3,"s3://crabby-images/b2af1/b2af199c395c7aa851616af8334ade6bbb9b45c9" alt="$ \frac{r}{s} \mapsto \frac{1}{\frac{r}{s} - \left\lfloor \frac{r}{s} \right\rfloor}$"
(where
is clearly the quotient in the division). The above discussion demonstrates that the set of fractional linear transformations satisfying
behaves under composition essentially like matrix multiplication. The group we get here is called the modular group
and the above discussion shows that it is isomorphic to
, the projective special linear group with integer coefficients (essentially
once we identify every transformation with its negative). The modular group is a rather fascinating group that shows up unexpectedly all over the place (this being one of those places!).
The transformation above is associated with the matrix
exactly as expected (since this is how we implemented the Euclidean algorithm). Here
corresponds to the subtraction step and
corresponds to the map
. The fractional linear transformation
(which has matrix
, again as expected) is the inverse map of the above; applying the Euclidean algorithm on
and then inverting each step gives
data:image/s3,"s3://crabby-images/d4efa/d4efa2028a6ba7bc1774d621c0c5cfef7d5e3e35" alt="$ \frac{r}{s} = f_{q_0}(f_{q_1}(...f_{q_n}(\infty)))$"
(where
), which we can write quite beautifully as
.
This is known as the (simple) continued fraction of
and is usually abbreviated
. For example, the continued fraction of
is
(precisely the sequence of quotients in the Euclidean algorithm). In other words, we have the following
Theorem (the Euclidean algorithm, take 4): Every rational number has a unique terminating continued fraction expansion.
(Again, unique has to be understood in the proper sense because
. The convention we are using, therefore, is that
.) Continued fraction representation is really exactly Take 3 of the theorems above once we identify
with
. Because of the way we defined fractional linear transformations, the point
at which we chose to end the algorithm is now essentially the point at infinity and corresponds to our use of
above. The definition of the convergents of
is now perhaps more natural. They are given by the slopes of the points corresponding to the vectors
.
Since the computation of successive convergents is just "inserted" multiplication by a matrix, it is also not suprising that the calculation of convergents can be done by recurrences known as the fundamental recurrence formulas (which have a very obvious interpretation in terms of matrix multiplication). Simply note that
![$ \mathbf{F}_{q_{k+1}} \left[ \begin{array}{c} 1 \\ 0 \end{array} \right] = \left[ \begin{array}{c} q_{k+1} \\ 1 \end{array} \right] \implies$](//latex.artofproblemsolving.com/7/b/7/7b73d4fecc71db1dbaf42391d3049ed32e24c39e.png)
.
Denoting the LHS by
, it is now immediate that
data:image/s3,"s3://crabby-images/1b5d1/1b5d17062440ff755c62efa34a509e8c57ca6873" alt="$ \mathbf{P}_{k+1} = \mathbf{P}_k \mathbf{F}_{q_{k+1}}$"
and that
; in other words, we have the identities
data:image/s3,"s3://crabby-images/8cd60/8cd608b854f6261750a26cd67752fe4036a67ea7" alt="$ r_{k+1} = r_k q_{k+1} + r_{k-1}$"
data:image/s3,"s3://crabby-images/3ffba/3ffba446ec180237c39e55d71f6707da0a9e00ce" alt="$ s_{k+1} = s_k q_{k+1} + s_{k-1}$"
.
In particular, because the last convergent of a rational number is itself, the third identity tells us that the second-to-last convergent is the solution to
that we wanted in the first place! Thus the second-to-last convergent of
is
. These seemingly simple identities have other deep implications. Note, for example, their use in my solution to IMO 2008 #3. But first: now that we have recast the Euclidean algorithm in terms of the map
, we no longer have to restrict ourselves to rational
. The simple continued fraction of an irrational number
can be defined as the infinite result of applying the Euclidean algorithm. Perhaps the most beautiful example of such a fraction is
data:image/s3,"s3://crabby-images/dd8a3/dd8a3b55db4553c40618f2346d236c7477c25f5d" alt="$ \phi = 1 + \frac{1}{1 + \frac{1}{1 + \frac{1}{1 + ...}}}$"
which satisfies
(and therefore
.) The convergents to
are therefore precisely the ratios of consecutive Fibonacci numbers
. (This is obvious from the matrix computation and from the recursions given above.) This provides an immediate proof of the identity
(which, as you'll recall, we proved by matrix methods alone before) and also an even more natural interpretation of Distinguishing Result 1: the number of steps required to run the Euclidean algorithm on a rational number
is the number of terms in its continued fraction representation, so to minimize the "size" (here a quantity known as height) of the corresponding fraction we want to make each term as small as possible, that is,
.
You may take some pleasure from the fact that after all of the effort that has been expended on this blog finding ways to express the Fibonacci numbers in terms of
we now have an extraordinary framework in which we found a way to express
in terms of the Fibonacci numbers.
The identities given above can be interpreted in terms of what is sometimes called the geometry of numbers. If a real number
has convergents
, the observation that
is really the observation that
,
which tells us that
and
are quite close together, and moreover that the sequence
is alternately increasing and decreasing. Since the absolute value of the first differences is strictly increasing it then follows that
is alternately above and below
(which is also straightforward by observing what happens when you delete and add terms "deep down" in a simple continued fraction). We interpret this as follows:
Draw the line
. The lattice points
are very close to each other and alternate between different sides of the line. Moreover, by Pick's theorem we conclude that the triangle
contains no lattice points. Any possible lattice points within the interior of the above triangle correspond to a point whose slope is closer to the value of
than
, but we now know that this does not occur. We are therefore led to the conclusion that
The convergents to a real number determine its best rational approximations.
As Practice Problem 2 shows, this has important implications for the solution of certain Diophantine equations. The observation that
is an extremely good approximation to
can therefore be explained by the fact that it is a convergent, and moreover, it turns out that the next quotient in the continued fraction is quite large (which means
). We can even estimate the error in the approximation:
,
so in other words, the error is approximately the square of the denominator, which is quite good, and if
is significantly larger than
it is a lot better. How much better this estimate can get in general is discussed in Practice Problem 3. In any case, if I have not convinced you of anything else you should note the power of Pick's Theorem, which is so mighty it is one of the lemmas used in a proof of quadratic reciprocity (but that's another story).
Note that the action of the elements of the modular group we described above takes each convergent to a better convergent which has "almost" the same slope - in other words, as lattice points the convergents (and therefore
) are "almost" eigenvectors. The actual eigenvectors of
correspond to the slopes
, a clear generalization of the situation with the Fibonacci sequence, where
is the exact eigenvector. Thus the action of repeated applications of
can be seen to be an expression of the principle of the dominant eigenvalue. Generally, the action of
for each of the quotients in a continued fraction expansion can be thought to "average" out in some sense to
. (It is perhaps less surprising, now, if I tell you that the quotients in the continued fraction of almost any real have the same geometric mean.)
This notion generalizes slightly as follows: if we take
for a fixed constant
, we obtain the sequence of rational functions
data:image/s3,"s3://crabby-images/f4c32/f4c322c5441f9fe5904c289dc88d1b53aae37310" alt="$ \phi_n(x) = x + \frac{1}{x + \frac{1}{x + ...}} = \frac{F_{n+1}(x)}{F_n(x)}$"
where
is the Fibonacci polynomial of order
. This is a straightforward generalization of Binet's formula; the recurrence that describes these polynomials is just
, with
.
Excursion: It turns out that
(by induction, for example), which gives in particular
, a rather beautiful identity begging for a combinatorial interpretation. Recalling that
counts the number of paths of length
that can be taken by steps of length
or
, this is reasonably straightforward: a path of length
with
steps of length
has
total steps, and given a set of
steps we pick
of them to "lengthen."
Now the general Fibonacci polynomial (for a positive integer
) can be understood as counting the number ways in which a
rectangle can be tiled by
tiles of
different colors and
tiles of one color (a situation where a recurrence can be written whose characteristic polynomial is precisely
), and the corresponding combinatorial proof is along exactly the same lines as above. This general situation can also be interpreted as the powers of the adjacency matrix of a graph on two variables in which a vertex
connects to a vertex
with
loops. We can also consider the situation where the
tiles are of
different colors (the general second-order recurrence), but this recurrence is not as easy to translate back into the language of simple continued fractions. (The appropriate generalization is the subject of Practice Problem 1.)
Back on topic, we would like to ask whether
is a "generalization" of the convergents to
. In other words,
Does there exist a function
such that
in an appropriate sense?
We might expect this function to be
. Since the two roots above are the roots of the polynomial
, the negative root has small absolute value (for real
) and so has negligible contribution to asymptotic behavior. Indeed, within this context the above calculation can be considered (at least for integer
) to be the process of simultaneously computing the continued fraction of a large class of rationals where, at each step, we remark that it is always the case that
. We might now ask whether this notion generalizes; in other words,
Does there exist a notion of continued fraction expansion for some large class of functions?
Rational functions have an obvious choice of terminating simple continued fraction given by the corresponding Euclidean algorithm on polynomials (although it is no longer true that substituting integers will get us a valid simple continued fraction of a rational number; some quotients may be negative). This is an interesting perspective: the Euclidean algorithm then allows one to decompose rational functions uniquely into the composition of fractional linear transformations of the form
for polynomial coefficients
. If the notion of "functional" continued fraction exists for polynomial quotients, rational functions will be its convergents. Part of the question we're asking, therefore, is the question of what class of functions can be appropriately approximated by sequences of rational functions.
This should remind you of the notion of a Taylor series, which essentially asks the question of what class of functions can be appropriately approximated by sequences of polynomials. Indeed, it is possible to ask the same kind of convergence questions for infinite continued fractions as it is for power series, although these questions are much harder to answer. (This appears to be a current area of active research.) A partial answer is provided by Euler's continued fraction formula, a rather beautiful identity which translates an infinite series into an infinite continued fraction and therefore allows a partial translation in the other direction, and it is here that I am, once again, out of details (although my hunch that hypergeometric functions are part of the answer appears to be correct.)
In closing, one application of the modular group is its use in verifying identities involving a fascinating set of functions called modular forms, which are functions that satisfy a "modular symmetry"; in other words, the modular group acts on them in a very specific way (as described in the article). This condition can be broken down into two conditions by looking at two generators of the modular group (which, we must stress, are not unique), and indeed this is the way a function is usually proven modular. A major application of this idea is to prove that two functions are identical by proving that they are both modular with the same value of
(called the weight of the function). Without getting into all that, ideas from the application of the modular group to complex analysis provide a proof of the Euclidean algorithm which is at once familiar and novel, and relies on the fact that the modular group has a natural group action on the upper half plane
(and in fact forms a subgroup of
, the full automorphism group of
).
First, we will need a few definitions. We say that
if there exists an element
of the modular group such that
. (Verify that this is an equivalence relation.) Let
denote the equivalence class of all such
for a particular
. Let
denote the fundamental domain in the upper half-plane.
Theorem (the Euclidean algorithm, take 5): For a given
, there exists either exactly one element of
in the interior of
or two elements of
on its boundary. Consequently, the modular group is generated by
and
.
The proof is left as an exercise. (Note that
is a translation and
is a reflection through the
-axis followed by an inversion about the circle immediately below
.) Suffice it to say that the sequence of steps that translates a complex number in
into
is the complex-numerical analogue of the Euclidean algorithm and implies that the values of a modular function are uniquely determined by its values in
. Therefore, if two modular functions of the same weight agree on
then they are identical. This seemingly straightforward principle leads to a number of highly nontrivial results, but this is also another story.
Practice Problem 0: Prove that
by expanding the Binet-like formula.
Practice Problem 1: Prove that a simple continued fraction is (eventually) periodic if and only if it is the real root of a quadratic polynomial with integer coefficients.
Practice Problem 2: Prove that if
is a solution to the Pell's equation
, then
is a convergent of
.
Practice Problem 3: What is the best constant
such that
for infinitely many convergents
of
, where
is an arbitrary irrational? (Hint: Look at
again. This result is closely related, in spirit, to Lamé's Theorem.)
Practice Problem 4: Prove Take 5.
The basic idea of the extended Euclidean algorithm on integers is extraordinarily simple, and yet it is one of the fundamental properties of the integers that allow for unique prime factorization and its existence in an arbitrary ring of integers is still the easiest way to prove unique prime factorization there. As we will see, it has even more interesting consequences (which we will illustrate by reformulating its statement five times!) but first we shall work through a large example. (In the rest of this post the Euclidean algorithm always refers to the relatively prime case, since the case that
data:image/s3,"s3://crabby-images/248dc/248dc6879c32db82e0009368c7536783a2ca30ef" alt="$ a, b$"
data:image/s3,"s3://crabby-images/de5bb/de5bbcf01661ed9a06f42894bebaead244b434ec" alt="$ (a, b)$"
data:image/s3,"s3://crabby-images/de5bb/de5bbcf01661ed9a06f42894bebaead244b434ec" alt="$ (a, b)$"
Suppose we wanted to compute solutions to
data:image/s3,"s3://crabby-images/bc02c/bc02cbc1a264ee1453d438b6a9434ad5e41e5c92" alt="$ 15284x - 4889y = 1$"
data:image/s3,"s3://crabby-images/ed310/ed310059d05c1f25283199445539146078eb9c03" alt="$ 15284 = 3 \cdot 4889 + 617$"
data:image/s3,"s3://crabby-images/b3e02/b3e02944e1d001b6ee1b6ff8b2914e76de79ef4a" alt="$ 4889 = 7 \cdot 617 + 570$"
data:image/s3,"s3://crabby-images/1537a/1537a91bdadde7b7f9aa2281f956c8979071a839" alt="$ 617 = 1 \cdot 570 + 47$"
data:image/s3,"s3://crabby-images/31396/31396e34b45a5fe1f1838d575ff4f16d0c3a0052" alt="$ 570 = 12 \cdot 47 + 6$"
data:image/s3,"s3://crabby-images/47223/472232209b4c12af2635e58cb42c52fd2b01cc2f" alt="$ 47 = 7 \cdot 6 + 5$"
data:image/s3,"s3://crabby-images/eb8ac/eb8acd969a54f7a28f0675ede465c46fc8908c8b" alt="$ 6 = 1 \cdot 5 + 1$"
data:image/s3,"s3://crabby-images/aa47c/aa47c530ff6a6b3f696a7f2c0d6956a4f375284d" alt="$ 5 = 5 \cdot 1 + 0$"
The next step of the extended Euclidean algorithm is to substitute expressions for each of our remainders as follows:
$ \begin{eqnarray*} 1 &=& 6 - 1 \cdot 5 \\ &=& 6 - 1 \cdot (47 - 7 \cdot 6) \\ &=& 8 \cdot 6 - 1 \cdot 47 \\ &=& 8 \cdot (570 - 12 \cdot 47) - 1 \cdot 47 \\ &=& 8 \cdot 570 - 97 \cdot 47 \\ &=& 8 \cdot 570 - 97 \cdot (617 - 1 \cdot 570) \\ &=& 105 \cdot 570 - 97 \cdot 617 \\ &=& 105 \cdot (4889 - 7 \cdot 617) - 97 \cdot 617 \\ &=& 105 \cdot 4889 - 832 \cdot 617 \\ &=& 105 \cdot 4889 - 832 (15284 - 3 \cdot 4889) \\ &=& 2601 \cdot 4889 - 832 \cdot 15284 \\ \end{eqnarray*}$.
So why does this algorithm really work? One way of motivating the Euclidean algorithm is the question of finding multiplicative inverses modulo some
data:image/s3,"s3://crabby-images/06078/0607881c834866d3aa491483e3c52bf499ca0d03" alt="$ m$"
data:image/s3,"s3://crabby-images/19c56/19c56ad803a1eda747023b1a4b138e87676b3879" alt="$ a \bmod m$"
data:image/s3,"s3://crabby-images/c9252/c9252682369d6effeba8443f437addab0190e467" alt="$ ax = 1 + my \Leftrightarrow$"
data:image/s3,"s3://crabby-images/357d1/357d126bc4cf69c5d6455f825fd0d092dfe5294f" alt="$ ax - my = 1$"
For example, the above calculation demonstrates that the multiplicative inverse of
data:image/s3,"s3://crabby-images/ae30e/ae30e11186f3dfcd8ec073e7a3fd482d7a4294b0" alt="$ 4889 \bmod 15284$"
data:image/s3,"s3://crabby-images/0a920/0a9200a0e00c0498456e88725cd84d7777c88a0d" alt="$ 2601$"
data:image/s3,"s3://crabby-images/17e02/17e0255747f8393739384caaf1d112a0b6251d7f" alt="$ \bmod m$"
data:image/s3,"s3://crabby-images/ae30e/ae30e11186f3dfcd8ec073e7a3fd482d7a4294b0" alt="$ 4889 \bmod 15284$"
data:image/s3,"s3://crabby-images/bc02c/bc02cbc1a264ee1453d438b6a9434ad5e41e5c92" alt="$ 15284x - 4889y = 1$"
We recover the inverse by taking
data:image/s3,"s3://crabby-images/6280a/6280acdcdb284a3d8c3c3c74177043915924f5ff" alt="$ \bmod 15284$"
data:image/s3,"s3://crabby-images/90415/9041577aa106eae3a3c12f48d410498d241c36af" alt="$ \bmod 4889$"
data:image/s3,"s3://crabby-images/f9086/f9086387caead26ec44373d6f9e8a93c939f551c" alt="$ 617x \equiv 1 \bmod 4889$"
and we are finding the inverse of
data:image/s3,"s3://crabby-images/d3615/d36156e5e6281a979041236aec1280f50d262047" alt="$ 617 \bmod 4889$"
data:image/s3,"s3://crabby-images/de5bb/de5bbcf01661ed9a06f42894bebaead244b434ec" alt="$ (a, b)$"
data:image/s3,"s3://crabby-images/c1b10/c1b10f281d292531a6aa7e222401a6e8c092daeb" alt="$ a \bmod b$"
data:image/s3,"s3://crabby-images/fbf17/fbf17340156a59e734e630df5f3cf4265ee054fd" alt="$ (b', a)$"
data:image/s3,"s3://crabby-images/5dc38/5dc3883d1bd0865c41cfe8c1d59e54c072f075fb" alt="$ b' \equiv b \bmod a$"
Generalizations of the Euclidean algorithm lead to the notion of a Euclidean domain, but for now let's dispense with the abstract stuff and ask ourselves, say, an algorithmic question: can we bound the number of steps required to execute the Euclidean on
data:image/s3,"s3://crabby-images/de5bb/de5bbcf01661ed9a06f42894bebaead244b434ec" alt="$ (a, b)$"
data:image/s3,"s3://crabby-images/d3a92/d3a925ad4728a2eae35a3fc175642fd68dc1858f" alt="$ a$"
data:image/s3,"s3://crabby-images/ff91f/ff91fb1d38c7998946fb3ee52bb2b9dc26626a33" alt="$ b$"
Lamé's Theorem: The pair
data:image/s3,"s3://crabby-images/1748c/1748cf968e0aa555cb6372a1334a14ef04f07d35" alt="$ (F_n, F_{n+1})$"
data:image/s3,"s3://crabby-images/df78f/df78f4632ed3b68b23bf1fdecf605c21703b9cda" alt="$ n$"
And you thought I couldn't sneak the Fibonacci numbers into this one!
We defer the proof of the above result because we wish to place this result in the proper context (although it is somewhat intuitive). To do so it is necessary first to streamline the Euclidean algorithm. The fundamental step where we replace
data:image/s3,"s3://crabby-images/de5bb/de5bbcf01661ed9a06f42894bebaead244b434ec" alt="$ (a, b)$"
data:image/s3,"s3://crabby-images/fbf17/fbf17340156a59e734e630df5f3cf4265ee054fd" alt="$ (b', a)$"
data:image/s3,"s3://crabby-images/bfb61/bfb61de16c587ede0f6302a3b6ec9c4ad368c85a" alt="$ (a, b) \mapsto (a, b - a), a < b$"
or
data:image/s3,"s3://crabby-images/c58ab/c58abeb7a36bcab454c9455c35eeb2abe795d191" alt="$ (a, b) \mapsto (b, a), a > b$"
In running the algorithm we merely always keep the larger of the two numbers on the right until we get the ordered pair
data:image/s3,"s3://crabby-images/03ace/03ace3a1562a21a18e68b4cd1b1a6334badcbfa1" alt="$ (0, 1)$"
data:image/s3,"s3://crabby-images/eeff1/eeff1e791b8ef99833fed744eb73d8888813dd26" alt="$ (1, 0)$"
data:image/s3,"s3://crabby-images/659a0/659a04f601d43964c447ae1a5252c347c3649157" alt="$ (1, p)$"
![$ \mathbf{A} = \left[ \begin{array}{cc} 1 & -1 \\ 0 & 1 \end{array} \right]$](http://latex.artofproblemsolving.com/0/7/2/0723d6a0274bce7910d55a2749ef4e43ca83cd25.png)
![$ \mathbf{J} = \left[ \begin{array}{cc} 0 & 1 \\ 1 & 0 \end{array} \right]$](http://latex.artofproblemsolving.com/5/c/5/5c529956659d02ee23fc0c29b2e9147f59d2180b.png)
(where we have identified the ordered pair
data:image/s3,"s3://crabby-images/de5bb/de5bbcf01661ed9a06f42894bebaead244b434ec" alt="$ (a, b)$"
![$ \left[ \begin{array}{c} b \\ a \end{array} \right]$](http://latex.artofproblemsolving.com/e/4/c/e4cbb26555c9085fe0cff8086db4bf975e91a253.png)
Theorem (the Euclidean algorithm): Given two relatively prime integers
data:image/s3,"s3://crabby-images/4b6b0/4b6b0cf0cc62bc8189c9401e75e75abe96bf5b5e" alt="$ a, b, a < b$"
data:image/s3,"s3://crabby-images/c32cc/c32cc912e70c54c225d287c449c4f9db2163e5a7" alt="$ q_0, q_1, ..., q_n$"
![$ \mathbf{J} \mathbf{A}^{q_n} ... \mathbf{J} \mathbf{A}^{q_0} \left[ \begin{array}{c} b \\ a \end{array} \right] = \left[ \begin{array}{c} 1 \\ 0 \end{array} \right]$](http://latex.artofproblemsolving.com/6/e/4/6e478a603ee3eff5f86e30abdcca2bc933def984.png)
data:image/s3,"s3://crabby-images/1f2ac/1f2acd244998d92f60250700b1d7dce9fb0106d8" alt="$ \{ q_i \}$"
data:image/s3,"s3://crabby-images/3596b/3596b742f77bc03dba5f184f36f650c7ec52fd3f" alt="$ 1$"
It is then natural to ask what the nature of the matrix
data:image/s3,"s3://crabby-images/8a7ee/8a7ee1d698d1bb25326a30ac20f3559f5989fb55" alt="$ \mathbf{J} \mathbf{A}^{q_n} ... \mathbf{J} \mathbf{A}^{q_0}$"
Theorem (the Euclidean algorithm, take 2): The special linear group
data:image/s3,"s3://crabby-images/86cb9/86cb9c46ebd72ed649503609829f26e77ad1f509" alt="$ SL_2(\mathbb{Z})$"
data:image/s3,"s3://crabby-images/3596b/3596b742f77bc03dba5f184f36f650c7ec52fd3f" alt="$ 1$"
data:image/s3,"s3://crabby-images/a0b35/a0b35f84dff6851a5b5484e51de3bfb32628db26" alt="$ \mathbf{A}$"
data:image/s3,"s3://crabby-images/5915f/5915f6a8b19af264acb8c9f916c57ac368df31f2" alt="$ \mathbf{JAJ} = \mathbf{A}^T$"
data:image/s3,"s3://crabby-images/41b4f/41b4f3105174fe95cdd1d9a7af88a9c7e7c4f73f" alt="$ \mathbf{J}$"
data:image/s3,"s3://crabby-images/95a3d/95a3d9e94f14df23c275ab92c0b2ec19ae9eea0e" alt="$ -1$"
Proof. The additional step necessary to execute the Euclidean algorithm on negative integers is
data:image/s3,"s3://crabby-images/dcc01/dcc012a161d824a20b476b7a8498727b90c68c3b" alt="$ (a, b) \mapsto (a, b + a)$"
data:image/s3,"s3://crabby-images/248dc/248dc6879c32db82e0009368c7536783a2ca30ef" alt="$ a, b$"
data:image/s3,"s3://crabby-images/1864a/1864a132ab84974ddc69b42ee84f26a9209966b9" alt="$ \mathbf{A}^{-1}$"
data:image/s3,"s3://crabby-images/a148f/a148f4edc2f83aaefddf49f6639e5dcded28afb2" alt="$ \mathbf{JAJ}$"
data:image/s3,"s3://crabby-images/359d8/359d813be6bbcd5c3e802278a3f61d2817d0bd18" alt="$ (a, b) \mapsto (a - b, b)$"
data:image/s3,"s3://crabby-images/248dc/248dc6879c32db82e0009368c7536783a2ca30ef" alt="$ a, b$"
-
data:image/s3,"s3://crabby-images/1ed17/1ed179b8e5d6346165ce04e3a522530f6f4cd71b" alt="$ (a, b) \mapsto (a, b-a), a, b \ge 0, a < b \text{ or } a, b \le 0, a > b (\mathbf{A})$"
-
data:image/s3,"s3://crabby-images/3c640/3c640cdce01fab20222bd8186a83c99dc21fe9a9" alt="$ (a, b) \mapsto (a-b, b), a, b \ge 0, a > b \text{ or } a, b \le 0, a < b (\mathbf{JAJ})$"
-
data:image/s3,"s3://crabby-images/7255c/7255c91b256f2a02782e491f9bed26320738566f" alt="$ (a, b) \mapsto (a, b+a), a < 0, b \ge 0 (\mathbf{A}^{-1})$"
-
data:image/s3,"s3://crabby-images/dc211/dc211bfbf010685f8fd8b91f2469aa5d8dfc93b0" alt="$ (a, b) \mapsto (a+b, b), a \ge 0, b < 0 (\mathbf{JA}^{-1} \mathbf{J})$"
Now, given
![$ \mathbf{M} = \left[ \begin{array}{cc} b & x \\ a & y \end{array} \right] \in SL_2(\mathbb{Z})$](http://latex.artofproblemsolving.com/0/9/e/09e56e59c8ddaed666c0820b6a4442d9c914f0e7.png)
data:image/s3,"s3://crabby-images/12734/127343d0d2d43cab693e8a12218b244a95221882" alt="$ by - ax = 1$"
$ \mathbf{M} \left[ \begin{array}{c} 1 & 0 \end{array} \right] = \left[ \begin{array}{c} b & a \end{array} \right]$.
We get an expression of the form
$ (\text{Some As and Js}) \mathbf{M} \left[ \begin{array}{c} 1 & 0 \end{array} \right] = \left[ \begin{array}{c} 1 \\ 0 \end{array} \right]$.
(Note that even without an explicit switching step
data:image/s3,"s3://crabby-images/267d2/267d2ec48cc5537cf806df99243bf9d2a3564db2" alt="$ (a, b) \mapsto (b, a)$"
data:image/s3,"s3://crabby-images/03ace/03ace3a1562a21a18e68b4cd1b1a6334badcbfa1" alt="$ (0, 1)$"
data:image/s3,"s3://crabby-images/0349e/0349eddef5be9d1ba2acf6ac76419b0c6ba0e508" alt="$ (1, 1)$"
data:image/s3,"s3://crabby-images/11376/113767007709a7623eb236f5c50e819245bcf664" alt="$ (\text{Some As and Js}) \mathbf{M}$"
![$ \left[ \begin{array}{c} 1 \\ 0 \end{array} \right]$](http://latex.artofproblemsolving.com/1/6/f/16f46d1343e425c8bfb134a99e1a35b5bcf808db.png)
data:image/s3,"s3://crabby-images/3596b/3596b742f77bc03dba5f184f36f650c7ec52fd3f" alt="$ 1$"
data:image/s3,"s3://crabby-images/1cee0/1cee017b25643d3078197befdd9e9533b6f58943" alt="$ \mathbf{A}, \mathbf{JAJ}$"
data:image/s3,"s3://crabby-images/3596b/3596b742f77bc03dba5f184f36f650c7ec52fd3f" alt="$ 1$"
![$ \left[ \begin{array}{c} x' \\ 1 \end{array} \right]$](http://latex.artofproblemsolving.com/2/d/2/2d2473217a777e827804a7eeadb91925452f1ffd.png)
data:image/s3,"s3://crabby-images/72110/721106a0c14548ff3cfc7d62e75b357b73dca5f8" alt="$ x'$"
data:image/s3,"s3://crabby-images/cd31b/cd31ba83500a0ddf33aba5fa3dbf344f8b008e6a" alt="$ \mathbf{A}^{-x'}$"
Note that this is a slightly more general statement than the ordinary Euclidean algorithm because we have made no assumptions about the signs of the integers involved. The members of
data:image/s3,"s3://crabby-images/86cb9/86cb9c46ebd72ed649503609829f26e77ad1f509" alt="$ SL_2(\mathbb{Z})$"
data:image/s3,"s3://crabby-images/a0b35/a0b35f84dff6851a5b5484e51de3bfb32628db26" alt="$ \mathbf{A}$"
data:image/s3,"s3://crabby-images/a148f/a148f4edc2f83aaefddf49f6639e5dcded28afb2" alt="$ \mathbf{JAJ}$"
![$ \mathbf{F}_q = \mathbf{A}^{-q} \mathbf{J} = \left[ \begin{array}{cc} q & 1 \\ 1 & 0 \end{array} \right]$](http://latex.artofproblemsolving.com/b/1/3/b131b9f9a92a9c47893c33d7fc9e912fe7fd4d9d.png)
Theorem (the Euclidean algorithm, take 3): Given relatively prime positive integers
data:image/s3,"s3://crabby-images/00ad8/00ad84d2b680927c8c1d2088e3fabb9873150635" alt="$ (a, b), a < b$"
data:image/s3,"s3://crabby-images/04b80/04b80eddc903bdd204bda68b28bed2bd5e0d66b7" alt="$ q_0, q_1, ... q_n$"
![$ \left[ \begin{array}{c} b \\ a \end{array} \right] = \mathbf{F}_{q_0} \mathbf{F}_{q_1} ... \mathbf{F}_{q_n} \left[ \begin{array}{c} 1 \\ 0 \end{array} \right]$](http://latex.artofproblemsolving.com/f/c/5/fc5001a0dc72af67b3ea678bb54218fc2c36013d.png)
Consequently,
data:image/s3,"s3://crabby-images/86cb9/86cb9c46ebd72ed649503609829f26e77ad1f509" alt="$ SL_2(\mathbb{Z})$"
data:image/s3,"s3://crabby-images/5d084/5d08491f3146dc378554cc5710a5a852c4020c21" alt="$ \mathbf{JF}_1$"
data:image/s3,"s3://crabby-images/9036e/9036ee458123dabbd89a0216224009f0e53728fc" alt="$ \mathbf{F}_1 \mathbf{J}$"
The use of the letter
data:image/s3,"s3://crabby-images/46109/46109bff31ba8bf4c6ef0a3f98f590ecd3ccf7a9" alt="$ \mathbf{F}$"
data:image/s3,"s3://crabby-images/46cf1/46cf19a4790853cec21be8ebdd08e8fc3f04794c" alt="$ \mathbf{F}_1$"
Proof of Lamé's Theorem. In counting the number of steps in the Euclidean algorithm, we should be specific: we are counting the number of steps of the form
data:image/s3,"s3://crabby-images/958c9/958c973a4a6836837cd6b8ef559112cc75f28201" alt="$ (a, b) \mapsto (b', a)$"
data:image/s3,"s3://crabby-images/a1cea/a1cea675cb2090195d346bc27fab466e59884b8c" alt="$ b'$"
data:image/s3,"s3://crabby-images/c2c8c/c2c8c5881d3d572122cf516301819507c55bd402" alt="$ b \bmod a$"
data:image/s3,"s3://crabby-images/8620d/8620dea0d06d641f6420178d270dc6f2ca583950" alt="$ q_i$"
data:image/s3,"s3://crabby-images/de5bb/de5bbcf01661ed9a06f42894bebaead244b434ec" alt="$ (a, b)$"
data:image/s3,"s3://crabby-images/39717/39717078d10e0bb63680e70cbfb5294b6a77758c" alt="$ \text{max}(a, b)$"
It is now straightforward that
data:image/s3,"s3://crabby-images/1864a/1864a132ab84974ddc69b42ee84f26a9209966b9" alt="$ \mathbf{A}^{-1}$"
data:image/s3,"s3://crabby-images/41b4f/41b4f3105174fe95cdd1d9a7af88a9c7e7c4f73f" alt="$ \mathbf{J}$"
data:image/s3,"s3://crabby-images/df78f/df78f4632ed3b68b23bf1fdecf605c21703b9cda" alt="$ n$"
![$ \left( \mathbf{F}_1 \right)^n \left[ \begin{array}{c} 1 \\ 0 \end{array} \right] = \left[ \begin{array}{c} F_{n+1} \\ F_n \end{array} \right]$](http://latex.artofproblemsolving.com/7/9/5/795f0aa0897183eebd53e4cb6cb5015acbb66493.png)
exactly as desired. Beautiful!
There is a fascinating sense in which the Euclidean algorithm generalizes to irrational numbers. Suppose we interpreted the intermediate steps
data:image/s3,"s3://crabby-images/7fb32/7fb32dd3465b82b1f9f32c349b814e790a001ee3" alt="$ (s, r), s < r$"
data:image/s3,"s3://crabby-images/3e1db/3e1dbe79052393e3d289eb80f28db60f3bb7b71a" alt="$ r, s$"
data:image/s3,"s3://crabby-images/78441/784415fd5c946f33c9c6965d84879129c3df05b0" alt="$ \frac{r}{s}$"
data:image/s3,"s3://crabby-images/e87bc/e87bc20b337ee202d6a90ee4fdcfcddaa20f12e1" alt="$ (s, r) \mapsto (cr + ds, ar + bs)$"
data:image/s3,"s3://crabby-images/e0e07/e0e0776fb7aa547f830d20aaf251295fd2b3b80e" alt="$ \frac{r}{s} \mapsto \frac{ a \frac{r}{s} + b}{c \frac{r}{s} + d}$"
data:image/s3,"s3://crabby-images/32f46/32f462f583d584bcbf9412554c2f7a9b5b8b804f" alt="$ \frac{r}{s} \mapsto \frac{1}{\frac{r}{s} - \left\lfloor \frac{r}{s} \right\rfloor}$"
(where
data:image/s3,"s3://crabby-images/890b0/890b00230669dda11fc181227846005deea81d32" alt="$ q = \left\lfloor \frac{r}{s} \right\rfloor$"
data:image/s3,"s3://crabby-images/e2bd1/e2bd1ab80ffb4e379126bb7ad381b7e0e93deeed" alt="$ ad - bc = 1$"
data:image/s3,"s3://crabby-images/b8bfa/b8bfa26f692543259bc4f8d37f5dc4a2b3a04577" alt="$ \Gamma$"
data:image/s3,"s3://crabby-images/78a12/78a121d568ad946e030986ac8156fad5fbec1a04" alt="$ PSL_2(\mathbb{Z})$"
data:image/s3,"s3://crabby-images/86cb9/86cb9c46ebd72ed649503609829f26e77ad1f509" alt="$ SL_2(\mathbb{Z})$"
The transformation above is associated with the matrix
data:image/s3,"s3://crabby-images/8c784/8c78437b40b599d89fe1ae5f371a2d0b12c9c268" alt="$ \mathbf{F}_{-q} = \mathbf{J} \mathbf{A}^q$"
data:image/s3,"s3://crabby-images/b903e/b903e71102ff469abb05b76597edf7d9385a3245" alt="$ \mathbf{A}^q$"
data:image/s3,"s3://crabby-images/41b4f/41b4f3105174fe95cdd1d9a7af88a9c7e7c4f73f" alt="$ \mathbf{J}$"
data:image/s3,"s3://crabby-images/22549/225499c1b52ecb1ad7e5603016338cfa9650efd3" alt="$ x \mapsto \frac{1}{x}$"
data:image/s3,"s3://crabby-images/9b2de/9b2de6a0ea95842d71e9accfe1fe89368d6f6d72" alt="$ f_q(x) = q + \frac{1}{x} = \frac{qx + 1}{x}$"
data:image/s3,"s3://crabby-images/cfb8f/cfb8f6e22aacd2c0563b6eea93a8aa50923b3d65" alt="$ \mathbf{F}_q$"
data:image/s3,"s3://crabby-images/78441/784415fd5c946f33c9c6965d84879129c3df05b0" alt="$ \frac{r}{s}$"
data:image/s3,"s3://crabby-images/88360/88360582bcafa3140d9dbcb58e8764f8cba56e04" alt="$ \frac{r}{s} = f_{q_0}(f_{q_1}(...f_{q_n}(\infty)))$"
(where
data:image/s3,"s3://crabby-images/d73ed/d73edefd8d28f0c7fc2803b05dea675aff7a9fdd" alt="$ f_q(\infty) = q$"
data:image/s3,"s3://crabby-images/d8891/d8891dc0796baf472b7f35ed287161dcca78d778" alt="$ \frac{r}{s} = q_0 + \frac{1}{q_1 + \frac{1}{... + \frac{1}{q_n}}}$"
This is known as the (simple) continued fraction of
data:image/s3,"s3://crabby-images/78441/784415fd5c946f33c9c6965d84879129c3df05b0" alt="$ \frac{r}{s}$"
![$ [q_0 ; q_1, q_2, ... q_n]$](http://latex.artofproblemsolving.com/5/d/8/5d88d445b9ac7943c194f4c4dd6610ab4afa285f.png)
data:image/s3,"s3://crabby-images/8cba4/8cba43470acef15599095d1031dc82557ba35063" alt="$ \frac{15284}{4889}$"
![$ [3; 7, 1, 12, 7, 1, 5]$](http://latex.artofproblemsolving.com/7/4/8/748b60df7b99b73d60e6394bef109eed9fd602f2.png)
Theorem (the Euclidean algorithm, take 4): Every rational number has a unique terminating continued fraction expansion.
(Again, unique has to be understood in the proper sense because
![$ [q_0 ; q_1, q_2, ... q_n] = [q_0 ; q_1, q_2, ... q_n - 1, 1]$](http://latex.artofproblemsolving.com/d/3/5/d3579fe419c898f30b898137bd012b50521761cd.png)
data:image/s3,"s3://crabby-images/93d4a/93d4ac388e4e8bf9d1aaf902ef8252c196798998" alt="$ q_n > 1$"
data:image/s3,"s3://crabby-images/ae64e/ae64e98fcf6691b8214b77f102f2142f5c424d0e" alt="$ (s, r)$"
data:image/s3,"s3://crabby-images/78441/784415fd5c946f33c9c6965d84879129c3df05b0" alt="$ \frac{r}{s}$"
data:image/s3,"s3://crabby-images/60318/603189dfe43399b228338ad514a63fa185ec8206" alt="$ (0 : 1)$"
data:image/s3,"s3://crabby-images/e0815/e0815f225c9b4c58da77fe26feee0d3cfd3f82f1" alt="$ \infty$"
data:image/s3,"s3://crabby-images/78441/784415fd5c946f33c9c6965d84879129c3df05b0" alt="$ \frac{r}{s}$"
![$ \mathbf{p}_k = \left[ \begin{array}{c} r_k \\ s_k \end{array} \right] = \mathbf{F}_{q_0} \mathbf{F}_{q_1} ... \mathbf{F}_{q_k} \left[ \begin{array}{c} 1 \\ 0 \end{array} \right], k \le n$](http://latex.artofproblemsolving.com/2/9/b/29bac83692e1e1102b5a99e4a5ef882160a9d329.png)
Since the computation of successive convergents is just "inserted" multiplication by a matrix, it is also not suprising that the calculation of convergents can be done by recurrences known as the fundamental recurrence formulas (which have a very obvious interpretation in terms of matrix multiplication). Simply note that
![$ \mathbf{F}_{q_{k+1}} \left[ \begin{array}{c} 1 \\ 0 \end{array} \right] = \left[ \begin{array}{c} q_{k+1} \\ 1 \end{array} \right] \implies$](http://latex.artofproblemsolving.com/7/b/7/7b73d4fecc71db1dbaf42391d3049ed32e24c39e.png)
![$ \left[ \begin{array}{cc} r_{k+1} & r_k \\ s_{k+1} & s_k \end{array} \right] = \mathbf{F}_{q_0}... \mathbf{F}_{q_k} \mathbf{F}_{q_{k+1}}$](http://latex.artofproblemsolving.com/f/6/4/f64000178c28bb5db3014faf5e4b24b588fc1cfd.png)
Denoting the LHS by
data:image/s3,"s3://crabby-images/a41d5/a41d5f8732fcd540246651bdc170319f1af7a2f1" alt="$ \mathbf{P}_{k+1}$"
data:image/s3,"s3://crabby-images/be8f1/be8f139f8ed2a177ecb38fcd56976fcba579cb82" alt="$ \mathbf{P}_{k+1} = \mathbf{P}_k \mathbf{F}_{q_{k+1}}$"
and that
data:image/s3,"s3://crabby-images/89b6d/89b6da3aa7526354165f3afd41c3589fa326cc97" alt="$ \text{det}(\mathbf{P}_{k+1}) = (-1)^k$"
data:image/s3,"s3://crabby-images/2bc16/2bc1678aef9f5b8e20f413a3c2007d70fa9f344e" alt="$ r_{k+1} = r_k q_{k+1} + r_{k-1}$"
data:image/s3,"s3://crabby-images/9ed8d/9ed8d50b2257cbc2614ddaa66ef99a85950946cd" alt="$ s_{k+1} = s_k q_{k+1} + s_{k-1}$"
data:image/s3,"s3://crabby-images/4934e/4934e4af1b178824dfe41d289c0e746a519a5676" alt="$ r_{k+1} s_k - r_k s_{k+1} = (-1)^k$"
In particular, because the last convergent of a rational number is itself, the third identity tells us that the second-to-last convergent is the solution to
data:image/s3,"s3://crabby-images/830b1/830b17c23519f60e315df8ed8ee0b27a80bb3d79" alt="$ ax - by = 1$"
data:image/s3,"s3://crabby-images/8cba4/8cba43470acef15599095d1031dc82557ba35063" alt="$ \frac{15284}{4889}$"
data:image/s3,"s3://crabby-images/edf71/edf71ee35baad08f2bcd387a9d880b8fc724d406" alt="$ \frac{2601}{832}$"
data:image/s3,"s3://crabby-images/5bf25/5bf259265bdb3504b8367d8d7cd4df76d330a675" alt="$ x \mapsto \frac{1}{x - \lfloor x \rfloor}$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/c8c9b/c8c9ba393947a869b399082b93cc8833605f97f8" alt="$ \phi = 1 + \frac{1}{1 + \frac{1}{1 + \frac{1}{1 + ...}}}$"
which satisfies
data:image/s3,"s3://crabby-images/03bcc/03bcc0fc45c99f08f07ff16071ca4d0bd9d3eaa7" alt="$ q_0 = q_1 = ... = 1$"
data:image/s3,"s3://crabby-images/024bc/024bcd4d51b09e7c49b5e2b2da36d817c61a38d6" alt="$ \mathbf{F}_{q_k} = \mathbf{F}_1 = \mathbf{F}$"
data:image/s3,"s3://crabby-images/272ef/272effee5d8a7938d20e0300f4c6cfb2ed1577b0" alt="$ \phi$"
data:image/s3,"s3://crabby-images/64276/642762980173ae996d0c3577420c633a6b1aec52" alt="$ \frac{F_{n+1}}{F_n}$"
data:image/s3,"s3://crabby-images/6fde5/6fde5d45dd57b4a0dcb3a6d6c03ae875190aee4a" alt="$ F_{k+1} F_{k-1} - F_k^2 = (-1)^k$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/3596b/3596b742f77bc03dba5f184f36f650c7ec52fd3f" alt="$ 1$"
You may take some pleasure from the fact that after all of the effort that has been expended on this blog finding ways to express the Fibonacci numbers in terms of
data:image/s3,"s3://crabby-images/272ef/272effee5d8a7938d20e0300f4c6cfb2ed1577b0" alt="$ \phi$"
data:image/s3,"s3://crabby-images/272ef/272effee5d8a7938d20e0300f4c6cfb2ed1577b0" alt="$ \phi$"
The identities given above can be interpreted in terms of what is sometimes called the geometry of numbers. If a real number
data:image/s3,"s3://crabby-images/83f57/83f57c7d56a3f6abd727c3543d900de9cb8b793e" alt="$ p$"
data:image/s3,"s3://crabby-images/cd82d/cd82d9e075074df3b994b81ff8641a67b4b2b049" alt="$ p_k = \frac{r_k}{s_k}$"
data:image/s3,"s3://crabby-images/4934e/4934e4af1b178824dfe41d289c0e746a519a5676" alt="$ r_{k+1} s_k - r_k s_{k+1} = (-1)^k$"
data:image/s3,"s3://crabby-images/d650e/d650e51da56fd1b566f98004eab02d7cfd7e82c5" alt="$ \frac{r_{k+1}}{s_{k+1}} - \frac{r_k}{s_k} = \frac{(-1)^k}{s_k s_{k+1}}$"
which tells us that
data:image/s3,"s3://crabby-images/abf52/abf5265ea4640d241e4a5f136f60d74305acf421" alt="$ p_k$"
data:image/s3,"s3://crabby-images/755e8/755e8bdbe5ffd18ad144d4969ec3b452cb328f94" alt="$ p_{k+1}$"
data:image/s3,"s3://crabby-images/957fd/957fda31c2987c2378a106a90052d05dbf120afc" alt="$ \{ p_k \}$"
data:image/s3,"s3://crabby-images/abf52/abf5265ea4640d241e4a5f136f60d74305acf421" alt="$ p_k$"
data:image/s3,"s3://crabby-images/83f57/83f57c7d56a3f6abd727c3543d900de9cb8b793e" alt="$ p$"
Draw the line
data:image/s3,"s3://crabby-images/66379/6637974e8ae7371987ffe98d83ddfe9b04f47720" alt="$ y = px$"
data:image/s3,"s3://crabby-images/d89b1/d89b1bb3a41b043115d4838231778d7e3ba39668" alt="$ (s_k, r_k)$"
data:image/s3,"s3://crabby-images/5171a/5171abadb9cfa02fa79e2cdd0b3ebd9ce8260447" alt="$ (0, 0), (s_k, r_k), (s_{k+1}, r_{k+1})$"
data:image/s3,"s3://crabby-images/83f57/83f57c7d56a3f6abd727c3543d900de9cb8b793e" alt="$ p$"
data:image/s3,"s3://crabby-images/abf52/abf5265ea4640d241e4a5f136f60d74305acf421" alt="$ p_k$"
The convergents to a real number determine its best rational approximations.
As Practice Problem 2 shows, this has important implications for the solution of certain Diophantine equations. The observation that
data:image/s3,"s3://crabby-images/8813a/8813a81812b0c30c19246392883570baf5250622" alt="$ \frac{355}{113}$"
data:image/s3,"s3://crabby-images/8ca9a/8ca9a8cefe83b80e794811c86e367af8857445f4" alt="$ \pi$"
data:image/s3,"s3://crabby-images/c50a8/c50a8731c0263a89209e0eda26b47172b6ffd1cc" alt="$ s_{k+1} >> s_k$"
data:image/s3,"s3://crabby-images/4c594/4c594ce8a51e977816b8f72bde535b4561af7fc0" alt="$ |p_k - p| < \frac{1}{s_k s_{k+1}} < \frac{1}{s_k^2}$"
so in other words, the error is approximately the square of the denominator, which is quite good, and if
data:image/s3,"s3://crabby-images/c658f/c658f2608a4eafb96cd39fafbcc17ce8231f8da4" alt="$ s_{k+1}$"
data:image/s3,"s3://crabby-images/b3c1a/b3c1a01e4d238f45a22d6cd8dcd362b3674e2420" alt="$ s_k$"
Note that the action of the elements of the modular group we described above takes each convergent to a better convergent which has "almost" the same slope - in other words, as lattice points the convergents (and therefore
data:image/s3,"s3://crabby-images/83f57/83f57c7d56a3f6abd727c3543d900de9cb8b793e" alt="$ p$"
data:image/s3,"s3://crabby-images/cfb8f/cfb8f6e22aacd2c0563b6eea93a8aa50923b3d65" alt="$ \mathbf{F}_q$"
data:image/s3,"s3://crabby-images/e6932/e6932b1c6243bc0f586293383d6ad4ddeb348b53" alt="$ \frac{q \pm \sqrt{q^2 + 4}}{2}$"
data:image/s3,"s3://crabby-images/7eb72/7eb7252e373c362d3f9bff3c96a576228060f107" alt="$ p = \phi$"
data:image/s3,"s3://crabby-images/46cf1/46cf19a4790853cec21be8ebdd08e8fc3f04794c" alt="$ \mathbf{F}_1$"
data:image/s3,"s3://crabby-images/c0aea/c0aea3cadc3e0da6a49b22e67f6034de1baf8961" alt="$ \mathbf{F}_{q_k}$"
data:image/s3,"s3://crabby-images/83f57/83f57c7d56a3f6abd727c3543d900de9cb8b793e" alt="$ p$"
This notion generalizes slightly as follows: if we take
data:image/s3,"s3://crabby-images/78c30/78c30cfc9ea39e47082de2124aeac4c018598ab7" alt="$ q_0 = q_1 = ... = x$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/712b5/712b5fbba1a8002dce74c9c066ef9dc120a18c3b" alt="$ \phi_n(x) = x + \frac{1}{x + \frac{1}{x + ...}} = \frac{F_{n+1}(x)}{F_n(x)}$"
where
data:image/s3,"s3://crabby-images/ec606/ec606cac15c8ce79aaeeda83f74a1a3208d1caf2" alt="$ F_n(x) = \frac{1}{\sqrt{x^2 + 4}} \left( \left( \frac{(x + \sqrt{x^2 - 4})}{2} \right)^n - \left( \frac{(x - \sqrt{x^2 - 4})}{2} \right)^n \right)$"
data:image/s3,"s3://crabby-images/df78f/df78f4632ed3b68b23bf1fdecf605c21703b9cda" alt="$ n$"
data:image/s3,"s3://crabby-images/031d1/031d1b4889862ff31cdd5f590992a1a1fd3a4a32" alt="$ F_0(x) = 0, F_1(x) = 1, F_n(x) = x F_{n-1}(x) + F_{n-2}(x)$"
data:image/s3,"s3://crabby-images/c2ef6/c2ef669ab359d71b8e5c21675dcfdc657fd60506" alt="$ F_n(1) = F_n$"
Excursion: It turns out that
data:image/s3,"s3://crabby-images/0c9d0/0c9d0fa091c1ac9ad812951400f2256ddf0fa3e1" alt="$ F_{n+1}(x) = \sum_{j=0}^{ \lfloor \frac{n}{2} \rfloor} {n - j \choose j} x^{n-2j}$"
data:image/s3,"s3://crabby-images/e062f/e062fccb7e9d8e37d8e4de3fc075d0b3e193fa69" alt="$ F_{n+1} = \sum_{j=0} {n-j \choose j}$"
data:image/s3,"s3://crabby-images/76adb/76adb9e45a09484af478ea6300dbd6b85ca5760b" alt="$ F_{n+1}$"
data:image/s3,"s3://crabby-images/df78f/df78f4632ed3b68b23bf1fdecf605c21703b9cda" alt="$ n$"
data:image/s3,"s3://crabby-images/3596b/3596b742f77bc03dba5f184f36f650c7ec52fd3f" alt="$ 1$"
data:image/s3,"s3://crabby-images/d442f/d442fc99105470e8d250f53514fda9af4190ed07" alt="$ 2$"
data:image/s3,"s3://crabby-images/df78f/df78f4632ed3b68b23bf1fdecf605c21703b9cda" alt="$ n$"
data:image/s3,"s3://crabby-images/10049/1004908b7bcb4e94d0d1f932fd57547ac1e7f944" alt="$ j$"
data:image/s3,"s3://crabby-images/d442f/d442fc99105470e8d250f53514fda9af4190ed07" alt="$ 2$"
data:image/s3,"s3://crabby-images/3d73f/3d73f65128822478c5f275de4285e2f54632f502" alt="$ n - j$"
data:image/s3,"s3://crabby-images/3d73f/3d73f65128822478c5f275de4285e2f54632f502" alt="$ n - j$"
data:image/s3,"s3://crabby-images/10049/1004908b7bcb4e94d0d1f932fd57547ac1e7f944" alt="$ j$"
Now the general Fibonacci polynomial (for a positive integer
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/88c39/88c391f706f54c263859dca618e4001737678e10" alt="$ 1 \times n$"
data:image/s3,"s3://crabby-images/a0a9e/a0a9e0dd3260ceae72cf61f9176e2fb617a03c79" alt="$ 1 \times 1$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/e113d/e113d50890c31fafd0f7c47b03269c6af7312a6b" alt="$ 1 \times 2$"
data:image/s3,"s3://crabby-images/ef2b1/ef2b10dde7fb0317f048d372b5f81fe923107ccc" alt="$ t^2 = xt + 1$"
data:image/s3,"s3://crabby-images/e237e/e237e50b397e055f40adbc73364e1721a60b1010" alt="$ A$"
data:image/s3,"s3://crabby-images/2f578/2f578b5fa2279e1458718274b45f908cbcc41080" alt="$ B$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/e113d/e113d50890c31fafd0f7c47b03269c6af7312a6b" alt="$ 1 \times 2$"
data:image/s3,"s3://crabby-images/ba548/ba548638496f4805870891af887597cd07e1835c" alt="$ y$"
Back on topic, we would like to ask whether
data:image/s3,"s3://crabby-images/e201a/e201af40c3aeeebcd347f6e34a08a9a492fb0fde" alt="$ \phi_n(x)$"
data:image/s3,"s3://crabby-images/272ef/272effee5d8a7938d20e0300f4c6cfb2ed1577b0" alt="$ \phi$"
Does there exist a function
data:image/s3,"s3://crabby-images/e2128/e2128bdb8b0bbd75f605f09b3be78d63d360ef5c" alt="$ \phi(x)$"
data:image/s3,"s3://crabby-images/67df1/67df19a7bd48f0ccafde01998b67cc1cce784c4a" alt="$ \lim_{n \to \infty} \phi_n(x) = \phi(x)$"
We might expect this function to be
data:image/s3,"s3://crabby-images/8c10a/8c10a4dfbe7c49d57c089c22800d1a3b5cd43d81" alt="$ \frac{x + \sqrt{x^2 + 4}}{2}$"
data:image/s3,"s3://crabby-images/8c2f7/8c2f7e7c6ce3e864cda16b3dc8ea3a95d854282e" alt="$ t^2 - xt - 1$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/8dfc5/8dfc5a7efb8371fa668dceb6bbd1a3969813fc26" alt="$ \frac{-x + \sqrt{x^2 + 4}}{2} < 1$"
Does there exist a notion of continued fraction expansion for some large class of functions?
Rational functions have an obvious choice of terminating simple continued fraction given by the corresponding Euclidean algorithm on polynomials (although it is no longer true that substituting integers will get us a valid simple continued fraction of a rational number; some quotients may be negative). This is an interesting perspective: the Euclidean algorithm then allows one to decompose rational functions uniquely into the composition of fractional linear transformations of the form
data:image/s3,"s3://crabby-images/5f961/5f9614055057301b79351952eb3a640c910d589b" alt="$ x \mapsto q + \frac{1}{x} = \frac{qx + 1}{x}$"
data:image/s3,"s3://crabby-images/139cb/139cb2b52ed08a4579ce2a21466bce6a6a6cc4d0" alt="$ q = Q(t)$"
This should remind you of the notion of a Taylor series, which essentially asks the question of what class of functions can be appropriately approximated by sequences of polynomials. Indeed, it is possible to ask the same kind of convergence questions for infinite continued fractions as it is for power series, although these questions are much harder to answer. (This appears to be a current area of active research.) A partial answer is provided by Euler's continued fraction formula, a rather beautiful identity which translates an infinite series into an infinite continued fraction and therefore allows a partial translation in the other direction, and it is here that I am, once again, out of details (although my hunch that hypergeometric functions are part of the answer appears to be correct.)
In closing, one application of the modular group is its use in verifying identities involving a fascinating set of functions called modular forms, which are functions that satisfy a "modular symmetry"; in other words, the modular group acts on them in a very specific way (as described in the article). This condition can be broken down into two conditions by looking at two generators of the modular group (which, we must stress, are not unique), and indeed this is the way a function is usually proven modular. A major application of this idea is to prove that two functions are identical by proving that they are both modular with the same value of
data:image/s3,"s3://crabby-images/7acd8/7acd84341707b49271cb5f3dcc527824f82230b0" alt="$ k$"
data:image/s3,"s3://crabby-images/22f07/22f077cc2686083c6eeae996a58659c539d8f056" alt="$ \mathbb{H}$"
data:image/s3,"s3://crabby-images/ddd35/ddd3565118818f442c1b6c57bef36d6f38dd92d7" alt="$ SL_2(\mathbb{R})$"
data:image/s3,"s3://crabby-images/22f07/22f077cc2686083c6eeae996a58659c539d8f056" alt="$ \mathbb{H}$"
First, we will need a few definitions. We say that
data:image/s3,"s3://crabby-images/ec47a/ec47a656c8243cac9ebb3efc26d6a87cbc4f996d" alt="$ z \sim w$"
data:image/s3,"s3://crabby-images/0707b/0707bb43692f6ce6d16b2e5b6c7c0a49a5f22b51" alt="$ \gamma$"
data:image/s3,"s3://crabby-images/b351b/b351be7d8e8ffc9afcde1be8e874a00ff2923f00" alt="$ \gamma(z) = w$"
data:image/s3,"s3://crabby-images/e45c3/e45c3f194dcc71e0849a8fc6e7fea0974863b689" alt="$ E_z$"
data:image/s3,"s3://crabby-images/9f26d/9f26daa5500054ca37e40b3467081176fd823ed9" alt="$ w$"
data:image/s3,"s3://crabby-images/a88c5/a88c5c2ac302fd8f4c56f486248a08b8223a26d7" alt="$ z \in \mathbb{H}$"
data:image/s3,"s3://crabby-images/080d9/080d91f4095980dec9b54844416f79aafa675dcb" alt="$ \mathcal{F} = \{ \tau \in \mathbb{H} : |\tau| \ge 1, |\Re{\tau}| \le 1 \}$"
Theorem (the Euclidean algorithm, take 5): For a given
data:image/s3,"s3://crabby-images/cb708/cb7080f1df1d51b4c40987022cb31c455a63b53f" alt="$ z$"
data:image/s3,"s3://crabby-images/e45c3/e45c3f194dcc71e0849a8fc6e7fea0974863b689" alt="$ E_z$"
data:image/s3,"s3://crabby-images/a88ab/a88ab7e7bc4405bce7c8b130b87b86ea277b8237" alt="$ \mathcal{F}$"
data:image/s3,"s3://crabby-images/e45c3/e45c3f194dcc71e0849a8fc6e7fea0974863b689" alt="$ E_z$"
data:image/s3,"s3://crabby-images/3a8e6/3a8e6836032c9c94350c1c68e8338f3d9f10f684" alt="$ z \mapsto - \frac{1}{z}$"
data:image/s3,"s3://crabby-images/ad147/ad147f21b8187bbcf09b9d1af9b38554c1b51174" alt="$ z \mapsto z + 1$"
The proof is left as an exercise. (Note that
data:image/s3,"s3://crabby-images/ad147/ad147f21b8187bbcf09b9d1af9b38554c1b51174" alt="$ z \mapsto z + 1$"
data:image/s3,"s3://crabby-images/3a8e6/3a8e6836032c9c94350c1c68e8338f3d9f10f684" alt="$ z \mapsto - \frac{1}{z}$"
data:image/s3,"s3://crabby-images/ba548/ba548638496f4805870891af887597cd07e1835c" alt="$ y$"
data:image/s3,"s3://crabby-images/a88ab/a88ab7e7bc4405bce7c8b130b87b86ea277b8237" alt="$ \mathcal{F}$"
data:image/s3,"s3://crabby-images/22f07/22f077cc2686083c6eeae996a58659c539d8f056" alt="$ \mathbb{H}$"
data:image/s3,"s3://crabby-images/a88ab/a88ab7e7bc4405bce7c8b130b87b86ea277b8237" alt="$ \mathcal{F}$"
data:image/s3,"s3://crabby-images/a88ab/a88ab7e7bc4405bce7c8b130b87b86ea277b8237" alt="$ \mathcal{F}$"
data:image/s3,"s3://crabby-images/a88ab/a88ab7e7bc4405bce7c8b130b87b86ea277b8237" alt="$ \mathcal{F}$"
Practice Problem 0: Prove that
data:image/s3,"s3://crabby-images/d48ea/d48eac82642f6506a3d817c26a8a7336c9c8b1a9" alt="$ F_{n+1}(x) = \sum_{j=0}^{\lfloor \frac{n}{2} \rfloor} {n - j \choose j} x^{n-2j}$"
Practice Problem 1: Prove that a simple continued fraction is (eventually) periodic if and only if it is the real root of a quadratic polynomial with integer coefficients.
Practice Problem 2: Prove that if
data:image/s3,"s3://crabby-images/b0b9a/b0b9a318e61cf82f61ace48fa5022529faa94f27" alt="$ (x, y)$"
data:image/s3,"s3://crabby-images/2ef49/2ef49128193e9b0dd2150dcf2a88ee4ef68ed803" alt="$ x^2 - dy^2 = 1$"
data:image/s3,"s3://crabby-images/e6986/e6986f09cc7041074e0bd2861eb37ca512477e9a" alt="$ \frac{x}{y}$"
data:image/s3,"s3://crabby-images/38652/38652942d943149abee963e2575e8a6e360d7037" alt="$ \sqrt{d}$"
Practice Problem 3: What is the best constant
data:image/s3,"s3://crabby-images/7acd8/7acd84341707b49271cb5f3dcc527824f82230b0" alt="$ k$"
data:image/s3,"s3://crabby-images/5f2ba/5f2ba7ef0867538b014c3dd521aebfc91e14d292" alt="$ \left| \frac{r}{s} - x \right| < \frac{1}{ks^2}$"
data:image/s3,"s3://crabby-images/78441/784415fd5c946f33c9c6965d84879129c3df05b0" alt="$ \frac{r}{s}$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/c4291/c42917d0e5ea0c4bfcb72d5eed01910e483dcc83" alt="$ x$"
data:image/s3,"s3://crabby-images/272ef/272effee5d8a7938d20e0300f4c6cfb2ed1577b0" alt="$ \phi$"
Practice Problem 4: Prove Take 5.