NO DOC
#include <iostream>
#define GIVARO_LENSTRA
#include <givaro/givintnumtheo.h>
#include <givaro/givtimer.h>
#ifndef TIMING
#define TIMING 1
#endif
int main(int argc, char** argv)
{
#ifndef __GIVARO_GMP_NO_CXX
IP.seeding();
#endif
uint64_t runs;
Integer phin; IP.
sub(phin,a,IP.
one);
std::vector<Integer> Lf;
IP.
write(std::cout <<
"Totient : ", Lf,phin) << std::endl;
for(uint64_t i = 0; i < TIMING; ++i)
IP.
prim_root_of_prime(pr, a);
IP.write( std::cout << "Deterministic : ", pr ) << std::endl;
std::cerr << tim << std::endl;
}
for(uint64_t i = 0; i < TIMING; ++i)
IP.write( std::cout << "Random : ", pr ) << std::endl;
std::cerr << tim << " (" << runs << " runs)" << std::endl;
for(uint64_t i = 0; i < TIMING; ++i)
IP.
lowest_prim_root(pr, a);
IP.write( std::cout << "Lowest : ", pr ) << std::endl;
std::cerr << tim << std::endl;
return 0;
}