Implementation notes: amd64, hydra7, crypto_dh

Computer: hydra7
Architecture: amd64
CPU ID: GenuineIntel-000206a7-bfebfbff
CPU cycles/second: 3101000000...3101000000 (amd64cpuinfo)
SUPERCOP version: 20141014
Benchmark dates: 20140426...20141014

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
68872601.00clauscrypto_dh/claus/gmpg++ -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.3)
82078241.19clauscrypto_dh/claus/cryptoppg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
84623801.23clauscrypto_dh/claus/opensslgcc -march=k8 -O2 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
5843721.00curve2251crypto_dh/curve2251/relic/amd64-avxgcc -march=nocona -O3 -fomit-frame-pointer (4.6.3)
6548841.12curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
12124682.07curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
30569165.23curve2251crypto_dh/curve2251/mpfqgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
7767641.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.6.3)
11473561.48curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
6020841.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
6087921.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
6204521.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.3)
6472321.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -O3 -fomit-frame-pointer
9971241.66ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer
7127561.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -O3 -fomit-frame-pointer (4.6.3)
7196881.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
7330321.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer
7616321.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
12075201.69ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -O3 -fomit-frame-pointer
10419961.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=corei7 -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
6314041.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.6.3)
6374841.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
6499561.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
6756281.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -O3 -fomit-frame-pointer
10216761.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer
7586681.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -O3 -fomit-frame-pointer (4.6.3)
7662401.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
7792641.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
8089201.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -fno-schedule-insns -O3 -fomit-frame-pointer
12883641.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -O3 -fomit-frame-pointer (4.6.3)
20212081.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)gcc -funroll-loops -O3 -fomit-frame-pointer (4.6.3)
22988161.14ed448goldilockscrypto_dh/ed448goldilocks/64gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
59914322.96ed448goldilockscrypto_dh/ed448goldilocks/32gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/arm32gcc -m64 -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/neongcc -m64 -O3 -fomit-frame-pointer
7179121.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.6.3)
3249241.00gls254crypto_dh/gls254/refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
4805161.48gls254crypto_dh/gls254/protgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer
4809721.00gls254protcrypto_dh/gls254prot/protgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer (4.6.3)
6045401.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.3)
6064041.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer
6084961.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -O3 -fomit-frame-pointer
6156081.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer
6286441.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer
6551121.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
10722961.77hecfp127icrypto_dh/hecfp127i/v02/vargcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer
4802241.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -march=k8 -O2 -fomit-frame-pointer (4.6.3)
4829881.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
4871441.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
4970161.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
5162081.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer
5547681.16hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -m64 -march=nocona -O2 -fomit-frame-pointer
7529801.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
4793841.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer (4.6.3)
4813921.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
4856761.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -march=nocona -O2 -fomit-frame-pointer
4946521.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
5143601.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
5537401.16hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -O3 -fomit-frame-pointer
7519481.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
9321081.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -march=nocona -O2 -fomit-frame-pointer (4.6.3)
9345241.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
9397041.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
9492161.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -m64 -march=core2 -O3 -fomit-frame-pointer
9694241.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer
10103161.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -march=nocona -O2 -fomit-frame-pointer (4.6.3)
16578841.78hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=core2 -msse4 -O2 -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
24671121.00hectorcrypto_dh/hector/refgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer (4.6.3)
4844561.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -march=k8 -O -fomit-frame-pointer (4.6.3)
7502001.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -march=k8 -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
3570521.00kummercrypto_dh/kummer/refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
31372081.00nistp256crypto_dh/nistp256/refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.6.3)
41654881.33nistp256crypto_dh/nistp256/wblgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
11662241.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=core-avx-i -O3 -fomit-frame-pointer (4.6.3)
14703601.26sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=nocona -O3 -fomit-frame-pointer
58898121.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=corei7 -O3 -fomit-frame-pointer (4.6.3)
72755921.24sclaus2048crypto_dh/sclaus2048/cryptoppg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
11147041.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.6.3)
23348321.00surf2113crypto_dh/surf2113/mpfqgcc -m64 -march=corei7-avx -O2 -fomit-frame-pointer (4.6.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
7752321.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer (4.6.3)
8126441.05curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
9141361.18curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
14361761.85curve25519crypto_scalarmult/curve25519/donnagcc -O3 -fomit-frame-pointer
17457442.25curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -Os -fomit-frame-pointer
2758557235.58curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
3555841.00kummercrypto_scalarmult/kummer/avxgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.6.3)
12574403.54kummercrypto_scalarmult/kummer/ref5gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
13034643.67kummercrypto_scalarmult/kummer/ref5ugcc -m64 -march=k8 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2gcc -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2intgcc -m64 -O3 -fomit-frame-pointer
31395241.00nistp256crypto_scalarmult/nistp256/mj32gcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer (4.6.3)