Implementation notes: amd64, mangetsu, crypto_dh

Computer: mangetsu
Architecture: amd64
CPU ID: GenuineIntel-000206a7-bfebfbff
CPU cycles/second: 3400000000...3400000000 (amd64cpuinfo)
SUPERCOP version: 20141014
Benchmark dates: 20140911...20141018

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
82526281.00clauscrypto_dh/claus/cryptoppg++ -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc-4.7 -m64 -O3 -fomit-frame-pointer
5848681.00curve2251crypto_dh/curve2251/relic/amd64-avxgcc-4.7 -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.7.4)
6560561.12curve2251crypto_dh/curve2251/relic/amd64-clmulgcc-4.7 -funroll-loops -march=k8 -O3 -fomit-frame-pointer
12170562.08curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/mpfqgcc-4.7 -m64 -O3 -fomit-frame-pointer
7770201.00curve25519crypto_dh/curve25519/refgcc-4.7 -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.7.4)
curve25519crypto_dh/curve25519/mpfqgcc-4.7 -m64 -O3 -fomit-frame-pointer
6053801.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc-4.7 -O3 -fomit-frame-pointer (4.7.4)
6119921.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc-4.7 -m64 -march=core2 -O3 -fomit-frame-pointer
6235641.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc-4.7 -O3 -fomit-frame-pointer (4.7.4)
6495601.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc-4.7 -m64 -march=corei7 -O3 -fomit-frame-pointer
9978201.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc-4.7 -O3 -fomit-frame-pointer (4.7.4)
7160801.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc-4.7 -fno-schedule-insns -O3 -fomit-frame-pointer (4.7.4)
7236761.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc-4.7 -O3 -fomit-frame-pointer
7356561.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc-4.7 -fno-schedule-insns -O3 -fomit-frame-pointer (4.7.4)
7643921.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
12107041.69ecfp256hcrypto_dh/ecfp256h/v01/vargcc-4.7 -m64 -march=k8 -O3 -fomit-frame-pointer
10459401.00ecfp256icrypto_dh/ecfp256i/v01/vargcc-4.7 -m64 -march=core2 -O3 -fomit-frame-pointer (4.7.4)
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc-4.7 -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc-4.7 -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc-4.7 -m64 -O3 -fomit-frame-pointer
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc-4.7 -m64 -O3 -fomit-frame-pointer
6357041.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.7.4)
6408161.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc-4.7 -m64 -march=core2 -O3 -fomit-frame-pointer
6526481.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.7.4)
6780001.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.7.4)
10245921.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc-4.7 -O3 -fomit-frame-pointer
7618561.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.7.4)
7706361.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc-4.7 -O3 -fomit-frame-pointer
7841121.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc-4.7 -m64 -march=core2 -O3 -fomit-frame-pointer
8137121.07ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc-4.7 -O3 -fomit-frame-pointer
12922201.70ecfp256scrypto_dh/ecfp256s/v01/vargcc-4.8 -fno-schedule-insns -O3 -fomit-frame-pointer
17546081.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)clang -O3 -fomit-frame-pointer (4.2.1 Compatible Clang 3.3 (branches/release 33 183898))
22760801.30ed448goldilockscrypto_dh/ed448goldilocks/64gcc-4.7 -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
38429202.19ed448goldilockscrypto_dh/ed448goldilocks/arm32clang -O3 -fomit-frame-pointer (4.2.1 Compatible Clang 3.3 (branches/release 33 183898))
58224963.32ed448goldilockscrypto_dh/ed448goldilocks/32gcc-4.8 -m64 -march=barcelona -O3 -fomit-frame-pointer
ed448goldilockscrypto_dh/ed448goldilocks/neongcc-4.7 -m64 -O3 -fomit-frame-pointer
7082561.00gls1271crypto_dh/gls1271/ref4gcc-4.7 -fno-schedule-insns -O3 -fomit-frame-pointer (4.7.4)
3113281.00gls254crypto_dh/gls254/refclang -O3 -fwrapv -march=native -fomit-frame-pointer (4.2.1 Compatible Clang 3.3 (branches/release 33 183898))
4631721.49gls254crypto_dh/gls254/protgcc-4.8 -m64 -march=corei7-avx -O3 -fomit-frame-pointer
4632561.00gls254protcrypto_dh/gls254prot/protgcc-4.8 -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
6043481.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc-4.8 -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
6051721.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc-4.8 -m64 -march=k8 -O3 -fomit-frame-pointer
6082281.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc-4.8 -march=nocona -O2 -fomit-frame-pointer
6146921.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc-4.8 -m64 -march=barcelona -O2 -fomit-frame-pointer
6272561.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc-4.8 -m64 -march=k8 -O3 -fomit-frame-pointer
6541401.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc-4.8 -m64 -march=k8 -O3 -fomit-frame-pointer
10693801.77hecfp127icrypto_dh/hecfp127i/v02/vargcc-4.8 -march=k8 -O2 -fomit-frame-pointer
4839801.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc-4.7 -m64 -march=k8 -O2 -fomit-frame-pointer (4.7.4)
4862041.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc-4.8 -m64 -march=nocona -O2 -fomit-frame-pointer
4888481.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc-4.7 -march=barcelona -O2 -fomit-frame-pointer
4972241.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc-4.7 -O3 -fomit-frame-pointer
5171801.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc-4.8 -march=barcelona -O2 -fomit-frame-pointer
5565601.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc-4.7 -march=nocona -O3 -fomit-frame-pointer
7558721.56hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc-4.8 -m64 -march=barcelona -O2 -fomit-frame-pointer
4831641.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc-4.8 -m64 -march=core2 -O3 -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
4834241.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
4875721.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc-4.7 -fno-schedule-insns -O3 -fomit-frame-pointer
4960041.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc-4.7 -march=barcelona -O2 -fomit-frame-pointer
5152081.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc-4.8 -march=k8 -O3 -fomit-frame-pointer
5555961.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc-4.8 -m64 -march=barcelona -O2 -fomit-frame-pointer
7525841.56hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc-4.7 -march=barcelona -O2 -fomit-frame-pointer
9364401.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc-4.7 -O3 -fomit-frame-pointer (4.7.4)
9364921.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc-4.7 -m64 -march=nocona -O3 -fomit-frame-pointer
9407721.00hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc-4.7 -m64 -march=k8 -O3 -fomit-frame-pointer
9514081.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc-4.7 -fno-schedule-insns -O3 -fomit-frame-pointer
9720161.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc-4.7 -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
10122521.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc-4.7 -march=k8 -O3 -fomit-frame-pointer
16603321.77hecfp128icrypto_dh/hecfp128i/v02/vargcc-4.8 -O2 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/varglv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s01glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s02glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s04glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s08glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s16glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s32glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/vargcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s01gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s02gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s04gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s08gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s16gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s32gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/varglv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s01glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s02glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s04glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s08glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s16glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s32glv8gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/vargcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s01gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s02gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s04gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s08gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s16gcc-4.7 -m64 -O3 -fomit-frame-pointer
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s32gcc-4.7 -m64 -O3 -fomit-frame-pointer
hectorcrypto_dh/hector/refgcc-4.7 -m64 -O3 -fomit-frame-pointer
4844681.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc-4.8 -m64 -march=nocona -O3 -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
7526521.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc-4.7 -march=nocona -Os -fomit-frame-pointer (4.7.4)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc-4.7 -m64 -O3 -fomit-frame-pointer
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc-4.7 -m64 -O3 -fomit-frame-pointer
3572641.00kummercrypto_dh/kummer/refgcc-4.7 -funroll-loops -m64 -O2 -fomit-frame-pointer (4.7.4)
31079081.00nistp256crypto_dh/nistp256/refgcc-4.7 -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.7.4)
33909281.09nistp256crypto_dh/nistp256/wblclang -O3 -fwrapv -mavx -fomit-frame-pointer
14716001.00sclaus1024crypto_dh/sclaus1024/cryptoppg++ -march=barcelona -O3 -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -O3 -fomit-frame-pointer
72727281.00sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O3 -fomit-frame-pointer
surf127epscrypto_dh/surf127eps/mpfqgcc-4.7 -m64 -O3 -fomit-frame-pointer
surf2113crypto_dh/surf2113/mpfqgcc-4.7 -m64 -O3 -fomit-frame-pointer

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
7753041.00curve25519crypto_scalarmult/curve25519/amd64-51gcc-4.8 -funroll-loops -m64 -O -fomit-frame-pointer (4.8.1 20130909 [gcc-4 8-branch revision 202388])
8056401.04curve25519crypto_scalarmult/curve25519/donna_c64gcc-4.7 -m64 -march=corei7 -O3 -fomit-frame-pointer
8120121.05curve25519crypto_scalarmult/curve25519/amd64-64clang -O3 -fwrapv -mavx -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
14356361.85curve25519crypto_scalarmult/curve25519/donnagcc-4.7 -m64 -O3 -fomit-frame-pointer
17051562.20curve25519crypto_scalarmult/curve25519/ref10gcc-4.7 -funroll-loops -march=barcelona -Os -fomit-frame-pointer
2672919634.48curve25519crypto_scalarmult/curve25519/refclang -O3 -fwrapv -mavx -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
3554921.00kummercrypto_scalarmult/kummer/avxclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer (4.2.1 Compatible Clang 3.3 (branches/release 33 183898))
11886283.34kummercrypto_scalarmult/kummer/ref5clang -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
12747363.59kummercrypto_scalarmult/kummer/ref5uclang -O3 -fwrapv -mavx -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2gcc-4.7 -m64 -O3 -fomit-frame-pointer
kummercrypto_scalarmult/kummer/avx2intgcc-4.7 -m64 -O3 -fomit-frame-pointer
31101841.00nistp256crypto_scalarmult/nistp256/mj32gcc-4.7 -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.7.4)