Time | Relative time | Primitive | Implementation | Compiler |
6397448 | 1.00 | claus | crypto_dh/claus/gmp | g++ -march=barcelona -O3 -fomit-frame-pointer (4.6.3) |
7950920 | 1.24 | claus | crypto_dh/claus/openssl | gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer |
8098104 | 1.27 | claus | crypto_dh/claus/cryptopp | g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer |
| | claus | crypto_dh/claus/ntl | g++ -m64 -O3 -fomit-frame-pointer |
566964 | 1.00 | curve2251 | crypto_dh/curve2251/relic/amd64-avx | gcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer (4.6.3) |
602676 | 1.06 | curve2251 | crypto_dh/curve2251/relic/amd64-clmul | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
1126308 | 1.99 | curve2251 | crypto_dh/curve2251/relic/amd64-ssse3 | gcc -funroll-loops -m64 -O2 -fomit-frame-pointer |
2793340 | 4.93 | curve2251 | crypto_dh/curve2251/mpfq | gcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer |
731084 | 1.00 | curve25519 | crypto_dh/curve25519/ref | gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3) |
1030488 | 1.41 | curve25519 | crypto_dh/curve25519/mpfq | gcc -m64 -march=core2 -O3 -fomit-frame-pointer |
551592 | 1.00 | ecfp256e | crypto_dh/ecfp256e/v01/w8s8 | gcc -m64 -O3 -fomit-frame-pointer (4.6.3) |
557464 | 1.01 | ecfp256e | crypto_dh/ecfp256e/v01/w8s4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
568432 | 1.03 | ecfp256e | crypto_dh/ecfp256e/v01/w8s2 | gcc -m64 -O3 -fomit-frame-pointer (4.6.3) |
592480 | 1.07 | ecfp256e | crypto_dh/ecfp256e/v01/w8s1 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
911256 | 1.65 | ecfp256e | crypto_dh/ecfp256e/v01/var | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
651116 | 1.00 | ecfp256h | crypto_dh/ecfp256h/v01/w8s8 | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3) |
657196 | 1.01 | ecfp256h | crypto_dh/ecfp256h/v01/w8s4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
669164 | 1.03 | ecfp256h | crypto_dh/ecfp256h/v01/w8s2 | gcc -O3 -fomit-frame-pointer |
695456 | 1.07 | ecfp256h | crypto_dh/ecfp256h/v01/w8s1 | gcc -m64 -march=corei7 -O3 -fomit-frame-pointer |
1100948 | 1.69 | ecfp256h | crypto_dh/ecfp256h/v01/var | gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer |
961412 | 1.00 | ecfp256i | crypto_dh/ecfp256i/v01/var | gcc -m64 -O3 -fomit-frame-pointer (4.6.3) |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s1 | gcc -m64 -O3 -fomit-frame-pointer (4.6.3) |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s2 | gcc -m64 -O3 -fomit-frame-pointer (4.6.3) |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s4 | gcc -m64 -O3 -fomit-frame-pointer (4.6.3) |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s8 | gcc -m64 -O3 -fomit-frame-pointer (4.6.3) |
580596 | 1.00 | ecfp256q | crypto_dh/ecfp256q/v01/w8s8 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
585872 | 1.01 | ecfp256q | crypto_dh/ecfp256q/v01/w8s4 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
597720 | 1.03 | ecfp256q | crypto_dh/ecfp256q/v01/w8s2 | gcc -m64 -O3 -fomit-frame-pointer |
620408 | 1.07 | ecfp256q | crypto_dh/ecfp256q/v01/w8s1 | gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer |
936752 | 1.61 | ecfp256q | crypto_dh/ecfp256q/v01/var | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
700520 | 1.00 | ecfp256s | crypto_dh/ecfp256s/v01/w8s8 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
707280 | 1.01 | ecfp256s | crypto_dh/ecfp256s/v01/w8s4 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
720472 | 1.03 | ecfp256s | crypto_dh/ecfp256s/v01/w8s2 | gcc -m64 -march=corei7 -O3 -fomit-frame-pointer |
747236 | 1.07 | ecfp256s | crypto_dh/ecfp256s/v01/w8s1 | gcc -m64 -march=corei7 -O3 -fomit-frame-pointer |
1189296 | 1.70 | ecfp256s | crypto_dh/ecfp256s/v01/var | gcc -m64 -march=nocona -O3 -fomit-frame-pointer |
1847380 | 1.00 | ed448goldilocks | crypto_dh/ed448goldilocks/amd64 (2014-10-12) | gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3) |
2066556 | 1.12 | ed448goldilocks | crypto_dh/ed448goldilocks/64 | gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer |
5705980 | 3.09 | ed448goldilocks | crypto_dh/ed448goldilocks/32 | gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer |
| | ed448goldilocks | crypto_dh/ed448goldilocks/arm32 | gcc -m64 -O3 -fomit-frame-pointer |
| | ed448goldilocks | crypto_dh/ed448goldilocks/neon | gcc -m64 -O3 -fomit-frame-pointer |
680888 | 1.00 | gls1271 | crypto_dh/gls1271/ref4 | gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3) |
319664 | 1.00 | gls254 | crypto_dh/gls254/ref | gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer (4.6.3) |
457740 | 1.43 | gls254 | crypto_dh/gls254/prot | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
458008 | 1.00 | gls254prot | crypto_dh/gls254prot/prot | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3) |
559688 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s32 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
560696 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s16 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
562952 | 1.01 | hecfp127i | crypto_dh/hecfp127i/v02/w8s08 | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
568648 | 1.02 | hecfp127i | crypto_dh/hecfp127i/v02/w8s04 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
581260 | 1.04 | hecfp127i | crypto_dh/hecfp127i/v02/w8s02 | gcc -m64 -march=nocona -O3 -fomit-frame-pointer |
605228 | 1.08 | hecfp127i | crypto_dh/hecfp127i/v02/w8s01 | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
991088 | 1.77 | hecfp127i | crypto_dh/hecfp127i/v02/var | gcc -O3 -fomit-frame-pointer |
426068 | 1.00 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s32glv4 | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
427608 | 1.00 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s16glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
431964 | 1.01 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s08glv4 | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
440352 | 1.03 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s04glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
457536 | 1.07 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s02glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
492112 | 1.16 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s01glv4 | gcc -m64 -march=k8 -O2 -fomit-frame-pointer |
666968 | 1.57 | hecfp128bk | crypto_dh/hecfp128bk/v02/varglv4 | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer |
424920 | 1.00 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s32glv4 | gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.6.3) |
426936 | 1.00 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s16glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
430004 | 1.01 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s08glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
438564 | 1.03 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s04glv4 | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer |
456064 | 1.07 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s02glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
490308 | 1.15 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s01glv4 | gcc -march=barcelona -O3 -fomit-frame-pointer |
665540 | 1.57 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/varglv4 | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer |
827248 | 1.00 | hecfp128i | crypto_dh/hecfp128i/v02/w8s32 | gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
828808 | 1.00 | hecfp128i | crypto_dh/hecfp128i/v02/w8s16 | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer |
832432 | 1.01 | hecfp128i | crypto_dh/hecfp128i/v02/w8s08 | gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
842448 | 1.02 | hecfp128i | crypto_dh/hecfp128i/v02/w8s04 | gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
860824 | 1.04 | hecfp128i | crypto_dh/hecfp128i/v02/w8s02 | gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
896772 | 1.08 | hecfp128i | crypto_dh/hecfp128i/v02/w8s01 | gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
1467792 | 1.77 | hecfp128i | crypto_dh/hecfp128i/v02/var | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer |
| | hecfp61e2bk | crypto_dh/hecfp61e2bk/v01/varglv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2bk | crypto_dh/hecfp61e2bk/v01/w8s01glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2bk | crypto_dh/hecfp61e2bk/v01/w8s02glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2bk | crypto_dh/hecfp61e2bk/v01/w8s04glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2bk | crypto_dh/hecfp61e2bk/v01/w8s08glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2bk | crypto_dh/hecfp61e2bk/v01/w8s16glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2bk | crypto_dh/hecfp61e2bk/v01/w8s32glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2i | crypto_dh/hecfp61e2i/v01/var | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2i | crypto_dh/hecfp61e2i/v01/w8s01 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2i | crypto_dh/hecfp61e2i/v01/w8s02 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2i | crypto_dh/hecfp61e2i/v01/w8s04 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2i | crypto_dh/hecfp61e2i/v01/w8s08 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2i | crypto_dh/hecfp61e2i/v01/w8s16 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp61e2i | crypto_dh/hecfp61e2i/v01/w8s32 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2bk | crypto_dh/hecfp64e2bk/v01/varglv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2bk | crypto_dh/hecfp64e2bk/v01/w8s01glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2bk | crypto_dh/hecfp64e2bk/v01/w8s02glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2bk | crypto_dh/hecfp64e2bk/v01/w8s04glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2bk | crypto_dh/hecfp64e2bk/v01/w8s08glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2bk | crypto_dh/hecfp64e2bk/v01/w8s16glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2bk | crypto_dh/hecfp64e2bk/v01/w8s32glv8 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2i | crypto_dh/hecfp64e2i/v01/var | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2i | crypto_dh/hecfp64e2i/v01/w8s01 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2i | crypto_dh/hecfp64e2i/v01/w8s02 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2i | crypto_dh/hecfp64e2i/v01/w8s04 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2i | crypto_dh/hecfp64e2i/v01/w8s08 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2i | crypto_dh/hecfp64e2i/v01/w8s16 | gcc -m64 -O3 -fomit-frame-pointer |
| | hecfp64e2i | crypto_dh/hecfp64e2i/v01/w8s32 | gcc -m64 -O3 -fomit-frame-pointer |
2298696 | 1.00 | hector | crypto_dh/hector/ref | gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer (4.6.3) |
459940 | 1.00 | kumfp127g | crypto_dh/kumfp127g/v02/var | gcc -m64 -march=k8 -O -fomit-frame-pointer (4.6.3) |
670284 | 1.00 | kumfp128g | crypto_dh/kumfp128g/v02/var | gcc -march=k8 -O2 -fomit-frame-pointer (4.6.3) |
| | kumfp61e2g | crypto_dh/kumfp61e2g/v01/var | gcc -m64 -O3 -fomit-frame-pointer |
| | kumfp64e2g | crypto_dh/kumfp64e2g/v01/var | gcc -m64 -O3 -fomit-frame-pointer |
355060 | 1.00 | kummer | crypto_dh/kummer/ref | gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer (4.6.3) |
2820624 | 1.00 | nistp256 | crypto_dh/nistp256/ref | gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.6.3) |
3900296 | 1.38 | nistp256 | crypto_dh/nistp256/wbl | gcc -funroll-loops -m64 -O2 -fomit-frame-pointer |
1083372 | 1.00 | sclaus1024 | crypto_dh/sclaus1024/gmp | g++ -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3) |
1454044 | 1.34 | sclaus1024 | crypto_dh/sclaus1024/cryptopp | g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer |
5388472 | 1.00 | sclaus2048 | crypto_dh/sclaus2048/gmp | g++ -m64 -O3 -fomit-frame-pointer (4.6.3) |
7174044 | 1.33 | sclaus2048 | crypto_dh/sclaus2048/cryptopp | g++ -O3 -fomit-frame-pointer |
965660 | 1.00 | surf127eps | crypto_dh/surf127eps/mpfq | gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.3) |
2139472 | 1.00 | surf2113 | crypto_dh/surf2113/mpfq | gcc -m64 -march=core-avx-i -O2 -fomit-frame-pointer (4.6.3) |