Chakravala method


The chakravala method is a cyclic algorithm to solve indeterminate quadratic equations, including Pell's equation. It is commonly attributed to Bhāskara II, although some attribute it to Jayadeva. Jayadeva pointed out that Brahmagupta's approach to solving equations of this type could be generalized, and he then described this general method, which was later refined by Bhāskara II in his Bijaganita treatise. He called it the Chakravala method: chakra meaning "wheel" in Sanskrit, a reference to the cyclic nature of the algorithm. C.-O. Selenius held that no European performances at the time of Bhāskara, nor much later, exceeded its marvellous height of mathematical complexity.
This method is also known as the cyclic method and contains traces of mathematical induction.

History

Chakra in Sanskrit means cycle. As per popular legend, Chakravala indicates a mythical range of mountains which orbits around the earth like a wall and not limited by light and darkness.
Brahmagupta in 628 CE studied indeterminate quadratic equations, including Pell's equation
for minimum integers x and y. Brahmagupta could solve it for several N, but not all.
Jayadeva and Bhaskara offered the first complete solution to the equation, using the chakravala method to find for the solution
This case was notorious for its difficulty, and was first solved in Europe by Brouncker in 1657–58 in response to a challenge by Fermat, using continued fractions. A method for the general problem was first completely described rigorously by Lagrange in 1766. Lagrange's method, however, requires the calculation of 21 successive convergents of the continued fraction for the square root of 61, while the chakravala method is much simpler. Selenius, in his assessment of the chakravala method, states
Hermann Hankel calls the chakravala method

The method

From Brahmagupta's identity, we observe that for given N,
For the equation, this allows the "composition" of two solution triples and into a new triple
In the general method, the main idea is that any triple can be composed with the trivial triple to get the new triple for any m. Assuming we started with a triple for which, this can be scaled down by k :
Since the signs inside the squares do not matter, the following substitutions are possible:
When a positive integer m is chosen so that /k is an integer, so are the other two numbers in the triple. Among such m, the method chooses one that minimizes the absolute value of m2N and hence that of /k. Then the substitution relations are applied for m equal to the chosen value. This results in a new triple. The process is repeated until a triple with is found. This method always terminates with a solution.
Optionally, we can stop when k is ±1, ±2, or ±4, as Brahmagupta's approach gives a solution for those cases.

Examples

''n'' = 61

The n = 61 case, issued as a challenge by Fermat many centuries later, was given by Bhaskara as an example.
We start with a solution for any k found by any means. In this case we can let b be 1, thus, since, we have the triple. Composing it with gives the triple, which is scaled down to get:
For 3 to divide and to be minimal, we choose, so that we have the triple. Now that k is −4, we can use Brahmagupta's idea: it can be scaled down to the rational solution, which composed with itself three times, with respectively, when k becomes square and scaling can be applied, this gives. Finally, such procedure can be repeated until the solution is found :. This is the minimal integer solution.

''n'' = 67

Suppose we are to solve for x and y.
We start with a solution for any k found by any means; in this case we can let b be 1, thus producing. At each step, we find an m > 0 such that k divides a + bm, and |m2 − 67| is minimal. We then update a, b, and k to and respectively.
;First iteration
We have. We want a positive integer m such that k divides a + bm, i.e. 3 divides 8 + m, and |m2 − 67| is minimal. The first condition implies that m is of the form 3t + 1, and among such m, the minimal value is attained for m = 7. Replacing with, we get the new values. That is, we have the new solution:
At this point, one round of the cyclic algorithm is complete.
;Second iteration
We now repeat the process. We have. We want an m > 0 such that k divides a + bm, i.e. 6 divides 41 + 5m, and |m2 − 67| is minimal. The first condition implies that m is of the form 6t + 5, and among such m, |m2 − 67| is minimal for m = 5. This leads to the new solution a = /6, etc.:
;Third iteration
For 7 to divide 90 + 11m, we must have m = 2 + 7t and among such m, we pick m = 9.
;Final solution
At this point, we could continue with the cyclic method, but since the right-hand side is among ±1, ±2, ±4, we can also use Brahmagupta's observation directly. Composing the triple with itself, we get
that is, we have the integer solution:
This equation approximates as to within a margin of about.