diff options
author | Niels Möller <nisse@lysator.liu.se> | 2018-03-10 15:50:34 +0100 |
---|---|---|
committer | Niels Möller <nisse@lysator.liu.se> | 2018-03-10 15:50:34 +0100 |
commit | 98efe78d809d4fb09ffd278d36ef73d987f432d9 (patch) | |
tree | 9894cc8f85db19f6d7635f594e03fde67fa3129c /eccparams.c | |
parent | be5b2eda8461cbe2f586b82fc04a245e4d18da99 (diff) | |
download | nettle-98efe78d809d4fb09ffd278d36ef73d987f432d9.tar.gz |
New program eccparams.
Diffstat (limited to 'eccparams.c')
-rw-r--r-- | eccparams.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/eccparams.c b/eccparams.c new file mode 100644 index 00000000..60829770 --- /dev/null +++ b/eccparams.c @@ -0,0 +1,38 @@ +#include <stdio.h> +#include <stdlib.h> + +int +main (int argc, char **argv) +{ + unsigned bits; + unsigned max; + unsigned c; + if (argc < 3) + { + usage: + fprintf(stderr, "Usage: %s: exp-bits max-entries\n", argv[0]); + return EXIT_FAILURE; + } + bits = atoi(argv[1]); + if (bits < 2) + goto usage; + max = atoi(argv[2]); + if ( max < 2) + goto usage; + + for (c = 3; (1<<c) <= max; c++) + { + unsigned b; + for (b = 1;; b++) + { + unsigned s = (1<<c) * b; + unsigned k; + if (s > max) + break; + k = (bits + (c*b) - 1) / (c * b); + printf("k = %2u, c = %2u, S = %3u, T = %3u (%3u A + %2u D)\n", + k, c, s, (b+1)*k, b*k, k); + } + } + return 0; +} |