Implementation notes: amd64, margaux, crypto_dh

Computer: margaux
Architecture: amd64
CPU ID: GenuineIntel-000006fb-bfebfbff
CPU cycles/second: 2394000000...2394000000 (amd64cpuinfo)
SUPERCOP version: 20170105
Benchmark dates: 20161010...20170107

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
101621521.00clauscrypto_dh/claus/gmpg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.4)
111592711.10clauscrypto_dh/claus/cryptoppg++ -m64 -march=nocona -Os -fomit-frame-pointer
128352061.26clauscrypto_dh/claus/opensslgcc -m64 -march=corei7 -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
13546171.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -O3 -fomit-frame-pointer (4.8.4)
34809482.57curve2251crypto_dh/curve2251/mpfqclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
12511351.00curve25519crypto_dh/curve25519/refgcc -march=nocona -O3 -fomit-frame-pointer (4.8.4)
15626431.25curve25519crypto_dh/curve25519/mpfqgcc -march=nocona -O3 -fomit-frame-pointer (4.8.4)
8781661.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
8881201.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9070561.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9446761.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
14526631.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer
10694161.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
10801171.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
11000161.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -march=k8 -O3 -fomit-frame-pointer
11431081.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
18147781.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
15288391.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
9312931.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9423271.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer
9578881.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -march=k8 -O3 -fomit-frame-pointer
9955711.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
15049891.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
10979281.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
11105191.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
11317411.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer
11728801.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer
18676441.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
27167941.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
32791051.21ed448goldilockscrypto_dh/ed448goldilocks/64clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
48793051.80ed448goldilockscrypto_dh/ed448goldilocks/arm32clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
68110382.51ed448goldilockscrypto_dh/ed448goldilocks/32gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
65909701.00ed521gscrypto_dh/ed521gs/ref (1.0)gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
8956171.00gls1271crypto_dh/gls1271/ref4gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
gls254crypto_dh/gls254/optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254crypto_dh/gls254/protgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254crypto_dh/gls254/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254protcrypto_dh/gls254prot/optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254protcrypto_dh/gls254prot/protgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
8726221.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
8754571.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
8802361.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
8896681.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9105571.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -march=k8 -O3 -fomit-frame-pointer
9494011.09hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -march=k8 -O3 -fomit-frame-pointer
15563701.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
8022151.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -funroll-loops -O2 -fomit-frame-pointer (4.8.4)
8051761.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
8139151.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
8312761.04hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -march=nocona -O3 -fomit-frame-pointer
8633431.08hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -O3 -fomit-frame-pointer
9293401.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
12628441.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -march=barcelona -O2 -fomit-frame-pointer
8013061.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
8056261.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
8129251.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
8272351.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
8588161.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
9269911.16hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -m64 -O3 -fomit-frame-pointer
12584071.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -O -fomit-frame-pointer
15570991.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
15598891.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer
15698971.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -fno-schedule-insns -O -fomit-frame-pointer
15859801.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
16207921.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
16899031.09hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
27722701.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/varglv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s01glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s02glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s04glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s08glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s16glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s32glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s01gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s02gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s04gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s08gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s16gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s32gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/varglv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s01glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s02glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s04glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s08glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s16glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s32glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s01gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s02gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s04gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s08gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s16gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s32gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
28600651.00hectorcrypto_dh/hector/refclang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
6633271.00jacfp127icrypto_dh/jacfp127i/v01/w8s32gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
6648301.00jacfp127icrypto_dh/jacfp127i/v01/w8s16gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
6689251.01jacfp127icrypto_dh/jacfp127i/v01/w8s08gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
6763771.02jacfp127icrypto_dh/jacfp127i/v01/w8s04gcc -march=k8 -O2 -fomit-frame-pointer
6910831.04jacfp127icrypto_dh/jacfp127i/v01/w8s02gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
7191721.08jacfp127icrypto_dh/jacfp127i/v01/w4s32gcc -march=k8 -O2 -fomit-frame-pointer
7198651.09jacfp127icrypto_dh/jacfp127i/v01/w8s01gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
7230691.09jacfp127icrypto_dh/jacfp127i/v01/w4s16gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
7306201.10jacfp127icrypto_dh/jacfp127i/v01/w4s08gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
7449301.12jacfp127icrypto_dh/jacfp127i/v01/w4s04gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
7749451.17jacfp127icrypto_dh/jacfp127i/v01/w4s02gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
8344531.26jacfp127icrypto_dh/jacfp127i/v01/w4s01gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
11672911.76jacfp127icrypto_dh/jacfp127i/v01/vargcc -m64 -march=barcelona -O2 -fomit-frame-pointer
6350041.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s32glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
6378751.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s16glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
6452101.02jacfp128bkcrypto_dh/jacfp128bk/v01/w8s08glv4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
6573781.04jacfp128bkcrypto_dh/jacfp128bk/v01/w8s04glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
6822181.07jacfp128bkcrypto_dh/jacfp128bk/v01/w8s02glv4gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
7314661.15jacfp128bkcrypto_dh/jacfp128bk/v01/w8s01glv4gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
7367851.16jacfp128bkcrypto_dh/jacfp128bk/v01/w4s32glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
7432381.17jacfp128bkcrypto_dh/jacfp128bk/v01/w4s16glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
7541461.19jacfp128bkcrypto_dh/jacfp128bk/v01/w4s08glv4gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
7797241.23jacfp128bkcrypto_dh/jacfp128bk/v01/w4s04glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
8277661.30jacfp128bkcrypto_dh/jacfp128bk/v01/w4s02glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
9297541.46jacfp128bkcrypto_dh/jacfp128bk/v01/w4s01glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
9850141.55jacfp128bkcrypto_dh/jacfp128bk/v01/varglv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
k277moncrypto_dh/k277mon/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
k277taacrypto_dh/k277taa/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
k298crypto_dh/k298/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
7205491.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -O -fomit-frame-pointer (4.8.4)
12806191.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -m64 -march=k8 -O -fomit-frame-pointer (4.8.4)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
4568311.00kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s32gcc -m64 -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
4591801.01kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s16gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
4626001.01kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s08gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
4700161.03kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s04gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
4847491.06kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s02gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
5126311.12kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s32gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
5148901.13kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s01gcc -funroll-loops -O2 -fomit-frame-pointer
5163931.13kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s16gcc -march=barcelona -O3 -fomit-frame-pointer
5240611.15kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s08gcc -fno-schedule-insns -O3 -fomit-frame-pointer
5390281.18kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s04gcc -march=barcelona -O2 -fomit-frame-pointer
5684221.24kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s02gcc -march=barcelona -O3 -fomit-frame-pointer
6284431.38kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s01gcc -m64 -march=nocona -O3 -fomit-frame-pointer
9657002.11kumjacfp127gcrypto_dh/kumjacfp127g/v01/vargcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
16218361.00kummercrypto_dh/kummer/refgcc -march=nocona -O3 -fomit-frame-pointer (4.8.4)
77545261.00nist521gscrypto_dh/nist521gs/ref (1.0)gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
33755221.00nistp256crypto_dh/nistp256/wbl (0.0.1)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
41208391.22nistp256crypto_dh/nistp256/refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
8511301.00prjfp127icrypto_dh/prjfp127i/v01/w8s32gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.8.4)
8534881.00prjfp127icrypto_dh/prjfp127i/v01/w8s16gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.8.4)
8580061.01prjfp127icrypto_dh/prjfp127i/v01/w8s08gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
8676181.02prjfp127icrypto_dh/prjfp127i/v01/w8s04gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.8.4)
8870131.04prjfp127icrypto_dh/prjfp127i/v01/w8s02gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
9210691.08prjfp127icrypto_dh/prjfp127i/v01/w4s32gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
9252901.09prjfp127icrypto_dh/prjfp127i/v01/w8s01gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
9269371.09prjfp127icrypto_dh/prjfp127i/v01/w4s16gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.8.4)
9355141.10prjfp127icrypto_dh/prjfp127i/v01/w4s08gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
9549271.12prjfp127icrypto_dh/prjfp127i/v01/w4s04gcc -march=nocona -O2 -fomit-frame-pointer
9943201.17prjfp127icrypto_dh/prjfp127i/v01/w4s02gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
10696411.26prjfp127icrypto_dh/prjfp127i/v01/w4s01gcc -m64 -march=nocona -O2 -fomit-frame-pointer (4.8.4)
15202891.79prjfp127icrypto_dh/prjfp127i/v01/vargcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
7802371.00prjfp128bkcrypto_dh/prjfp128bk/v01/w8s32glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.8.4)
7826491.00prjfp128bkcrypto_dh/prjfp128bk/v01/w8s16glv4gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
7932961.02prjfp128bkcrypto_dh/prjfp128bk/v01/w8s08glv4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
8101621.04prjfp128bkcrypto_dh/prjfp128bk/v01/w8s04glv4gcc -march=barcelona -O3 -fomit-frame-pointer
8415091.08prjfp128bkcrypto_dh/prjfp128bk/v01/w8s02glv4gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
9044641.16prjfp128bkcrypto_dh/prjfp128bk/v01/w4s32glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
9066331.16prjfp128bkcrypto_dh/prjfp128bk/v01/w8s01glv4gcc -march=barcelona -O2 -fomit-frame-pointer
9130141.17prjfp128bkcrypto_dh/prjfp128bk/v01/w4s16glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
9305101.19prjfp128bkcrypto_dh/prjfp128bk/v01/w4s08glv4gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer
9626041.23prjfp128bkcrypto_dh/prjfp128bk/v01/w4s04glv4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
10259101.31prjfp128bkcrypto_dh/prjfp128bk/v01/w4s02glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
11573281.48prjfp128bkcrypto_dh/prjfp128bk/v01/w4s01glv4gcc -march=barcelona -O2 -fomit-frame-pointer
12216691.57prjfp128bkcrypto_dh/prjfp128bk/v01/varglv4gcc -march=barcelona -O2 -fomit-frame-pointer
17154091.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -O3 -fomit-frame-pointer (4.8.4)
19888831.16sclaus1024crypto_dh/sclaus1024/cryptoppg++ -march=barcelona -Os -fomit-frame-pointer
84899881.00sclaus2048crypto_dh/sclaus2048/gmpg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.8.4)
97680151.15sclaus2048crypto_dh/sclaus2048/cryptoppg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
16437241.00surf127epscrypto_dh/surf127eps/mpfqclang -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
26883271.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.8.4)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
12490921.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -march=nocona -O -fomit-frame-pointer (4.8.4)
13094641.05curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
13177711.05curve25519crypto_scalarmult/curve25519/amd64-51gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv
19709821.58curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
25646762.05curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -O -fomit-frame-pointer
3771500430.19curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/sandy2xgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
16200091.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.8.4)
17347501.07kummercrypto_scalarmult/kummer/ref5ugcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avxgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
kummercrypto_scalarmult/kummer/avx2gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
kummercrypto_scalarmult/kummer/avx2intgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
41171671.00nistp256crypto_scalarmult/nistp256/mj32gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.8.4)