Time | Relative time | Primitive | Implementation | Compiler |
8026593 | 1.00 | claus | crypto_dh/claus/gmp | g++ -march=barcelona -O3 -fomit-frame-pointer (4.4.3) |
8892995 | 1.11 | claus | crypto_dh/claus/cryptopp | g++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer |
15060815 | 1.88 | claus | crypto_dh/claus/openssl | gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer |
| | claus | crypto_dh/claus/ntl | g++ -m64 -O3 -fomit-frame-pointer |
1064744 | 1.00 | curve2251 | crypto_dh/curve2251/relic/amd64-ssse3 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.3) |
2890181 | 2.71 | curve2251 | crypto_dh/curve2251/mpfq | gcc -funroll-loops -O2 -fomit-frame-pointer |
| | curve2251 | crypto_dh/curve2251/relic/amd64-avx | gcc -m64 -O3 -fomit-frame-pointer |
| | curve2251 | crypto_dh/curve2251/relic/amd64-clmul | gcc -m64 -O3 -fomit-frame-pointer |
777147 | 1.00 | curve25519 | crypto_dh/curve25519/ref | gcc -O3 -fomit-frame-pointer (4.4.3) |
1219742 | 1.57 | curve25519 | crypto_dh/curve25519/mpfq | gcc -m64 -march=core2 -O3 -fomit-frame-pointer |
629337 | 1.00 | ecfp256e | crypto_dh/ecfp256e/v01/w8s8 | gcc -march=k8 -O2 -fomit-frame-pointer (4.4.3) |
635761 | 1.01 | ecfp256e | crypto_dh/ecfp256e/v01/w8s4 | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer |
647167 | 1.03 | ecfp256e | crypto_dh/ecfp256e/v01/w8s2 | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
673886 | 1.07 | ecfp256e | crypto_dh/ecfp256e/v01/w8s1 | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
1043001 | 1.66 | ecfp256e | crypto_dh/ecfp256e/v01/var | gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer |
757940 | 1.00 | ecfp256h | crypto_dh/ecfp256h/v01/w8s8 | gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3) |
764312 | 1.01 | ecfp256h | crypto_dh/ecfp256h/v01/w8s4 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer |
778473 | 1.03 | ecfp256h | crypto_dh/ecfp256h/v01/w8s2 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer |
808591 | 1.07 | ecfp256h | crypto_dh/ecfp256h/v01/w8s1 | gcc -march=k8 -O3 -fomit-frame-pointer |
1286067 | 1.70 | ecfp256h | crypto_dh/ecfp256h/v01/var | gcc -m64 -march=core2 -O2 -fomit-frame-pointer |
1097052 | 1.00 | ecfp256i | crypto_dh/ecfp256i/v01/var | gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.4.3) |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s1 | gcc -m64 -O3 -fomit-frame-pointer |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s2 | gcc -m64 -O3 -fomit-frame-pointer |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s4 | gcc -m64 -O3 -fomit-frame-pointer |
| | ecfp256i | crypto_dh/ecfp256i/v01/w8s8 | gcc -m64 -O3 -fomit-frame-pointer |
667754 | 1.00 | ecfp256q | crypto_dh/ecfp256q/v01/w8s8 | gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3) |
672591 | 1.01 | ecfp256q | crypto_dh/ecfp256q/v01/w8s4 | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer |
683601 | 1.02 | ecfp256q | crypto_dh/ecfp256q/v01/w8s2 | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
708687 | 1.06 | ecfp256q | crypto_dh/ecfp256q/v01/w8s1 | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
1080188 | 1.62 | ecfp256q | crypto_dh/ecfp256q/v01/var | gcc -m64 -march=core2 -O3 -fomit-frame-pointer |
803341 | 1.00 | ecfp256s | crypto_dh/ecfp256s/v01/w8s8 | gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3) |
811101 | 1.01 | ecfp256s | crypto_dh/ecfp256s/v01/w8s4 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer |
825668 | 1.03 | ecfp256s | crypto_dh/ecfp256s/v01/w8s2 | gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3) |
858319 | 1.07 | ecfp256s | crypto_dh/ecfp256s/v01/w8s1 | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer |
1374237 | 1.71 | ecfp256s | crypto_dh/ecfp256s/v01/var | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
2086878 | 1.00 | ed448goldilocks | crypto_dh/ed448goldilocks/amd64 (2014-10-12) | gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.4.3) |
2487740 | 1.19 | ed448goldilocks | crypto_dh/ed448goldilocks/64 | gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer |
5665284 | 2.71 | ed448goldilocks | crypto_dh/ed448goldilocks/32 | gcc -funroll-loops -march=k8 -O3 -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 |
672894 | 1.00 | gls1271 | crypto_dh/gls1271/ref4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.3) |
| | gls254 | crypto_dh/gls254/prot | gcc -m64 -O3 -fomit-frame-pointer |
| | gls254 | crypto_dh/gls254/ref | gcc -m64 -O3 -fomit-frame-pointer |
| | gls254prot | crypto_dh/gls254prot/prot | gcc -m64 -O3 -fomit-frame-pointer |
649941 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s32 | gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.3) |
650760 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s16 | gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer |
652922 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s08 | gcc -m64 -march=k8 -O3 -fomit-frame-pointer |
659761 | 1.02 | hecfp127i | crypto_dh/hecfp127i/v02/w8s04 | gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer |
674690 | 1.04 | hecfp127i | crypto_dh/hecfp127i/v02/w8s02 | gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer |
704466 | 1.08 | hecfp127i | crypto_dh/hecfp127i/v02/w8s01 | gcc -march=k8 -O3 -fomit-frame-pointer |
1155881 | 1.78 | hecfp127i | crypto_dh/hecfp127i/v02/var | gcc -march=k8 -O3 -fomit-frame-pointer |
582207 | 1.00 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s32glv4 | gcc -march=barcelona -O3 -fomit-frame-pointer (4.4.3) |
584491 | 1.00 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s16glv4 | gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer |
589716 | 1.01 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s08glv4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
600921 | 1.03 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s04glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
624677 | 1.07 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s02glv4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
672934 | 1.16 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s01glv4 | gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer |
914719 | 1.57 | hecfp128bk | crypto_dh/hecfp128bk/v02/varglv4 | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer |
581995 | 1.00 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s32glv4 | gcc -funroll-loops -O2 -fomit-frame-pointer (4.4.3) |
583007 | 1.00 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s16glv4 | gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer |
588840 | 1.01 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s08glv4 | gcc -march=k8 -O2 -fomit-frame-pointer |
600231 | 1.03 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s04glv4 | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer |
623243 | 1.07 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s02glv4 | gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer |
671596 | 1.15 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s01glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer |
911446 | 1.57 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/varglv4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
1133869 | 1.00 | hecfp128i | crypto_dh/hecfp128i/v02/w8s32 | gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.4.3) |
1135824 | 1.00 | hecfp128i | crypto_dh/hecfp128i/v02/w8s16 | gcc -m64 -march=k8 -O2 -fomit-frame-pointer |
1141258 | 1.01 | hecfp128i | crypto_dh/hecfp128i/v02/w8s08 | gcc -march=nocona -O2 -fomit-frame-pointer |
1153912 | 1.02 | hecfp128i | crypto_dh/hecfp128i/v02/w8s04 | gcc -m64 -march=k8 -O2 -fomit-frame-pointer |
1178930 | 1.04 | hecfp128i | crypto_dh/hecfp128i/v02/w8s02 | gcc -march=nocona -O2 -fomit-frame-pointer |
1229556 | 1.08 | hecfp128i | crypto_dh/hecfp128i/v02/w8s01 | gcc -march=k8 -O2 -fomit-frame-pointer |
2015962 | 1.78 | hecfp128i | crypto_dh/hecfp128i/v02/var | gcc -m64 -march=native -mtune=native -O -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 |
2328383 | 1.00 | hector | crypto_dh/hector/ref | gcc -funroll-loops -O2 -fomit-frame-pointer (4.4.3) |
566882 | 1.00 | kumfp127g | crypto_dh/kumfp127g/v02/var | gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer (4.4.3) |
943543 | 1.00 | kumfp128g | crypto_dh/kumfp128g/v02/var | gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer (4.4.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 |
1188878 | 1.00 | kummer | crypto_dh/kummer/ref | gcc -funroll-loops -m64 -O3 -fomit-frame-pointer |
5328180 | 1.00 | nistp256 | crypto_dh/nistp256/ref | gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3) |
| | nistp256 | crypto_dh/nistp256/wbl | gcc -m64 -O3 -fomit-frame-pointer |
1356013 | 1.00 | sclaus1024 | crypto_dh/sclaus1024/gmp | g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.3) |
1577824 | 1.16 | sclaus1024 | crypto_dh/sclaus1024/cryptopp | g++ -fno-schedule-insns -O3 -fomit-frame-pointer |
6842333 | 1.00 | sclaus2048 | crypto_dh/sclaus2048/gmp | g++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.3) |
7844318 | 1.15 | sclaus2048 | crypto_dh/sclaus2048/cryptopp | g++ -march=k8 -O3 -fomit-frame-pointer |
1290566 | 1.00 | surf127eps | crypto_dh/surf127eps/mpfq | gcc -march=k8 -O3 -fomit-frame-pointer (4.4.3) |
2220339 | 1.00 | surf2113 | crypto_dh/surf2113/mpfq | gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.3) |