Implementation notes: amd64, latour, crypto_dh

Computer: latour
Architecture: amd64
CPU ID: GenuineIntel-000006fb-bfebfbff
CPU cycles/second: 2399897000...2399897000 (amd64cpuinfo)
SUPERCOP version: 20170725
Benchmark dates: 20170719...20170727

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
101572741.00clauscrypto_dh/claus/gmpg++ -m64 -march=barcelona -O -fomit-frame-pointer (4.8.4)
112766671.11clauscrypto_dh/claus/cryptoppg++ -m64 -march=k8 -O -fomit-frame-pointer
128840131.27clauscrypto_dh/claus/opensslgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
13514671.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.8.4)
34809212.58curve2251crypto_dh/curve2251/mpfqclang -march=native -O3 -fomit-frame-pointer -fwrapv -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
12497581.00curve25519crypto_dh/curve25519/refgcc -Os -fomit-frame-pointer (4.8.4)
15662431.25curve25519crypto_dh/curve25519/mpfqgcc -march=nocona -O3 -fomit-frame-pointer
8780581.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
8882821.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9063271.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9451171.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer
14520691.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
10715401.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
10803781.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer
11018971.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -march=k8 -O3 -fomit-frame-pointer
11457181.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
18170011.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
15314671.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -funroll-loops -m64 -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
9327421.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9440821.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9577441.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
9944371.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer
15038551.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
11021311.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
11113201.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
11329921.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
11737261.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=k8 -O3 -fomit-frame-pointer
18644941.69ecfp256scrypto_dh/ecfp256s/v01/vargcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
27334171.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
32998861.21ed448goldilockscrypto_dh/ed448goldilocks/64clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
48682801.78ed448goldilockscrypto_dh/ed448goldilocks/arm32clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
68429252.50ed448goldilockscrypto_dh/ed448goldilocks/32gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
65939401.00ed521gscrypto_dh/ed521gs/ref (1.0)gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
8951041.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=core2 -O3 -fomit-frame-pointer (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
8753311.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.4)
8764561.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -m64 -march=core2 -O2 -fomit-frame-pointer
8811541.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -m64 -march=k8 -O3 -fomit-frame-pointer
8916841.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
9106111.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9504271.09hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
15609331.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
8030521.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -O3 -fomit-frame-pointer (4.8.4)
8069131.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=native -mtune=native -O -fomit-frame-pointer
8163631.02hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
8328151.04hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
8632891.08hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
9293581.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
12647611.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -O3 -fomit-frame-pointer
8019451.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -m64 -O3 -fomit-frame-pointer (4.8.4)
8038261.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
8136361.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
8296471.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
8618851.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -funroll-loops -O3 -fomit-frame-pointer
9268381.16hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
12601351.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
15578461.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.8.4)
15619321.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -funroll-loops -march=nocona -O -fomit-frame-pointer
15698971.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -march=k8 -O2 -fomit-frame-pointer
15874201.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
16196131.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer
16901551.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
27738901.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -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
28375651.00hectorcrypto_dh/hector/refclang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
6625981.00jacfp127icrypto_dh/jacfp127i/v01/w8s32gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
6651541.00jacfp127icrypto_dh/jacfp127i/v01/w8s16gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
6679981.01jacfp127icrypto_dh/jacfp127i/v01/w8s08gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
6760441.02jacfp127icrypto_dh/jacfp127i/v01/w8s04gcc -march=k8 -O2 -fomit-frame-pointer
6904441.04jacfp127icrypto_dh/jacfp127i/v01/w8s02gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
7194151.09jacfp127icrypto_dh/jacfp127i/v01/w4s32gcc -march=barcelona -O2 -fomit-frame-pointer
7206571.09jacfp127icrypto_dh/jacfp127i/v01/w8s01gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
7221061.09jacfp127icrypto_dh/jacfp127i/v01/w4s16gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
7296661.10jacfp127icrypto_dh/jacfp127i/v01/w4s08gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
7450381.12jacfp127icrypto_dh/jacfp127i/v01/w4s04gcc -march=barcelona -O2 -fomit-frame-pointer
7751431.17jacfp127icrypto_dh/jacfp127i/v01/w4s02gcc -march=barcelona -O3 -fomit-frame-pointer
8346781.26jacfp127icrypto_dh/jacfp127i/v01/w4s01gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
11667421.76jacfp127icrypto_dh/jacfp127i/v01/vargcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
6368401.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s32glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
6393151.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s16glv4gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
6451651.01jacfp128bkcrypto_dh/jacfp128bk/v01/w8s08glv4gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
6587191.03jacfp128bkcrypto_dh/jacfp128bk/v01/w8s04glv4gcc -funroll-loops -O2 -fomit-frame-pointer
6826411.07jacfp128bkcrypto_dh/jacfp128bk/v01/w8s02glv4gcc -march=nocona -O3 -fomit-frame-pointer
7324291.15jacfp128bkcrypto_dh/jacfp128bk/v01/w8s01glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
7369651.16jacfp128bkcrypto_dh/jacfp128bk/v01/w4s32glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
7426261.17jacfp128bkcrypto_dh/jacfp128bk/v01/w4s16glv4gcc -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
7552171.19jacfp128bkcrypto_dh/jacfp128bk/v01/w4s08glv4gcc -m64 -march=nocona -O3 -fomit-frame-pointer
7805611.23jacfp128bkcrypto_dh/jacfp128bk/v01/w4s04glv4gcc -m64 -march=k8 -O -fomit-frame-pointer
8305291.30jacfp128bkcrypto_dh/jacfp128bk/v01/w4s02glv4gcc -m64 -march=nocona -O2 -fomit-frame-pointer
9299071.46jacfp128bkcrypto_dh/jacfp128bk/v01/w4s01glv4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
9859411.55jacfp128bkcrypto_dh/jacfp128bk/v01/varglv4gcc -m64 -O3 -fomit-frame-pointer
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
7223311.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer
12814111.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -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
4580461.00kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s32gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
4590451.00kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s16gcc -m64 -march=nocona -O2 -fomit-frame-pointer
4624111.01kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s08gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4697641.03kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s04gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
4847131.06kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s02gcc -m64 -march=k8 -O2 -fomit-frame-pointer
5129191.12kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s32gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
5141521.12kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s01gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
5161411.13kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s16gcc -m64 -march=k8 -O -fomit-frame-pointer
5234761.14kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s08gcc -march=barcelona -O2 -fomit-frame-pointer
5383531.18kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s04gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
5675311.24kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s02gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
6283981.37kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s01gcc -m64 -march=nocona -O2 -fomit-frame-pointer
9641792.10kumjacfp127gcrypto_dh/kumjacfp127g/v01/vargcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
16331851.00kummercrypto_dh/kummer/refgcc -m64 -O3 -fomit-frame-pointer (4.8.4)
77537251.00nist521gscrypto_dh/nist521gs/ref (1.0)gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
33612301.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))
41257351.23nistp256crypto_dh/nistp256/refgcc -march=k8 -O -fomit-frame-pointer
8518591.00prjfp127icrypto_dh/prjfp127i/v01/w8s32gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.8.4)
8554141.00prjfp127icrypto_dh/prjfp127i/v01/w8s16gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
8596891.01prjfp127icrypto_dh/prjfp127i/v01/w8s08gcc -m64 -march=nocona -O3 -fomit-frame-pointer
8699131.02prjfp127icrypto_dh/prjfp127i/v01/w8s04gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
8879671.04prjfp127icrypto_dh/prjfp127i/v01/w8s02gcc -march=nocona -O2 -fomit-frame-pointer
9228961.08prjfp127icrypto_dh/prjfp127i/v01/w4s32gcc -m64 -march=nocona -O3 -fomit-frame-pointer
9264421.09prjfp127icrypto_dh/prjfp127i/v01/w4s16gcc -march=nocona -O3 -fomit-frame-pointer
9270271.09prjfp127icrypto_dh/prjfp127i/v01/w8s01gcc -m64 -march=nocona -O3 -fomit-frame-pointer
9362881.10prjfp127icrypto_dh/prjfp127i/v01/w4s08gcc -m64 -march=nocona -O3 -fomit-frame-pointer
9563581.12prjfp127icrypto_dh/prjfp127i/v01/w4s04gcc -march=nocona -O3 -fomit-frame-pointer
9929701.17prjfp127icrypto_dh/prjfp127i/v01/w4s02gcc -m64 -march=nocona -O3 -fomit-frame-pointer
10726111.26prjfp127icrypto_dh/prjfp127i/v01/w4s01gcc -m64 -march=nocona -O2 -fomit-frame-pointer
15213151.79prjfp127icrypto_dh/prjfp127i/v01/vargcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
7822891.00prjfp128bkcrypto_dh/prjfp128bk/v01/w8s32glv4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.8.4)
7865281.01prjfp128bkcrypto_dh/prjfp128bk/v01/w8s16glv4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.8.4)
7936921.01prjfp128bkcrypto_dh/prjfp128bk/v01/w8s08glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
8102701.04prjfp128bkcrypto_dh/prjfp128bk/v01/w8s04glv4gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
8434441.08prjfp128bkcrypto_dh/prjfp128bk/v01/w8s02glv4gcc -m64 -march=k8 -O3 -fomit-frame-pointer
9057061.16prjfp128bkcrypto_dh/prjfp128bk/v01/w4s32glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
9076681.16prjfp128bkcrypto_dh/prjfp128bk/v01/w8s01glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
9134461.17prjfp128bkcrypto_dh/prjfp128bk/v01/w4s16glv4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
9313201.19prjfp128bkcrypto_dh/prjfp128bk/v01/w4s08glv4gcc -march=barcelona -O2 -fomit-frame-pointer
9623791.23prjfp128bkcrypto_dh/prjfp128bk/v01/w4s04glv4gcc -march=barcelona -O2 -fomit-frame-pointer
10268911.31prjfp128bkcrypto_dh/prjfp128bk/v01/w4s02glv4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
11598931.48prjfp128bkcrypto_dh/prjfp128bk/v01/w4s01glv4gcc -march=k8 -O3 -fomit-frame-pointer
12208591.56prjfp128bkcrypto_dh/prjfp128bk/v01/varglv4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
17138881.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.4)
20044801.17sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer
84788641.00sclaus2048crypto_dh/sclaus2048/gmpclang++ -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
97668181.15sclaus2048crypto_dh/sclaus2048/cryptoppg++ -march=k8 -O -fomit-frame-pointer
16457761.00surf127epscrypto_dh/surf127eps/mpfqclang -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4 (tags/RELEASE 34/final))
26891641.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -O3 -fomit-frame-pointer (4.8.4)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
12539071.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -march=nocona -O -fomit-frame-pointer (4.8.4)
13142791.05curve25519crypto_scalarmult/curve25519/donna_c64gcc -fno-schedule-insns -O3 -fomit-frame-pointer
13252321.06curve25519crypto_scalarmult/curve25519/amd64-51gcc -m64 -Os -fomit-frame-pointer
19614331.56curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=core2 -O2 -fomit-frame-pointer
25721642.05curve25519crypto_scalarmult/curve25519/ref10gcc -fno-schedule-insns -O -fomit-frame-pointer
3677034629.32curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/sandy2xgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
16348231.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.8.4)
17148781.05kummercrypto_scalarmult/kummer/ref5ugcc -m64 -march=nocona -O3 -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
41139901.00nistp256crypto_scalarmult/nistp256/mj32gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.8.4)