Implementation notes: amd64, hydra4, crypto_dh

Computer: hydra4
Architecture: amd64
CPU ID: AuthenticAMD-00300f10-178bfbff
CPU cycles/second: 2600000000...2600000000 (amd64cpuinfo)
SUPERCOP version: 20141014
Benchmark dates: 20140525...20141014

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
63582951.00clauscrypto_dh/claus/gmpg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
76918341.21clauscrypto_dh/claus/ntlg++ -O3 -fomit-frame-pointer
85083331.34clauscrypto_dh/claus/cryptoppg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
37413551.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -O -fomit-frame-pointer (4.6.3)
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -O3 -fomit-frame-pointer
8591271.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.6.3)
11042311.29curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
5928311.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.6.3)
5994691.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -funroll-loops -O3 -fomit-frame-pointer
6113791.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.6.3)
6391121.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
9824771.66ecfp256ecrypto_dh/ecfp256e/v01/vargcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
7505661.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.6.3)
7583591.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.6.3)
7710421.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -funroll-loops -O3 -fomit-frame-pointer
8028511.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
12782721.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -funroll-loops -O3 -fomit-frame-pointer
10317251.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
6152831.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.6.3)
6218941.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
6333291.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
6599931.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -funroll-loops -O3 -fomit-frame-pointer
10039111.63ecfp256qcrypto_dh/ecfp256q/v01/vargcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
7286761.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.6.3)
7351771.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -funroll-loops -O3 -fomit-frame-pointer
7475871.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
7760531.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer (4.6.3)
12365141.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
25564581.00ed448goldilockscrypto_dh/ed448goldilocks/64 (2014-10-12)clang -O3 -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
25749091.01ed448goldilockscrypto_dh/ed448goldilocks/amd64clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
60289162.36ed448goldilockscrypto_dh/ed448goldilocks/arm32clang -O3 -fwrapv -mavx2 -fomit-frame-pointer
86133953.37ed448goldilockscrypto_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
6403871.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -fno-schedule-insns -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
gls254protcrypto_dh/gls254prot/protgcc -m64 -O3 -fomit-frame-pointer
5923671.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
5938181.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
5967041.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
6026791.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
6157001.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
6430791.09hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
10561011.78hecfp127icrypto_dh/hecfp127i/v02/vargcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer
5011611.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
5041571.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=corei7 -O2 -fomit-frame-pointer
5090431.02hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
5187591.04hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -funroll-loops -O3 -fomit-frame-pointer
5375761.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
5792991.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
7881511.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
5003271.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.6.3)
5015671.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -funroll-loops -O2 -fomit-frame-pointer
5071211.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
5165431.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -funroll-loops -O3 -fomit-frame-pointer
5374551.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -funroll-loops -O2 -fomit-frame-pointer
5780271.16hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
7876241.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
9593111.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.6.3)
9624771.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
9673331.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
9778081.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
9969571.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
10407581.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
17059461.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -funroll-loops -fno-schedule-insns -O3 -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
32049071.00hectorcrypto_dh/hector/refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer (4.6.3)
4820241.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3)
8333361.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -funroll-loops -m64 -march=nocona -O -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
16459791.00kummercrypto_dh/kummer/refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
36531691.00nistp256crypto_dh/nistp256/wbl (0.0.1)clang -O3 -fomit-frame-pointer (4.2.1 Compatible Ubuntu Clang 3.0 (tags/RELEASE 30/final))
38430801.05nistp256crypto_dh/nistp256/refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer
10838411.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
15218231.40sclaus1024crypto_dh/sclaus1024/cryptoppclang++ -O3 -fwrapv -mavx2 -fomit-frame-pointer
51565681.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
73654741.43sclaus2048crypto_dh/sclaus2048/cryptoppg++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer
11468491.00surf127epscrypto_dh/surf127eps/mpfqclang -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))
30895211.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer (4.6.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
8577621.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.3)
11019801.28curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
12314951.44curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
16004821.87curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
26568713.10curve25519crypto_scalarmult/curve25519/ref10gcc -m64 -march=k8 -O2 -fomit-frame-pointer
4433373351.69curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O2 -fomit-frame-pointer
16445801.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.6.3)
16642941.01kummercrypto_scalarmult/kummer/ref5ugcc -funroll-loops -m64 -march=k8 -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
38537581.00nistp256crypto_scalarmult/nistp256/mj32gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.3)