44 lines
1.0 KiB
44 lines
1.0 KiB
#include <cln/number.h>
|
|
#include <cln/io.h>
|
|
#include <cln/integer.h>
|
|
#include <cln/random.h>
|
|
#include <cstdlib>
|
|
#include <cstring>
|
|
#include <cln/timing.h>
|
|
#include <cl_print.h>
|
|
#include <cln/malloc.h>
|
|
#include <cln/abort.h>
|
|
|
|
int main (int argc, char * argv[])
|
|
{
|
|
int repetitions = 1;
|
|
if ((argc >= 3) && !strcmp(argv[1],"-r")) {
|
|
repetitions = atoi(argv[2]);
|
|
argc -= 2; argv += 2;
|
|
}
|
|
if (argc < 2)
|
|
exit(1);
|
|
cl_I m = cl_I(argv[1]);
|
|
cl_I M = (cl_I)1 << (intDsize*m);
|
|
cl_I a = random_I(M);
|
|
extern int cl_digits_algo;
|
|
// One run to fill the cache.
|
|
{
|
|
char* p = (cl_digits_algo = 0, cl_decimal_string(a));
|
|
char* q = (cl_digits_algo = 1, cl_decimal_string(a));
|
|
if (strcmp(p,q)) cl_abort();
|
|
free_hook(p);
|
|
free_hook(q);
|
|
}
|
|
// Now start the timing.
|
|
cl_digits_algo = 0;
|
|
{ CL_TIMING;
|
|
for (int rep = repetitions; rep > 0; rep--)
|
|
{ char* p = cl_decimal_string(a); free_hook(p); }
|
|
}
|
|
cl_digits_algo = 1;
|
|
{ CL_TIMING;
|
|
for (int rep = repetitions; rep > 0; rep--)
|
|
{ char* p = cl_decimal_string(a); free_hook(p); }
|
|
}
|
|
}
|