| Time | Relative time | Primitive | Implementation | Compiler |
| 10274436 | 1.00 | claus | crypto_dh/claus/gmp | g++ -march=k8 -O2 -fomit-frame-pointer (4.4.5) |
| 10555936 | 1.03 | claus | crypto_dh/claus/cryptopp | g++ -march=k8 -O3 -fomit-frame-pointer |
| 17685528 | 1.72 | claus | crypto_dh/claus/openssl | gcc |
| | claus | crypto_dh/claus/ntl | g++ -m64 -O3 -fomit-frame-pointer |
| 1279152 | 1.00 | curve2251 | crypto_dh/curve2251/relic/amd64-ssse3 | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.4.5) |
| 3459712 | 2.70 | curve2251 | crypto_dh/curve2251/mpfq | gcc -funroll-loops -fno-schedule-insns -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 |
| 1169740 | 1.00 | curve25519 | crypto_dh/curve25519/ref | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.5) |
| 1462600 | 1.25 | curve25519 | crypto_dh/curve25519/mpfq | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
| 742532 | 1.00 | ecfp256e | crypto_dh/ecfp256e/v01/w8s8 | gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.4.5) |
| 748052 | 1.01 | ecfp256e | crypto_dh/ecfp256e/v01/w8s4 | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer |
| 761908 | 1.03 | ecfp256e | crypto_dh/ecfp256e/v01/w8s2 | gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer |
| 794112 | 1.07 | ecfp256e | crypto_dh/ecfp256e/v01/w8s1 | gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.4.5) |
| 1227560 | 1.65 | ecfp256e | crypto_dh/ecfp256e/v01/var | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
| 893100 | 1.00 | ecfp256h | crypto_dh/ecfp256h/v01/w8s8 | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.5) |
| 901372 | 1.01 | ecfp256h | crypto_dh/ecfp256h/v01/w8s4 | gcc -m64 -march=core2 -O2 -fomit-frame-pointer |
| 917448 | 1.03 | ecfp256h | crypto_dh/ecfp256h/v01/w8s2 | gcc -march=k8 -O3 -fomit-frame-pointer |
| 953348 | 1.07 | ecfp256h | crypto_dh/ecfp256h/v01/w8s1 | gcc -m64 -march=k8 -O3 -fomit-frame-pointer |
| 1515740 | 1.70 | ecfp256h | crypto_dh/ecfp256h/v01/var | gcc -fno-schedule-insns -O3 -fomit-frame-pointer |
| 797968 | 1.00 | ecfp256i | crypto_dh/ecfp256i/v01/w8s8 | gcc -march=k8 -O2 -fomit-frame-pointer (4.4.5) |
| 803328 | 1.01 | ecfp256i | crypto_dh/ecfp256i/v01/w8s4 | gcc -fno-schedule-insns -O2 -fomit-frame-pointer |
| 817084 | 1.02 | ecfp256i | crypto_dh/ecfp256i/v01/w8s2 | gcc -m64 -march=core2 -O2 -fomit-frame-pointer |
| 842204 | 1.06 | ecfp256i | crypto_dh/ecfp256i/v01/w8s1 | gcc -fno-schedule-insns -O2 -fomit-frame-pointer |
| 1295388 | 1.62 | ecfp256i | crypto_dh/ecfp256i/v01/var | gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer |
| 787732 | 1.00 | ecfp256q | crypto_dh/ecfp256q/v01/w8s8 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.5) |
| 792368 | 1.01 | ecfp256q | crypto_dh/ecfp256q/v01/w8s4 | gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer |
| 805468 | 1.02 | ecfp256q | crypto_dh/ecfp256q/v01/w8s2 | gcc -O3 -fomit-frame-pointer |
| 834344 | 1.06 | ecfp256q | crypto_dh/ecfp256q/v01/w8s1 | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
| 1270904 | 1.61 | ecfp256q | crypto_dh/ecfp256q/v01/var | gcc -m64 -O3 -fomit-frame-pointer |
| 948772 | 1.00 | ecfp256s | crypto_dh/ecfp256s/v01/w8s8 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.5) |
| 955368 | 1.01 | ecfp256s | crypto_dh/ecfp256s/v01/w8s4 | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
| 972532 | 1.03 | ecfp256s | crypto_dh/ecfp256s/v01/w8s2 | gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer |
| 1009812 | 1.06 | ecfp256s | crypto_dh/ecfp256s/v01/w8s1 | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer |
| 1621564 | 1.71 | ecfp256s | crypto_dh/ecfp256s/v01/var | gcc -m64 -march=k8 -O3 -fomit-frame-pointer |
| 814924 | 1.00 | gls1271 | crypto_dh/gls1271/ref4 | gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.5) |
| 2882452 | 1.00 | hector | crypto_dh/hector/ref | gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5) |
| 1708528 | 1.00 | sclaus1024 | crypto_dh/sclaus1024/gmp | g++ -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.5) |
| 1878756 | 1.10 | sclaus1024 | crypto_dh/sclaus1024/cryptopp | g++ -m64 -march=k8 -O3 -fomit-frame-pointer |
| 8442916 | 1.00 | sclaus2048 | crypto_dh/sclaus2048/gmp | g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5) |
| 9266140 | 1.10 | sclaus2048 | crypto_dh/sclaus2048/cryptopp | g++ -m64 -O3 -fomit-frame-pointer |
| 1552016 | 1.00 | surf127eps | crypto_dh/surf127eps/mpfq | gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.5) |
| 2634392 | 1.00 | surf2113 | crypto_dh/surf2113/mpfq | gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5) |