Implementation notes: amd64, hydra2, crypto_dh

Computer: hydra2
Architecture: amd64
CPU ID: GenuineIntel-000206c2-bfebfbff
CPU cycles/second: 2400000000...2400000000 (amd64cpuinfo)
SUPERCOP version: 20141014
Benchmark dates: 20140525...20141014

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
94678001.00clauscrypto_dh/claus/gmpg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3)
103713321.10clauscrypto_dh/claus/cryptoppclang++ -O3 -fomit-frame-pointer
115921241.22clauscrypto_dh/claus/opensslgcc -m64 -march=core2 -O2 -fomit-frame-pointer
118421001.25clauscrypto_dh/claus/ntlg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
6703801.00curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer (4.6.3)
12639801.89curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
36353365.42curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -march=nocona -O -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer (4.6.3)
9111361.00curve25519crypto_dh/curve25519/refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
14358081.58curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
7849761.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
7938921.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
8112561.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -fno-schedule-insns -O3 -fomit-frame-pointer
8465801.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -march=nocona -O3 -fomit-frame-pointer
13111881.67ecfp256ecrypto_dh/ecfp256e/v01/vargcc -march=nocona -O3 -fomit-frame-pointer
9516881.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
9604921.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
9784281.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
10174201.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
16195241.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
13797601.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer
8251761.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
8329081.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
8485361.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
8829761.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
13421081.63ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=nocona -O3 -fomit-frame-pointer
9876481.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
9970761.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -O3 -fomit-frame-pointer
10151681.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
10553881.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -O3 -fomit-frame-pointer
16879601.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -march=nocona -O3 -fomit-frame-pointer
21897681.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)clang -O3 -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
26569921.21ed448goldilockscrypto_dh/ed448goldilocks/64gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
44066362.01ed448goldilockscrypto_dh/ed448goldilocks/arm32clang -O3 -fwrapv -march=native -fomit-frame-pointer
64800242.96ed448goldilockscrypto_dh/ed448goldilocks/32clang -O3 -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
ed448goldilockscrypto_dh/ed448goldilocks/neongcc -m64 -O3 -fomit-frame-pointer
7728041.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.3)
3820561.00gls254crypto_dh/gls254/refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
5393921.41gls254crypto_dh/gls254/protgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
5394481.00gls254protcrypto_dh/gls254prot/protgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
7632921.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
7651281.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
7682601.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
7772921.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
7946121.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
8291921.09hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -fno-schedule-insns -O3 -fomit-frame-pointer
13618641.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
6839881.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -march=k8 -O3 -fomit-frame-pointer (4.6.3)
6875841.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -march=barcelona -O2 -fomit-frame-pointer
6930681.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
7073121.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -O3 -fomit-frame-pointer
7335561.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
7906921.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -march=nocona -O3 -fomit-frame-pointer
10754041.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
6824721.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
6848121.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
6918481.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
7047641.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -funroll-loops -O2 -fomit-frame-pointer
7334561.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
7894601.16hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -march=k8 -O2 -fomit-frame-pointer
10722401.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -march=k8 -O3 -fomit-frame-pointer
13321281.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer (4.6.3)
13357601.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -funroll-loops -O -fomit-frame-pointer
13423321.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -funroll-loops -m64 -O -fomit-frame-pointer
13569041.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -m64 -O -fomit-frame-pointer
13867961.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -m64 -O -fomit-frame-pointer
14458721.09hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -O -fomit-frame-pointer
23724001.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/varglv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s01glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s02glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s04glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s08glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s16glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s32glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/vargcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s01gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s02gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s04gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s08gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s16gcc -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s32gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/varglv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s01glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s02glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s04glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s08glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s16glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s32glv8gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/vargcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s01gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s02gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s04gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s08gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s16gcc -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s32gcc -m64 -O3 -fomit-frame-pointer
27312081.00hectorcrypto_dh/hector/refclang -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
6730161.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -funroll-loops -march=barcelona -O -fomit-frame-pointer (4.6.3)
11113681.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer (4.6.3)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
12182161.00kummercrypto_dh/kummer/refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
33672561.00nistp256crypto_dh/nistp256/refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.6.3)
39072001.16nistp256crypto_dh/nistp256/wblclang -O3 -fwrapv -march=native -fomit-frame-pointer
16002921.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.6.3)
18404361.15sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
80671481.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
92922201.15sclaus2048crypto_dh/sclaus2048/cryptoppclang++ -O3 -fwrapv -mavx2 -fomit-frame-pointer
15273001.00surf127epscrypto_dh/surf127eps/mpfqclang -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))
27400481.00surf2113crypto_dh/surf2113/mpfqclang -O3 -fwrapv -march=native -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
9089361.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer (4.6.3)
10612681.17curve25519crypto_scalarmult/curve25519/amd64-64clang -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
11370841.25curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
16487281.81curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
17718801.95curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer
3851994042.38curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
12197761.00kummercrypto_scalarmult/kummer/ref5gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
12972361.06kummercrypto_scalarmult/kummer/ref5ugcc -march=nocona -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avxgcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2gcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2intgcc -m64 -O3 -fomit-frame-pointer
33969401.00nistp256crypto_scalarmult/nistp256/mj32gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.6.3)