Time | Relative time | Primitive | Implementation | Compiler |
13629000 | 1.00 | claus | crypto_dh/claus/openssl | gcc -fno-schedule-insns -Os -fomit-frame-pointer (4.6.3) |
15821703 | 1.16 | claus | crypto_dh/claus/cryptopp | clang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer |
| | claus | crypto_dh/claus/gmp | g++ -m64 -O3 -fomit-frame-pointer |
| | claus | crypto_dh/claus/ntl | g++ -m64 -O3 -fomit-frame-pointer |
5130582 | 1.00 | curve2251 | crypto_dh/curve2251/relic/amd64-ssse3 | gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3) |
| | curve2251 | crypto_dh/curve2251/mpfq | gcc -m64 -O3 -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 |
1461315 | 1.00 | curve25519 | crypto_dh/curve25519/ref | gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3) |
| | curve25519 | crypto_dh/curve25519/mpfq | gcc -m64 -O3 -fomit-frame-pointer |
1003629 | 1.00 | ecfp256e | crypto_dh/ecfp256e/v01/w8s8 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1015062 | 1.01 | ecfp256e | crypto_dh/ecfp256e/v01/w8s4 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1032024 | 1.03 | ecfp256e | crypto_dh/ecfp256e/v01/w8s2 | gcc -m64 -O3 -fomit-frame-pointer |
1077069 | 1.07 | ecfp256e | crypto_dh/ecfp256e/v01/w8s1 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
1626849 | 1.62 | ecfp256e | crypto_dh/ecfp256e/v01/var | gcc -m64 -O3 -fomit-frame-pointer |
1237431 | 1.00 | ecfp256h | crypto_dh/ecfp256h/v01/w8s8 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1249125 | 1.01 | ecfp256h | crypto_dh/ecfp256h/v01/w8s4 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1269198 | 1.03 | ecfp256h | crypto_dh/ecfp256h/v01/w8s2 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1317417 | 1.06 | ecfp256h | crypto_dh/ecfp256h/v01/w8s1 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
2056491 | 1.66 | ecfp256h | crypto_dh/ecfp256h/v01/var | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1710513 | 1.00 | ecfp256i | crypto_dh/ecfp256i/v01/var | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.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 |
1053561 | 1.00 | ecfp256q | crypto_dh/ecfp256q/v01/w8s8 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3) |
1064373 | 1.01 | ecfp256q | crypto_dh/ecfp256q/v01/w8s4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3) |
1080858 | 1.03 | ecfp256q | crypto_dh/ecfp256q/v01/w8s2 | gcc -O3 -fomit-frame-pointer |
1123125 | 1.07 | ecfp256q | crypto_dh/ecfp256q/v01/w8s1 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3) |
1667727 | 1.58 | ecfp256q | crypto_dh/ecfp256q/v01/var | gcc -m64 -march=core2 -O3 -fomit-frame-pointer |
1231713 | 1.00 | ecfp256s | crypto_dh/ecfp256s/v01/w8s8 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1243467 | 1.01 | ecfp256s | crypto_dh/ecfp256s/v01/w8s4 | gcc -m64 -O3 -fomit-frame-pointer |
1262157 | 1.02 | ecfp256s | crypto_dh/ecfp256s/v01/w8s2 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1304613 | 1.06 | ecfp256s | crypto_dh/ecfp256s/v01/w8s1 | gcc -m64 -O3 -fomit-frame-pointer |
2042097 | 1.66 | ecfp256s | crypto_dh/ecfp256s/v01/var | gcc -march=k8 -O3 -fomit-frame-pointer |
4276317 | 1.00 | ed448goldilocks | crypto_dh/ed448goldilocks/amd64 (2014-10-12) | clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final)) |
4794105 | 1.12 | ed448goldilocks | crypto_dh/ed448goldilocks/64 | gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer |
11262237 | 2.63 | ed448goldilocks | crypto_dh/ed448goldilocks/arm32 | clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final)) |
13079121 | 3.06 | ed448goldilocks | crypto_dh/ed448goldilocks/32 | clang -O3 -fomit-frame-pointer |
| | ed448goldilocks | crypto_dh/ed448goldilocks/neon | gcc -m64 -O3 -fomit-frame-pointer |
1052394 | 1.00 | gls1271 | crypto_dh/gls1271/ref4 | gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.6.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 |
991773 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s16 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
992739 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s32 | gcc -m64 -march=k8 -O3 -fomit-frame-pointer |
996459 | 1.00 | hecfp127i | crypto_dh/hecfp127i/v02/w8s08 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
1007307 | 1.02 | hecfp127i | crypto_dh/hecfp127i/v02/w8s04 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
1028820 | 1.04 | hecfp127i | crypto_dh/hecfp127i/v02/w8s02 | gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer |
1072971 | 1.08 | hecfp127i | crypto_dh/hecfp127i/v02/w8s01 | gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer |
1748907 | 1.76 | hecfp127i | crypto_dh/hecfp127i/v02/var | gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer |
787452 | 1.00 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s32glv4 | gcc -m64 -march=core2 -O2 -fomit-frame-pointer (4.6.3) |
788871 | 1.00 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s16glv4 | gcc -O3 -fomit-frame-pointer |
793929 | 1.01 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s08glv4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
809631 | 1.03 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s04glv4 | gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer |
840528 | 1.07 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s02glv4 | gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer |
903018 | 1.15 | hecfp128bk | crypto_dh/hecfp128bk/v02/w8s01glv4 | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
1225509 | 1.56 | hecfp128bk | crypto_dh/hecfp128bk/v02/varglv4 | gcc -march=k8 -O2 -fomit-frame-pointer |
783600 | 1.00 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s16glv4 | gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
786684 | 1.00 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s32glv4 | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer |
793068 | 1.01 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s08glv4 | gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer |
807402 | 1.03 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s04glv4 | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer |
837162 | 1.07 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s02glv4 | gcc -m64 -march=k8 -O3 -fomit-frame-pointer |
900246 | 1.15 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/w8s01glv4 | gcc -m64 -march=barcelona -O3 -fomit-frame-pointer |
1220661 | 1.56 | hecfp128fkt | crypto_dh/hecfp128fkt/v02/varglv4 | gcc -march=barcelona -O2 -fomit-frame-pointer (4.6.3) |
1488690 | 1.00 | hecfp128i | crypto_dh/hecfp128i/v02/w8s16 | gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.6.3) |
1491480 | 1.00 | hecfp128i | crypto_dh/hecfp128i/v02/w8s32 | gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer |
1497789 | 1.01 | hecfp128i | crypto_dh/hecfp128i/v02/w8s08 | gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer |
1513239 | 1.02 | hecfp128i | crypto_dh/hecfp128i/v02/w8s04 | gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer |
1545573 | 1.04 | hecfp128i | crypto_dh/hecfp128i/v02/w8s02 | gcc -funroll-loops -O2 -fomit-frame-pointer |
1609521 | 1.08 | hecfp128i | crypto_dh/hecfp128i/v02/w8s01 | gcc -funroll-loops -m64 -O2 -fomit-frame-pointer |
2634969 | 1.77 | hecfp128i | crypto_dh/hecfp128i/v02/var | gcc -funroll-loops -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 |
| | hector | crypto_dh/hector/ref | gcc -m64 -O3 -fomit-frame-pointer |
798186 | 1.00 | kumfp127g | crypto_dh/kumfp127g/v02/var | gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3) |
1280280 | 1.00 | kumfp128g | crypto_dh/kumfp128g/v02/var | gcc -funroll-loops -march=barcelona -O -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 |
2954472 | 1.00 | kummer | crypto_dh/kummer/ref | gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3) |
5295681 | 1.00 | nistp256 | crypto_dh/nistp256/ref | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.3) |
6259794 | 1.18 | nistp256 | crypto_dh/nistp256/wbl | clang -O3 -fomit-frame-pointer |
2818389 | 1.00 | sclaus1024 | crypto_dh/sclaus1024/cryptopp | clang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final)) |
| | sclaus1024 | crypto_dh/sclaus1024/gmp | g++ -m64 -O3 -fomit-frame-pointer |
13443036 | 1.00 | sclaus2048 | crypto_dh/sclaus2048/cryptopp | g++ (4.6.3) |
| | sclaus2048 | crypto_dh/sclaus2048/gmp | g++ -m64 -O3 -fomit-frame-pointer |
| | surf127eps | crypto_dh/surf127eps/mpfq | gcc -m64 -O3 -fomit-frame-pointer |
| | surf2113 | crypto_dh/surf2113/mpfq | gcc -m64 -O3 -fomit-frame-pointer |