Previous Section
 < Day Day Up > 
Next Section


31.6 Powers of an element

Just as it is natural to consider the multiples of a given element a, modulo n, it is often natural to consider the sequence of powers of a, modulo n, where :

(31.29) 

modulo n. Indexing from 0, the 0th value in this sequence is a0 mod n = 1, and the ith value is ai mod n. For example, the powers of 3 modulo 7 are

i

0

1

2

3

4

5

6

7

8

9

10

11

3i mod 7

1

3

2

6

4

5

1

3

2

6

4

5

whereas the powers of 2 modulo 7 are

i

0

1

2

3

4

5

6

7

8

9

10

11

2i mod 7

1

2

4

1

2

4

1

2

4

1

2

4

In this section, let <a> denote the subgroup of generated by a by repeated multiplication, and let ordn(a) (the "order of a, modulo n") denote the order of a in . For example, <2> = {1, 2, 4} in , and ord7(2) = 3. Using the definition of the Euler phi function φ(n) as the size of (see Section 31.3), we now translate Corollary 31.19 into the notation of to obtain Euler's theorem and specialize it to , where p is prime, to obtain Fermat's theorem.

Theorem 31.30: (Euler's theorem)
Start example

For any integer n > 1,

End example
Theorem 31.31: (Fermat's theorem)
Start example

If p is prime, then

Proof By equation (31.20), φ(p) = p - 1 if p is prime.

End example

This corollary applies to every element in Zp except 0, since . For all a Zp, however, we have ap a (mod p) if p is prime.

If , then every element in is a power of g, modulo n, and we say that g is a primitive root or a generator of . For example, 3 is a primitive root, modulo 7, but 2 is not a primitive root, modulo 7. If possesses a primitive root, we say that the group is cyclic. We omit the proof of the following theorem, which is proven by Niven and Zuckerman [231].

Theorem 31.32
Start example

The values of n > 1 for which is cyclic are 2, 4, pe, and 2pe, for all primes p > 2 and all positive integers e.

End example

If g is a primitive root of and a is any element of , then there exists a z such that gz a (mod n). This z is called the discrete logarithm or index of a, modulo n, to the base g; we denote this value as indn,g(a).

Theorem 31.33: (Discrete logarithm theorem)
Start example

If g is a primitive root of , then the equation gx gy (mod n) holds if and only if the equation x y (mod φ(n)) holds.

Proof Suppose first that x y (mod φ(n)). Then, x = y + kφ(n) for some integer k. Therefore,

gx

gy+kφ(n)

(mod n)

 
 

gy · (gφ(n))k

(mod n)

 
 

gy · 1k

(mod n)

(by Euler's theorem)

 

gy

(mod n).

 

Conversely, suppose that gx gy (mod n). Because the sequence of powers of g generates every element of <g> and |<g>| = φ(n), Corollary 31.18 implies that the sequence of powers of g is periodic with period φ(n). Therefore, if gx gy (mod n), then we must have x y (mod φ(n)).

End example

Taking discrete logarithms can sometimes simplify reasoning about a modular equation, as illustrated in the proof of the following theorem.

Theorem 31.34
Start example

If p is an odd prime and e 1, then the equation

(31.30) 

has only two solutions, namely x = 1 and x = -1.

Proof Let n = pe. Theorem 31.32 implies that has a primitive root g. Equation (31.30) can be written

(31.31) 

After noting that indn,g(1) = 0, we observe that Theorem 31.33 implies that equation (31.31) is equivalent to

(31.32) 

To solve this equation for the unknown indn,g(x), we apply the methods of Section 31.4. By equation (31.19), we have φ(n) = pe(1 - 1/p) = (p - 1)pe-1. Letting d = gcd(2, φ(n)) = gcd(2, (p - 1) pe-1) = 2, and noting that d | 0, we find from Theorem 31.24 that equation (31.32) has exactly d = 2 solutions. Therefore, equation (31.30) has exactly 2 solutions, which are x = 1 and x = -1 by inspection.

End example

A number x is a nontrivial square root of 1, modulo n, if it satisfies the equation x2 1 (mod n) but x is equivalent to neither of the two "trivial" square roots: 1 or -1, modulo n. For example, 6 is a nontrivial square root of 1, modulo 35. The following corollary to Theorem 31.34 will be used in the correctness proof for the Miller-Rabin primality-testing procedure in Section 31.8.

Corollary 31.35
Start example

If there exists a nontrivial square root of 1, modulo n, then n is composite.

Proof By the contrapositive of Theorem 31.34, if there exists a nontrivial square root of 1, modulo n, then n can't be an odd prime or a power of an odd prime. If x2 1 (mod 2), then x 1 (mod 2), so all square roots of 1, modulo 2, are trivial. Thus, n cannot be prime. Finally, we must have n > 1 for a nontrivial square root of 1 to exist. Therefore, n must be composite.

End example

Raising to powers with repeated squaring

A frequently occurring operation in number-theoretic computations is raising one number to a power modulo another number, also known as modular exponentiation. More precisely, we would like an efficient way to compute ab mod n, where a and b are nonnegative integers and n is a positive integer. Modular exponentiation is an essential operation in many primality-testing routines and in the RSA public-key cryptosystem. The method of repeated squaring solves this problem efficiently using the binary representation of b.

Let <bk, bk-1, ..., b1, b0> be the binary representation of b. (That is, the binary representation is k + 1 bits long, bk is the most significant bit, and b0 is the least significant bit.) The following procedure computes ac mod n as c is increased by doublings and incrementations from 0 to b.

MODULAR-EXPONENTIATION(a, b, n)
 1  c  0
 2  d  1
 3  let <bk, bk-1, ..., b0> be the binary representation of b
 4  for i  k downto 0
 5        do c  2c
 6                  d  (d · d) mod n
 7                  if bi = 1
 8                            then c  c + 1
 9                                   d  (d · a) mod n
10  return d

The essential use of squaring in line 6 of each iteration explains the name "repeated squaring." As an example, for a = 7, b = 560, and n = 561, the algorithm computes the sequence of values modulo 561 shown in Figure 31.4; the sequence of exponents used is shown in the row of the table labeled by c.

Start Figure

i

9

8

7

6

5

4

3

2

1

0


bi

1

0

0

0

1

1

0

0

0

0

c

1

2

4

8

17

35

70

140

280

560

d

7

49

157

526

160

241

298

166

67

1

End Figure

Figure 31.4: The results of MODULAR-EXPONENTIATION when computing ab (mod n), where a = 7, b = 560 = <1000110000>, and n = 561. The values are shown after each execution of the for loop. The final result is 1.

The variable c is not really needed by the algorithm but is included for explanatory purposes; the algorithm maintains the following two-part loop invariant:

Just prior to each iteration of the for loop of lines 4-9,

  1. The value of c is the same as the prefix <bk, bk-1, ..., bi+1> of the binary representation of b, and

  2. d = ac mod n.

We use this loop invariant as follows:

  • Initialization: Initially, i = k, so that the prefix <bk, bk-1, ..., bi+1> is empty, which corresponds to c = 0. Moreover, d = 1 = a0 mod n.

  • Maintenance: Let c and d denote the values of c and d at the end of an iteration of the for loop, and thus the values prior to the next iteration. Each iteration updates c 2c (if bi = 0) or c 2c + 1 (if bi = 1), so that c will be correct prior to the next iteration. If bi = 0, then d = d2 mod n = (ac)2 mod n = a2c mod mod n. If bi = 1, then d = d2 a mod n = (ac)2a mod n =a2c+1 mod mod n. In either case, d = ac mod n prior to the next iteration.

  • Termination: At termination, i = -1. Thus, c = b, since c has the value of the prefix <bk, bk-1, ...,b0> of bs binary representation. Hence d = ac mod n = ab mod n.

If the inputs a, b, and n are β-bit numbers, then the total number of arithmetic operations required is O(β) and the total number of bit operations required is O(β3).

Exercises 31.6-1
Start example

Draw a table showing the order of every element in . Pick the smallest primitive root g and compute a table giving ind11,g(x) for all .

End example
Exercises 31.6-2
Start example

Give a modular exponentiation algorithm that examines the bits of b from right to left instead of left to right.

End example
Exercises 31.6-3
Start example

Assuming that you know φ (n), explain how to compute a-1 mod n for any using the procedure MODULAR-EXPONENTIATION.

End example


Previous Section
 < Day Day Up > 
Next Section