4
$\begingroup$

Is there a method for finding a primitive element (generator) of $(\mathbb Z/p\mathbb{Z})^*$, where $p$ is a prime number?

  • 0
    you mean a primitive root of unity?2012-01-14
  • 0
    No i mean: A group G which contains an element a with maximum order ord(a) = |G| is said to be cyclic. Elements with maximum order are called primitive elements or generators.2012-01-14
  • 0
    But you referred to Zp specifically. Why not 1?2012-01-14
  • 0
    What do you mean with "Why not 1?".2012-01-14
  • 0
    you mean Zp, the group of integers modulo p, under the operation of addition modulo p, right? 1 is a generator for that group.2012-01-14
  • 2
    No I mean Zp in respect of multiplication modulo p.2012-01-14
  • 1
    That is, the group of nonzero integers mod p, under multiplication mod p. Then you are asking for primitive roots of unity mod p!2012-01-14
  • 2
    http://en.wikipedia.org/wiki/Primitive_root_modulo_n2012-01-14
  • 2
    The same link you have provided contains a detailed answer you are looking for, see [this](http://en.wikipedia.org/wiki/Primitive_root_modulo_n#Finding_primitive_roots) @gosom2012-01-14
  • 4
    The references provided in that article should provide further methods. I've that Cohen's book is pretty good, for example.2012-01-14
  • 1
    Check out Section 4.8 (computing n-th primitive root of unity) in *Algorithms For Computer Algebra* by Keith O. Geddes, Stephen R. Czapor, George Labahn.2012-01-14
  • 0
    If $p$ is of the form $2^\alpha + 1$ then the primitive elements are precisely the quadratic non-residues2012-05-22

1 Answers 1

3

William Stein has a webpage on the problem of finding generators for $(\mathbb{Z}/p\mathbb{Z})^*$.

There are some probabilistic polytime algorithms for finding primitive roots. Also assuming the Extended Riemann Hypothesis, there are polytime algorithms.

However in general no efficient (fast) algorithm is known.