fbpx
Wikipedia

Tonelli–Shanks algorithm

The Tonelli–Shanks algorithm (referred to by Shanks as the RESSOL algorithm) is used in modular arithmetic to solve for r in a congruence of the form r2n (mod p), where p is a prime: that is, to find a square root of n modulo p.

Tonelli–Shanks cannot be used for composite moduli: finding square roots modulo composite numbers is a computational problem equivalent to integer factorization.[1]

An equivalent, but slightly more redundant version of this algorithm was developed by Alberto Tonelli[2][3] in 1891. The version discussed here was developed independently by Daniel Shanks in 1973, who explained:

My tardiness in learning of these historical references was because I had lent Volume 1 of Dickson's History to a friend and it was never returned.[4]

According to Dickson,[3] Tonelli's algorithm can take square roots of x modulo prime powers pλ apart from primes.

Core ideas edit

Given a non-zero   and a prime   (which will always be odd), Euler's criterion tells us that   has a square root (i.e.,   is a quadratic residue) if and only if:

 .

In contrast, if a number   has no square root (is a non-residue), Euler's criterion tells us that:

 .

It is not hard to find such  , because half of the integers between 1 and   have this property. So we assume that we have access to such a non-residue.

By (normally) dividing by 2 repeatedly, we can write   as  , where   is odd. Note that if we try

 ,

then  . If  , then   is a square root of  . Otherwise, for  , we have   and   satisfying:

  •  ; and
  •   is a  -th root of 1 (because  ).

If, given a choice of   and   for a particular   satisfying the above (where   is not a square root of  ), we can easily calculate another   and   for   such that the above relations hold, then we can repeat this until   becomes a  -th root of 1, i.e.,  . At that point   is a square root of  .

We can check whether   is a  -th root of 1 by squaring it   times and check whether it is 1. If it is, then we do not need to do anything, as the same choice of   and   works. But if it is not,   must be -1 (because squaring it gives 1, and there can only be two square roots 1 and -1 of 1 modulo  ).

To find a new pair of   and  , we can multiply   by a factor  , to be determined. Then   must be multiplied by a factor   to keep  . So, when   is -1, we need to find a factor   so that   is a  -th root of 1, or equivalently   is a  -th root of -1.

The trick here is to make use of  , the known non-residue. The Euler's criterion applied to   shown above says that   is a  -th root of -1. So by squaring   repeatedly, we have access to a sequence of  -th root of -1. We can select the right one to serve as  . With a little bit of variable maintenance and trivial case compression, the algorithm below emerges naturally.

The algorithm edit

Operations and comparisons on elements of the multiplicative group of integers modulo p   are implicitly mod p.

Inputs:

  • p, a prime
  • n, an element of   such that solutions to the congruence r2 = n exist; when this is so we say that n is a quadratic residue mod p.

Outputs:

  • r in   such that r2 = n

Algorithm:

  1. By factoring out powers of 2, find Q and S such that   with Q odd
  2. Search for a z in   which is a quadratic non-residue
  3. Let
     
  4. Loop:
    • If t = 0, return r = 0
    • If t = 1, return r = R
    • Otherwise, use repeated squaring to find the least i, 0 < i < M, such that  
    • Let  , and set
       

Once you have solved the congruence with r the second solution is  . If the least i such that   is M, then no solution to the congruence exists, i.e. n is not a quadratic residue.

This is most useful when p ≡ 1 (mod 4).

For primes such that p ≡ 3 (mod 4), this problem has possible solutions  . If these satisfy  , they are the only solutions. If not,  , n is a quadratic non-residue, and there are no solutions.

Proof edit

We can show that at the start of each iteration of the loop the following loop invariants hold:

  •  
  •  
  •  

