| Time | Relative time | Primitive | Implementation | Compiler |
| 49104160 | 1.00 | claus | crypto_dh/claus/cryptopp | g++ -m64 -march=nocona -O -fomit-frame-pointer (4.4.5) |
| 49919210 | 1.02 | claus | crypto_dh/claus/gmp | g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer |
| 64605380 | 1.32 | claus | crypto_dh/claus/openssl | gcc -m64 -march=barcelona -O2 -fomit-frame-pointer |
| | claus | crypto_dh/claus/ntl | g++ -m64 -O3 -fomit-frame-pointer |
| 2600030 | 1.00 | curve2251 | crypto_dh/curve2251/relic/amd64-ssse3 | gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.4.5) |
| 10377330 | 3.99 | curve2251 | crypto_dh/curve2251/mpfq | gcc -m64 -march=nocona -O -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 |
| 4377570 | 1.00 | curve25519 | crypto_dh/curve25519/ref | gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.5) |
| 4536450 | 1.04 | curve25519 | crypto_dh/curve25519/mpfq | gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer |
| 2665600 | 1.00 | ecfp256e | crypto_dh/ecfp256e/v01/w8s8 | gcc -march=nocona -O2 -fomit-frame-pointer (4.4.5) |
| 2685640 | 1.01 | ecfp256e | crypto_dh/ecfp256e/v01/w8s4 | gcc -m64 -march=core2 -O2 -fomit-frame-pointer |
| 2748260 | 1.03 | ecfp256e | crypto_dh/ecfp256e/v01/w8s2 | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer |
| 2861290 | 1.07 | ecfp256e | crypto_dh/ecfp256e/v01/w8s1 | gcc -m64 -march=core2 -O2 -fomit-frame-pointer |
| 4393530 | 1.65 | ecfp256e | crypto_dh/ecfp256e/v01/var | gcc -march=k8 -O2 -fomit-frame-pointer |
| 3386160 | 1.00 | ecfp256h | crypto_dh/ecfp256h/v01/w8s8 | gcc -O2 -fomit-frame-pointer (4.4.5) |
| 3430220 | 1.01 | ecfp256h | crypto_dh/ecfp256h/v01/w8s4 | gcc -march=k8 -O2 -fomit-frame-pointer |
| 3492700 | 1.03 | ecfp256h | crypto_dh/ecfp256h/v01/w8s2 | gcc -fno-schedule-insns -O2 -fomit-frame-pointer |
| 3623620 | 1.07 | ecfp256h | crypto_dh/ecfp256h/v01/w8s1 | gcc -m64 -O2 -fomit-frame-pointer |
| 5742750 | 1.70 | ecfp256h | crypto_dh/ecfp256h/v01/var | gcc -fno-schedule-insns -O2 -fomit-frame-pointer |
| 2890290 | 1.00 | ecfp256i | crypto_dh/ecfp256i/v01/w8s8 | gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer (4.4.5) |
| 2914370 | 1.01 | ecfp256i | crypto_dh/ecfp256i/v01/w8s4 | gcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer |
| 2961780 | 1.02 | ecfp256i | crypto_dh/ecfp256i/v01/w8s2 | gcc -m64 -march=barcelona -Os -fomit-frame-pointer |
| 3059290 | 1.06 | ecfp256i | crypto_dh/ecfp256i/v01/w8s1 | gcc -m64 -march=core2 -Os -fomit-frame-pointer |
| 4638790 | 1.60 | ecfp256i | crypto_dh/ecfp256i/v01/var | gcc -m64 -march=nocona -Os -fomit-frame-pointer |
| 2795760 | 1.00 | ecfp256q | crypto_dh/ecfp256q/v01/w8s8 | gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.5) |
| 2820560 | 1.01 | ecfp256q | crypto_dh/ecfp256q/v01/w8s4 | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer |
| 2878540 | 1.03 | ecfp256q | crypto_dh/ecfp256q/v01/w8s2 | gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer |
| 2987720 | 1.07 | ecfp256q | crypto_dh/ecfp256q/v01/w8s1 | gcc -m64 -march=core2 -O2 -fomit-frame-pointer |
| 4519030 | 1.62 | ecfp256q | crypto_dh/ecfp256q/v01/var | gcc -m64 -O2 -fomit-frame-pointer |
| 3223190 | 1.00 | ecfp256s | crypto_dh/ecfp256s/v01/w8s8 | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.5) |
| 3251160 | 1.01 | ecfp256s | crypto_dh/ecfp256s/v01/w8s4 | gcc -march=k8 -O2 -fomit-frame-pointer |
| 3310970 | 1.03 | ecfp256s | crypto_dh/ecfp256s/v01/w8s2 | gcc -march=k8 -O2 -fomit-frame-pointer |
| 3427090 | 1.06 | ecfp256s | crypto_dh/ecfp256s/v01/w8s1 | gcc -m64 -O2 -fomit-frame-pointer |
| 5409500 | 1.68 | ecfp256s | crypto_dh/ecfp256s/v01/var | gcc -march=k8 -O3 -fomit-frame-pointer |
| 2243290 | 1.00 | gls1271 | crypto_dh/gls1271/ref4 | gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (4.4.5) |
| 9157460 | 1.00 | hector | crypto_dh/hector/ref | gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.4.5) |
| | nistp256 | crypto_dh/nistp256/nawaz | gcc -m64 -O3 -fomit-frame-pointer |
| 8306770 | 1.00 | sclaus1024 | crypto_dh/sclaus1024/gmp | g++ -m64 -O3 -fomit-frame-pointer (4.4.5) |
| 8591320 | 1.03 | sclaus1024 | crypto_dh/sclaus1024/cryptopp | g++ -m64 -march=core2 -O -fomit-frame-pointer |
| 40475430 | 1.00 | sclaus2048 | crypto_dh/sclaus2048/gmp | g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer (4.4.5) |
| 43818600 | 1.08 | sclaus2048 | crypto_dh/sclaus2048/cryptopp | g++ -m64 -march=barcelona -Os -fomit-frame-pointer |
| 4626730 | 1.00 | surf127eps | crypto_dh/surf127eps/mpfq | gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.5) |
| 8844010 | 1.00 | surf2113 | crypto_dh/surf2113/mpfq | gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5) |
| Time | Relative time | Primitive | Implementation | Compiler |
| 2173150 | 1.00 | curve25519 | crypto_scalarmult/curve25519/amd64-64 | gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.4.5) |
| 2510400 | 1.16 | curve25519 | crypto_scalarmult/curve25519/donna_c64 | gcc -funroll-loops -O3 -fomit-frame-pointer |
| 2994260 | 1.38 | curve25519 | crypto_scalarmult/curve25519/amd64-51 | gcc -funroll-loops -O -fomit-frame-pointer |
| 3896820 | 1.79 | curve25519 | crypto_scalarmult/curve25519/donna | gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer |
| 6954440 | 3.20 | curve25519 | crypto_scalarmult/curve25519/ref10 | gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer |
| 69137520 | 31.81 | curve25519 | crypto_scalarmult/curve25519/ref | gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer |
| | curve25519 | crypto_scalarmult/curve25519/athlon | gcc -m64 -O3 -fomit-frame-pointer |
| | curve25519 | crypto_scalarmult/curve25519/costigan-schwabe/cbe | gcc -m64 -O3 -fomit-frame-pointer |