Implementation notes: amd64, floodyberry, crypto_dh

Computer: floodyberry
Architecture: amd64
CPU ID: GenuineIntel-00010676-bfebfbff
CPU cycles/second: 2500000000...2500000000 (amd64cpuinfo)
SUPERCOP version: 20140505
Benchmark dates: 20140507...20140508

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
104932251.00clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer (4.6.3)
111394501.06clauscrypto_dh/claus/cryptoppg++ -m64 -O2 -fomit-frame-pointer
122527371.17clauscrypto_dh/claus/opensslgcc -m64 -O2 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer (4.6.3)
12785131.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
45307623.54curve2251crypto_dh/curve2251/mpfqgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
12312251.00curve25519crypto_dh/curve25519/refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
15824251.29curve25519crypto_dh/curve25519/mpfqgcc -m64 -O3 -fomit-frame-pointer
8551621.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8718001.02ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
8833251.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
9251371.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
14298371.67ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -O3 -fomit-frame-pointer
10436371.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
10618751.02ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
10711751.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
11177751.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
17892871.71ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
15036881.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -O3 -fomit-frame-pointer (4.6.3)
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
9066501.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
9227501.02ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
9343881.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
9737881.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
14858001.64ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -O3 -fomit-frame-pointer
10838001.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
10847881.00ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
11032001.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
11447251.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
18394121.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -O3 -fomit-frame-pointer
8932131.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)
gls254crypto_dh/gls254/protgcc -m64 -O3 -fomit-frame-pointer
gls254crypto_dh/gls254/refgcc -m64 -O3 -fomit-frame-pointer
8753371.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
8787001.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
8852621.01hecfp127icrypto_dh/hecfp127i/v02/w8s08icc -m64 -O1 -static -xHost -fomit-frame-pointer
8950371.02hecfp127icrypto_dh/hecfp127i/v02/w8s04icc -m64 -O1 -static -xHost -fomit-frame-pointer
9129001.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
9504381.09hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -m64 -O3 -fomit-frame-pointer (4.6.3)
15570381.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -m64 -O3 -fomit-frame-pointer (4.6.3)
8074871.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8081001.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8237251.02hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8322621.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8686371.08hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
9313501.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
12641501.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
8038501.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8147501.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8176871.02hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
8361381.04hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4icc -m64 -O1 -static -xHost -fomit-frame-pointer
8634001.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
9310871.16hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
12618501.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -m64 -O3 -fomit-frame-pointer
15630501.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)
15631871.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -m64 -O3 -fomit-frame-pointer
15721751.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)
15890501.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)
16228001.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)
16926751.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)
27729001.77hecfp128icrypto_dh/hecfp128i/v02/varicc -m64 -O3 -static -xHost -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
36250751.00hectorcrypto_dh/hector/refgcc -m64 -O2 -fomit-frame-pointer (4.6.3)
7232001.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
12851881.00kumfp128gcrypto_dh/kumfp128g/v02/varicc -m64 -O3 -static -xHost -fomit-frame-pointer (14.0.20130728)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -m64 -O3 -fomit-frame-pointer
kummercrypto_dh/kummer/refgcc -m64 -O3 -fomit-frame-pointer
17657621.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -O3 -fomit-frame-pointer (4.6.3)
19799631.12sclaus1024crypto_dh/sclaus1024/cryptoppicpc -m64 -O1 -static -xHost -fomit-frame-pointer
86807251.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
95009751.09sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
16283871.00surf127epscrypto_dh/surf127eps/mpfqclang -O3 -march=native -m64 -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.4 (trunk))
34560371.00surf2113crypto_dh/surf2113/mpfqgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.6.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
12298381.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
12835121.04curve25519crypto_scalarmult/curve25519/amd64-64clang -O1 -march=native -m64 -fomit-frame-pointer
13296001.08curve25519crypto_scalarmult/curve25519/amd64-51gcc -m64 -O2 -fomit-frame-pointer
19856751.61curve25519crypto_scalarmult/curve25519/donnagcc -m64 -O2 -fomit-frame-pointer
25455872.07curve25519crypto_scalarmult/curve25519/ref10clang -O3 -march=native -m64 -fomit-frame-pointer
4255288734.60curve25519crypto_scalarmult/curve25519/reficc -m64 -O3 -static -xHost -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avxgcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2gcc -m64 -O3 -fomit-frame-pointer