Initially:

  •   (since z is a quadratic nonresidue, per Euler's criterion)
  •   (since n is a quadratic residue)
  •  

At each iteration, with M' , c' , t' , R' the new values replacing M, c, t, R:

  •  
  •  
    •   since we have that   but   (i is the least value such that  )
    •  
  •  

From   and the test against t = 1 at the start of the loop, we see that we will always find an i in 0 < i < M such that  . M is strictly smaller on each iteration, and thus the algorithm is guaranteed to halt. When we hit the condition t = 1 and halt, the last loop invariant implies that R2 = n.

Order of t edit

We can alternately express the loop invariants using the order of the elements:

  •  
  •  
  •   as before

Each step of the algorithm moves t into a smaller subgroup by measuring the exact order of t and multiplying it by an element of the same order.

Example edit

Solving the congruence r2 ≡ 5 (mod 41). 41 is prime as required and 41 ≡ 1 (mod 4). 5 is a quadratic residue by Euler's criterion:   (as before, operations in   are implicitly mod 41).

  1.   so  ,  
  2. Find a value for z:
    •  , so 2 is a quadratic residue by Euler's criterion.
    •  , so 3 is a quadratic nonresidue: set  
  3. Set
    •  
    •  
    •  
    •  
  4. Loop:
    • First iteration:
      •  , so we're not finished
      •  ,   so  
      •  
      •  
      •  
      •  
      •  
    • Second iteration:
      •  , so we're still not finished
      •   so  
      •  
      •  
      •  
      •  
      •  
    • Third iteration:
      •  , and we are finished; return  

Indeed, 282 ≡ 5 (mod 41) and (−28)2 ≡ 132 ≡ 5 (mod 41). So the algorithm yields the two solutions to our congruence.

Speed of the algorithm edit

The Tonelli–Shanks algorithm requires (on average over all possible input (quadratic residues and quadratic nonresidues))

 

modular multiplications, where   is the number of digits in the binary representation of   and   is the number of ones in the binary representation of  . If the required quadratic nonresidue   is to be found by checking if a randomly taken number   is a quadratic nonresidue, it requires (on average)   computations of the Legendre symbol.[5] The average of two computations of the Legendre symbol are explained as follows:   is a quadratic residue with chance  , which is smaller than   but  , so we will on average need to check if a   is a quadratic residue two times.

This shows essentially that the Tonelli–Shanks algorithm works very well if the modulus   is random, that is, if   is not particularly large with respect to the number of digits in the binary representation of  . As written above, Cipolla's algorithm works better than Tonelli–Shanks if (and only if)  . However, if one instead uses Sutherland's algorithm to perform the discrete logarithm computation in the 2-Sylow subgroup of  , one may replace   with an expression that is asymptotically bounded by  .[6] Explicitly, one computes   such that   and then   satisfies   (note that   is a multiple of 2 because   is a quadratic residue).

The algorithm requires us to find a quadratic nonresidue  . There is no known deterministic algorithm that runs in polynomial time for finding such a  . However, if the generalized Riemann hypothesis is true, there exists a quadratic nonresidue  ,[7] making it possible to check every   up to that limit and find a suitable   within polynomial time. Keep in mind, however, that this is a worst-case scenario; in general,   is found in on average 2 trials as stated above.

Uses edit

The Tonelli–Shanks algorithm can (naturally) be used for any process in which square roots modulo a prime are necessary. For example, it can be used for finding points on elliptic curves. It is also useful for the computations in the Rabin cryptosystem and in the sieving step of the quadratic sieve.

Generalizations edit

Tonelli–Shanks can be generalized to any cyclic group (instead of  ) and to kth roots for arbitrary integer k, in particular to taking the kth root of an element of a finite field.[8]

If many square-roots must be done in the same cyclic group and S is not too large, a table of square-roots of the elements of 2-power order can be prepared in advance and the algorithm simplified and sped up as follows.

  1. Factor out powers of 2 from p − 1, defining Q and S as:   with Q odd.
  2. Let  
  3. Find   from the table such that   and set  
  4. return R.

Tonelli's algorithm will work on mod p^k edit

According to Dickson's "Theory of Numbers"[3]

A. Tonelli[9] gave an explicit formula for the roots of  [3]

The Dickson reference shows the following formula for the square root of  .

when  , or   (s must be 2 for this equation) and   such that  
for   then
  where  

Noting that   and noting that   then

 

To take another example:   and

 

Dickson also attributes the following equation to Tonelli:

  where   and  ;

Using   and using the modulus of   the math follows:

 

First, find the modular square root mod   which can be done by the regular Tonelli algorithm:

  and thus  

And applying Tonelli's equation (see above):

 

Dickson's reference[3] clearly shows that Tonelli's algorithm works on moduli of  .

Notes edit

  1. ^ Oded Goldreich, Computational complexity: a conceptual perspective, Cambridge University Press, 2008, p. 588.
  2. ^ Volker Diekert; Manfred Kufleitner; Gerhard Rosenberger; Ulrich Hertrampf (24 May 2016). Discrete Algebraic Methods: Arithmetic, Cryptography, Automata and Groups. De Gruyter. pp. 163–165. ISBN 978-3-11-041632-9.
  3. ^ a b c d e Leonard Eugene Dickson (1919). History of the Theory of Numbers. Vol. 1. Washington, Carnegie Institution of Washington. pp. 215–216.
  4. ^ Daniel Shanks. Five Number-theoretic Algorithms. Proceedings of the Second Manitoba Conference on Numerical Mathematics. Pp. 51–70. 1973.
  5. ^ Gonzalo Tornaria - Square roots modulo p, page 2 https://doi.org/10.1007%2F3-540-45995-2_38
  6. ^ Sutherland, Andrew V. (2011), "Structure computation and discrete logarithms in finite abelian p-groups", Mathematics of Computation, 80 (273): 477–500, arXiv:0809.3413, doi:10.1090/s0025-5718-10-02356-2, S2CID 13940949
  7. ^ Bach, Eric (1990), "Explicit bounds for primality testing and related problems", Mathematics of Computation, 55 (191): 355–380, doi:10.2307/2008811, JSTOR 2008811
  8. ^ Adleman, L. M., K. Manders, and G. Miller: 1977, `On taking roots in finite fields'. In: 18th IEEE Symposium on Foundations of Computer Science. pp. 175-177
  9. ^ "Accademia nazionale dei Lincei, Rome. Rendiconti, (5), 1, 1892, 116-120."

References edit

  • Ivan Niven; Herbert S. Zuckerman; Hugh L. Montgomery (1991). An Introduction to the Theory of Numbers (5th ed.). Wiley. pp. 110–115. ISBN 0-471-62546-9.
  • Daniel Shanks. Five Number Theoretic Algorithms. Proceedings of the Second Manitoba Conference on Numerical Mathematics. Pp. 51–70. 1973.
  • Alberto Tonelli, Bemerkung über die Auflösung quadratischer Congruenzen. Nachrichten von der Königlichen Gesellschaft der Wissenschaften und der Georg-Augusts-Universität zu Göttingen. Pp. 344–346. 1891. [1]
  • Gagan Tara Nanda - Mathematics 115: The RESSOL Algorithm [2]
  • Gonzalo Tornaria [3]

tonelli, shanks, algorithm, referred, shanks, ressol, algorithm, used, modular, arithmetic, solve, congruence, form, where, prime, that, find, square, root, modulo, tonelli, shanks, cannot, used, composite, moduli, finding, square, roots, modulo, composite, nu. The Tonelli Shanks algorithm referred to by Shanks as the RESSOL algorithm is used in modular arithmetic to solve for r in a congruence of the form r2 n mod p where p is a prime that is to find a square root of n modulo p Tonelli Shanks cannot be used for composite moduli finding square roots modulo composite numbers is a computational problem equivalent to integer factorization 1 An equivalent but slightly more redundant version of this algorithm was developed by Alberto Tonelli 2 3 in 1891 The version discussed here was developed independently by Daniel Shanks in 1973 who explained My tardiness in learning of these historical references was because I had lent Volume 1 of Dickson s History to a friend and it was never returned 4 According to Dickson 3 Tonelli s algorithm can take square roots of x modulo prime powers pl apart from primes Contents 1 Core ideas 2 The algorithm 3 Proof 3 1 Order of t 4 Example 5 Speed of the algorithm 6 Uses 7 Generalizations 7 1 Tonelli s algorithm will work on mod p k 8 Notes 9 ReferencesCore ideas editGiven a non zero n displaystyle n nbsp and a prime p gt 2 displaystyle p gt 2 nbsp which will always be odd Euler s criterion tells us that n displaystyle n nbsp has a square root i e n displaystyle n nbsp is a quadratic residue if and only if n p 1 2 1 mod p displaystyle n frac p 1 2 equiv 1 pmod p nbsp In contrast if a number z displaystyle z nbsp has no square root is a non residue Euler s criterion tells us that z p 1 2 1 mod p displaystyle z frac p 1 2 equiv 1 pmod p nbsp It is not hard to find such z displaystyle z nbsp because half of the integers between 1 and p 1 displaystyle p 1 nbsp have this property So we assume that we have access to such a non residue By normally dividing by 2 repeatedly we can write p 1 displaystyle p 1 nbsp as Q 2 S displaystyle Q2 S nbsp where Q displaystyle Q nbsp is odd Note that if we try R n Q 1 2 mod p displaystyle R equiv n frac Q 1 2 pmod p nbsp then R 2 n Q 1 n n Q mod p displaystyle R 2 equiv n Q 1 n n Q pmod p nbsp If t n Q 1 mod p displaystyle t equiv n Q equiv 1 pmod p nbsp then R displaystyle R nbsp is a square root of n displaystyle n nbsp Otherwise for M S displaystyle M S nbsp we have R displaystyle R nbsp and t displaystyle t nbsp satisfying R 2 n t mod p displaystyle R 2 equiv nt pmod p nbsp and t displaystyle t nbsp is a 2 M 1 displaystyle 2 M 1 nbsp th root of 1 because t 2 M 1 t 2 S 1 n Q 2 S 1 n p 1 2 displaystyle t 2 M 1 t 2 S 1 equiv n Q2 S 1 n frac p 1 2 nbsp If given a choice of R displaystyle R nbsp and t displaystyle t nbsp for a particular M displaystyle M nbsp satisfying the above where R displaystyle R nbsp is not a square root of n displaystyle n nbsp we can easily calculate another R displaystyle R nbsp and t displaystyle t nbsp for M 1 displaystyle M 1 nbsp such that the above relations hold then we can repeat this until t displaystyle t nbsp becomes a 2 0 displaystyle 2 0 nbsp th root of 1 i e t 1 displaystyle t 1 nbsp At that point R displaystyle R nbsp is a square root of n displaystyle n nbsp We can check whether t displaystyle t nbsp is a 2 M 2 displaystyle 2 M 2 nbsp th root of 1 by squaring it M 2 displaystyle M 2 nbsp times and check whether it is 1 If it is then we do not need to do anything as the same choice of R displaystyle R nbsp and t displaystyle t nbsp works But if it is not t 2 M 2 displaystyle t 2 M 2 nbsp must be 1 because squaring it gives 1 and there can only be two square roots 1 and 1 of 1 modulo p displaystyle p nbsp To find a new pair of R displaystyle R nbsp and t displaystyle t nbsp we can multiply R displaystyle R nbsp by a factor b displaystyle b nbsp to be determined Then t displaystyle t nbsp must be multiplied by a factor b 2 displaystyle b 2 nbsp to keep R 2 n t mod p displaystyle R 2 equiv nt pmod p nbsp So when t 2 M 2 displaystyle t 2 M 2 nbsp is 1 we need to find a factor b 2 displaystyle b 2 nbsp so that t b 2 displaystyle tb 2 nbsp is a 2 M 2 displaystyle 2 M 2 nbsp th root of 1 or equivalently b 2 displaystyle b 2 nbsp is a 2 M 2 displaystyle 2 M 2 nbsp th root of 1 The trick here is to make use of z displaystyle z nbsp the known non residue The Euler s criterion applied to z displaystyle z nbsp shown above says that z Q displaystyle z Q nbsp is a 2 S 1 displaystyle 2 S 1 nbsp th root of 1 So by squaring z Q displaystyle z Q nbsp repeatedly we have access to a sequence of 2 i displaystyle 2 i nbsp th root of 1 We can select the right one to serve as b displaystyle b nbsp With a little bit of variable maintenance and trivial case compression the algorithm below emerges naturally The algorithm editOperations and comparisons on elements of the multiplicative group of integers modulo p Z p Z displaystyle mathbb Z p mathbb Z nbsp are implicitly mod p Inputs p a prime n an element of Z p Z displaystyle mathbb Z p mathbb Z nbsp such that solutions to the congruence r2 n exist when this is so we say that n is a quadratic residue mod p Outputs r in Z p Z displaystyle mathbb Z p mathbb Z nbsp such that r2 nAlgorithm By factoring out powers of 2 find Q and S such that p 1 Q 2 S displaystyle p 1 Q2 S nbsp with Q odd Search for a z in Z p Z displaystyle mathbb Z p mathbb Z nbsp which is a quadratic non residue Half of the elements in the set will be quadratic non residues Candidates can be tested with Euler s criterion or by finding the Jacobi symbol Let M S c z Q t n Q R n Q 1 2 displaystyle begin aligned M amp leftarrow S c amp leftarrow z Q t amp leftarrow n Q R amp leftarrow n frac Q 1 2 end aligned nbsp Loop If t 0 return r 0 If t 1 return r R Otherwise use repeated squaring to find the least i 0 lt i lt M such that t 2 i 1 displaystyle t 2 i 1 nbsp Let b c 2 M i 1 displaystyle b leftarrow c 2 M i 1 nbsp and set M i c b 2 t t b 2 R R b displaystyle begin aligned M amp leftarrow i c amp leftarrow b 2 t amp leftarrow tb 2 R amp leftarrow Rb end aligned nbsp Once you have solved the congruence with r the second solution is r mod p displaystyle r pmod p nbsp If the least i such that t 2 i 1 displaystyle t 2 i 1 nbsp is M then no solution to the congruence exists i e n is not a quadratic residue This is most useful when p 1 mod 4 For primes such that p 3 mod 4 this problem has possible solutions r n p 1 4 mod p displaystyle r pm n frac p 1 4 pmod p nbsp If these satisfy r 2 n mod p displaystyle r 2 equiv n pmod p nbsp they are the only solutions If not r 2 n mod p displaystyle r 2 equiv n pmod p nbsp n is a quadratic non residue and there are no solutions Proof editWe can show that at the start of each iteration of the loop the following loop invariants hold c 2 M 1 1 displaystyle c 2 M 1 1 nbsp t 2 M 1 1 displaystyle t 2 M 1 1 nbsp R 2 t n displaystyle R 2 tn nbsp Initially c 2 M 1 z Q 2 S 1 z p 1 2 1 displaystyle c 2 M 1 z Q2 S 1 z frac p 1 2 1 nbsp since z is a quadratic nonresidue per Euler s criterion t 2 M 1 n Q 2 S 1 n p 1 2 1 displaystyle t 2 M 1 n Q2 S 1 n frac p 1 2 1 nbsp since n is a quadratic residue R 2 n Q 1 t n displaystyle R 2 n Q 1 tn nbsp At each iteration with M c t R the new values replacing M c t R c 2 M 1 b 2 2 i 1 c 2 M i 2 i 1 c 2 M 1 1 displaystyle c 2 M 1 b 2 2 i 1 c 2 M i 2 i 1 c 2 M 1 1 nbsp t 2 M 1 t b 2 2 i 1 t 2 i 1 b 2 i 1 1 1 displaystyle t 2 M 1 tb 2 2 i 1 t 2 i 1 b 2 i 1 cdot 1 1 nbsp t 2 i 1 1 displaystyle t 2 i 1 1 nbsp since we have that t 2 i 1 displaystyle t 2 i 1 nbsp but t 2 i 1 1 displaystyle t 2 i 1 neq 1 nbsp i is the least value such that t 2 i 1 displaystyle t 2 i 1 nbsp b 2 i c 2 M i 1 2 i c 2 M 1 1 displaystyle b 2 i c 2 M i 1 2 i c 2 M 1 1 nbsp R 2 R 2 b 2 t n b 2 t n displaystyle R 2 R 2 b 2 tnb 2 t n nbsp From t 2 M 1 1 displaystyle t 2 M 1 1 nbsp and the test against t 1 at the start of the loop we see that we will always find an i in 0 lt i lt M such that t 2 i 1 displaystyle t 2 i 1 nbsp M is strictly smaller on each iteration and thus the algorithm is guaranteed to halt When we hit the condition t 1 and halt the last loop invariant implies that R2 n Order of t edit We can alternately express the loop invariants using the order of the elements ord c 2 M displaystyle operatorname ord c 2 M nbsp ord t 2 M 1 displaystyle operatorname ord t 2 M 1 nbsp R 2 t n displaystyle R 2 tn nbsp as beforeEach step of the algorithm moves t into a smaller subgroup by measuring the exact order of t and multiplying it by an element of the same order Example editSolving the congruence r2 5 mod 41 41 is prime as required and 41 1 mod 4 5 is a quadratic residue by Euler s criterion 5 41 1 2 5 20 1 displaystyle 5 frac 41 1 2 5 20 1 nbsp as before operations in Z 41 Z displaystyle mathbb Z 41 mathbb Z times nbsp are implicitly mod 41 p 1 40 5 2 3 displaystyle p 1 40 5 cdot 2 3 nbsp so Q 5 displaystyle Q leftarrow 5 nbsp S 3 displaystyle S leftarrow 3 nbsp Find a value for z 2 41 1 2 1 displaystyle 2 frac 41 1 2 1 nbsp so 2 is a quadratic residue by Euler s criterion 3 41 1 2 40 1 displaystyle 3 frac 41 1 2 40 1 nbsp so 3 is a quadratic nonresidue set z 3 displaystyle z leftarrow 3 nbsp Set M S 3 displaystyle M leftarrow S 3 nbsp c z Q 3 5 38 displaystyle c leftarrow z Q 3 5 38 nbsp t n Q 5 5 9 displaystyle t leftarrow n Q 5 5 9 nbsp R n Q 1 2 5 5 1 2 2 displaystyle R leftarrow n frac Q 1 2 5 frac 5 1 2 2 nbsp Loop First iteration t 1 displaystyle t neq 1 nbsp so we re not finished t 2 1 40 displaystyle t 2 1 40 nbsp t 2 2 1 displaystyle t 2 2 1 nbsp so i 2 displaystyle i leftarrow 2 nbsp b c 2 M i 1 38 2 3 2 1 38 displaystyle b leftarrow c 2 M i 1 38 2 3 2 1 38 nbsp M i 2 displaystyle M leftarrow i 2 nbsp c b 2 38 2 9 displaystyle c leftarrow b 2 38 2 9 nbsp t t b 2 9 9 40 displaystyle t leftarrow tb 2 9 cdot 9 40 nbsp R R b 2 38 35 displaystyle R leftarrow Rb 2 cdot 38 35 nbsp Second iteration t 1 displaystyle t neq 1 nbsp so we re still not finished t 2 1 1 displaystyle t 2 1 1 nbsp so i 1 displaystyle i leftarrow 1 nbsp b c 2 M i 1 9 2 2 1 1 9 displaystyle b leftarrow c 2 M i 1 9 2 2 1 1 9 nbsp M i 1 displaystyle M leftarrow i 1 nbsp c b 2 9 2 40 displaystyle c leftarrow b 2 9 2 40 nbsp t t b 2 40 40 1 displaystyle t leftarrow tb 2 40 cdot 40 1 nbsp R R b 35 9 28 displaystyle R leftarrow Rb 35 cdot 9 28 nbsp Third iteration t 1 displaystyle t 1 nbsp and we are finished return r R 28 displaystyle r R 28 nbsp Indeed 282 5 mod 41 and 28 2 132 5 mod 41 So the algorithm yields the two solutions to our congruence Speed of the algorithm editThe Tonelli Shanks algorithm requires on average over all possible input quadratic residues and quadratic nonresidues 2 m 2 k S S 1 4 1 2 S 1 9 displaystyle 2m 2k frac S S 1 4 frac 1 2 S 1 9 nbsp modular multiplications where m displaystyle m nbsp is the number of digits in the binary representation of p displaystyle p nbsp and k displaystyle k nbsp is the number of ones in the binary representation of p displaystyle p nbsp If the required quadratic nonresidue z displaystyle z nbsp is to be found by checking if a randomly taken number y displaystyle y nbsp is a quadratic nonresidue it requires on average 2 displaystyle 2 nbsp computations of the Legendre symbol 5 The average of two computations of the Legendre symbol are explained as follows y displaystyle y nbsp is a quadratic residue with chance p 1 2 p 1 1 p 2 displaystyle tfrac tfrac p 1 2 p tfrac 1 tfrac 1 p 2 nbsp which is smaller than 1 displaystyle 1 nbsp but 1 2 displaystyle geq tfrac 1 2 nbsp so we will on average need to check if a y displaystyle y nbsp is a quadratic residue two times This shows essentially that the Tonelli Shanks algorithm works very well if the modulus p displaystyle p nbsp is random that is if S displaystyle S nbsp is not particularly large with respect to the number of digits in the binary representation of p displaystyle p nbsp As written above Cipolla s algorithm works better than Tonelli Shanks if and only if S S 1 gt 8 m 20 displaystyle S S 1 gt 8m 20 nbsp However if one instead uses Sutherland s algorithm to perform the discrete logarithm computation in the 2 Sylow subgroup of F p displaystyle mathbb F p nbsp one may replace S S 1 displaystyle S S 1 nbsp with an expression that is asymptotically bounded by O S log S log log S displaystyle O S log S log log S nbsp 6 Explicitly one computes e displaystyle e nbsp such that c e n Q displaystyle c e equiv n Q nbsp and then R c e 2 n Q 1 2 displaystyle R equiv c e 2 n Q 1 2 nbsp satisfies R 2 n displaystyle R 2 equiv n nbsp note that e displaystyle e nbsp is a multiple of 2 because n displaystyle n nbsp is a quadratic residue The algorithm requires us to find a quadratic nonresidue z displaystyle z nbsp There is no known deterministic algorithm that runs in polynomial time for finding such a z displaystyle z nbsp However if the generalized Riemann hypothesis is true there exists a quadratic nonresidue z lt 2 ln 2 p displaystyle z lt 2 ln 2 p nbsp 7 making it possible to check every z displaystyle z nbsp up to that limit and find a suitable z displaystyle z nbsp within polynomial time Keep in mind however that this is a worst case scenario in general z displaystyle z nbsp is found in on average 2 trials as stated above Uses editThe Tonelli Shanks algorithm can naturally be used for any process in which square roots modulo a prime are necessary For example it can be used for finding points on elliptic curves It is also useful for the computations in the Rabin cryptosystem and in the sieving step of the quadratic sieve Generalizations editTonelli Shanks can be generalized to any cyclic group instead of Z p Z displaystyle mathbb Z p mathbb Z times nbsp and to kth roots for arbitrary integer k in particular to taking the kth root of an element of a finite field 8 If many square roots must be done in the same cyclic group and S is not too large a table of square roots of the elements of 2 power order can be prepared in advance and the algorithm simplified and sped up as follows Factor out powers of 2 from p 1 defining Q and S as p 1 Q 2 S displaystyle p 1 Q2 S nbsp with Q odd Let R n Q 1 2 t n Q R 2 n displaystyle R leftarrow n frac Q 1 2 t leftarrow n Q equiv R 2 n nbsp Find b displaystyle b nbsp from the table such that b 2 t displaystyle b 2 equiv t nbsp and set R R b displaystyle R equiv R b nbsp return R Tonelli s algorithm will work on mod p k edit According to Dickson s Theory of Numbers 3 A Tonelli 9 gave an explicit formula for the roots of x 2 c mod p l displaystyle x 2 c pmod p lambda nbsp 3 The Dickson reference shows the following formula for the square root of x 2 mod p l displaystyle x 2 bmod p lambda nbsp when p 4 7 1 displaystyle p 4 cdot 7 1 nbsp or s 2 displaystyle s 2 nbsp s must be 2 for this equation and A 7 displaystyle A 7 nbsp such that 29 2 2 7 1 displaystyle 29 2 2 cdot 7 1 nbsp for x 2 mod p l c displaystyle x 2 bmod p lambda equiv c nbsp thenx mod p l c A 3 b c b 1 2 displaystyle x bmod p lambda equiv pm c A 3 beta cdot c beta 1 2 nbsp where b a p l 1 displaystyle beta equiv a cdot p lambda 1 nbsp dd dd Noting that 23 2 mod 29 3 529 displaystyle 23 2 bmod 29 3 equiv 529 nbsp and noting that b 7 29 2 displaystyle beta 7 cdot 29 2 nbsp then 529 7 3 7 29 2 529 7 29 2 1 2 mod 29 3 24366 23 displaystyle 529 7 3 7 cdot 29 2 cdot 529 7 cdot 29 2 1 2 bmod 29 3 equiv 24366 equiv 23 nbsp To take another example 2333 2 mod 29 3 4142 displaystyle 2333 2 bmod 29 3 equiv 4142 nbsp and 4142 7 3 7 29 2 4142 7 29 2 1 2 mod 29 3 2333 displaystyle 4142 7 3 7 cdot 29 2 cdot 4142 7 cdot 29 2 1 2 bmod 29 3 equiv 2333 nbsp dd Dickson also attributes the following equation to Tonelli X mod p l x p l 1 c p l 2 p l 1 1 2 displaystyle X bmod p lambda equiv x p lambda 1 cdot c p lambda 2p lambda 1 1 2 nbsp where X 2 mod p l c displaystyle X 2 bmod p lambda equiv c nbsp and x 2 mod p c displaystyle x 2 bmod p equiv c nbsp Using p 23 displaystyle p 23 nbsp and using the modulus of p 3 displaystyle p 3 nbsp the math follows 1115 2 mod 23 3 2191 displaystyle 1115 2 bmod 23 3 2191 nbsp First find the modular square root mod p displaystyle p nbsp which can be done by the regular Tonelli algorithm 1115 2 mod 23 6 displaystyle 1115 2 bmod 23 equiv 6 nbsp and thus 6 mod 23 11 displaystyle sqrt 6 bmod 23 equiv 11 nbsp And applying Tonelli s equation see above 11 23 2 2191 23 3 2 23 2 1 2 mod 23 3 1115 displaystyle 11 23 2 cdot 2191 23 3 2 cdot 23 2 1 2 bmod 23 3 equiv 1115 nbsp Dickson s reference 3 clearly shows that Tonelli s algorithm works on moduli of p l displaystyle p lambda nbsp Notes edit Oded Goldreich Computational complexity a conceptual perspective Cambridge University Press 2008 p 588 Volker Diekert Manfred Kufleitner Gerhard Rosenberger Ulrich Hertrampf 24 May 2016 Discrete Algebraic Methods Arithmetic Cryptography Automata and Groups De Gruyter pp 163 165 ISBN 978 3 11 041632 9 a b c d e Leonard Eugene Dickson 1919 History of the Theory of Numbers Vol 1 Washington Carnegie Institution of Washington pp 215 216 Daniel Shanks Five Number theoretic Algorithms Proceedings of the Second Manitoba Conference on Numerical Mathematics Pp 51 70 1973 Gonzalo Tornaria Square roots modulo p page 2 https doi org 10 1007 2F3 540 45995 2 38 Sutherland Andrew V 2011 Structure computation and discrete logarithms in finite abelian p groups Mathematics of Computation 80 273 477 500 arXiv 0809 3413 doi 10 1090 s0025 5718 10 02356 2 S2CID 13940949 Bach Eric 1990 Explicit bounds for primality testing and related problems Mathematics of Computation 55 191 355 380 doi 10 2307 2008811 JSTOR 2008811 Adleman L M K Manders and G Miller 1977 On taking roots in finite fields In 18th IEEE Symposium on Foundations of Computer Science pp 175 177 Accademia nazionale dei Lincei Rome Rendiconti 5 1 1892 116 120 References editIvan Niven Herbert S Zuckerman Hugh L Montgomery 1991 An Introduction to the Theory of Numbers 5th ed Wiley pp 110 115 ISBN 0 471 62546 9 Daniel Shanks Five Number Theoretic Algorithms Proceedings of the Second Manitoba Conference on Numerical Mathematics Pp 51 70 1973 Alberto Tonelli Bemerkung uber die Auflosung quadratischer Congruenzen Nachrichten von der Koniglichen Gesellschaft der Wissenschaften und der Georg Augusts Universitat zu Gottingen Pp 344 346 1891 1 Gagan Tara Nanda Mathematics 115 The RESSOL Algorithm 2 Gonzalo Tornaria 3 Retrieved from https en wikipedia org w index php title Tonelli Shanks algorithm amp oldid 1175141791, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.