Implementation notes: amd64, titan0, crypto_dh

Computer: titan0
Architecture: amd64
CPU ID: GenuineIntel-000306c3-bfebfbff
CPU cycles/second: 3500000000...3501000000 (amd64cpuinfo)
SUPERCOP version: 20170105
Benchmark dates: 20160715...20170106

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
52032561.00clauscrypto_dh/claus/gmpg++ -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
72935321.40clauscrypto_dh/claus/opensslgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
78311241.51clauscrypto_dh/claus/cryptoppg++ -O3 -fomit-frame-pointer
83009961.60clauscrypto_dh/claus/ntlg++ -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
4035601.00curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -funroll-loops -O3 -fomit-frame-pointer (4.8.4)
4049201.00curve2251crypto_dh/curve2251/relic/amd64-avxgcc -march=nocona -O3 -fomit-frame-pointer
10900602.70curve2251crypto_dh/curve2251/relic/amd64-ssse3clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
24202966.00curve2251crypto_dh/curve2251/mpfqclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments
6022921.00curve25519crypto_dh/curve25519/refgcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.8.4)
9575361.59curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
5049681.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.8.4)
5093081.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
5197561.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer
5398361.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.8.4)
8262081.64ecfp256ecrypto_dh/ecfp256e/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
5912801.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.4)
5968681.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.4)
6076921.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
6305841.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
9962441.68ecfp256hcrypto_dh/ecfp256h/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
8756321.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.8.4)
ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
5312321.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
5360681.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
5453721.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
5667081.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
8525801.60ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
6414441.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
6470601.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
6585321.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
6815521.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
10837841.69ecfp256scrypto_dh/ecfp256s/v01/vargcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
14269001.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))
16901001.18ed448goldilockscrypto_dh/ed448goldilocks/64clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
28830722.02ed448goldilockscrypto_dh/ed448goldilocks/arm32clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
51500643.61ed448goldilockscrypto_dh/ed448goldilocks/32gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
42513681.00ed521gscrypto_dh/ed521gs/ref (1.0)gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv (4.8.4)
6199561.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.8.4)
1799201.00gls254crypto_dh/gls254/refclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))
1996521.11gls254crypto_dh/gls254/optclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
2484881.38gls254crypto_dh/gls254/protgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
2482241.00gls254protcrypto_dh/gls254prot/protgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
gls254protcrypto_dh/gls254prot/optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
5252921.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
5260841.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
5284081.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
5336881.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
5454281.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
5687721.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
9264201.76hecfp127icrypto_dh/hecfp127i/v02/vargcc -m64 -march=corei7 -O3 -fomit-frame-pointer
3836201.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3848321.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3880121.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
3946601.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
4119521.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
4424481.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -O2 -fomit-frame-pointer
5988241.56hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3829241.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3832201.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3865721.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
3939841.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
4103521.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
4421521.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -funroll-loops -O3 -fomit-frame-pointer
5977361.56hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer
7442561.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -march=k8 -O3 -fomit-frame-pointer (4.8.4)
7464561.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -m64 -march=k8 -O3 -fomit-frame-pointer
7492961.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
7573641.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
7736441.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -m64 -march=k8 -O3 -fomit-frame-pointer
8054881.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -m64 -march=k8 -O3 -fomit-frame-pointer
13185321.77hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=barcelona -O2 -fomit-frame-pointer
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/varglv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s01glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s02glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s04glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s08glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s16glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2bkcrypto_dh/hecfp61e2bk/v01/w8s32glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s01gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s02gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s04gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s08gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s16gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp61e2icrypto_dh/hecfp61e2i/v01/w8s32gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/varglv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s01glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s02glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s04glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s08glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s16glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2bkcrypto_dh/hecfp64e2bk/v01/w8s32glv8gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s01gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s02gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s04gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s08gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s16gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hecfp64e2icrypto_dh/hecfp64e2i/v01/w8s32gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
19585201.00hectorcrypto_dh/hector/refclang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))
4278761.00jacfp127icrypto_dh/jacfp127i/v01/w8s32gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.8.4)
4281521.00jacfp127icrypto_dh/jacfp127i/v01/w8s16gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4309801.01jacfp127icrypto_dh/jacfp127i/v01/w8s08gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
4357561.02jacfp127icrypto_dh/jacfp127i/v01/w8s04gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
4448721.04jacfp127icrypto_dh/jacfp127i/v01/w8s02gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4624801.08jacfp127icrypto_dh/jacfp127i/v01/w4s32gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4642321.08jacfp127icrypto_dh/jacfp127i/v01/w8s01gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4651281.09jacfp127icrypto_dh/jacfp127i/v01/w4s16gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4709881.10jacfp127icrypto_dh/jacfp127i/v01/w4s08gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4805641.12jacfp127icrypto_dh/jacfp127i/v01/w4s04gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
5004681.17jacfp127icrypto_dh/jacfp127i/v01/w4s02gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer
5392601.26jacfp127icrypto_dh/jacfp127i/v01/w4s01gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
7490321.75jacfp127icrypto_dh/jacfp127i/v01/vargcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
3026041.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s32glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3039361.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s16glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
3057961.01jacfp128bkcrypto_dh/jacfp128bk/v01/w8s08glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3113361.03jacfp128bkcrypto_dh/jacfp128bk/v01/w8s04glv4gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
3221521.06jacfp128bkcrypto_dh/jacfp128bk/v01/w8s02glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
3449961.14jacfp128bkcrypto_dh/jacfp128bk/v01/w8s01glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
3473481.15jacfp128bkcrypto_dh/jacfp128bk/v01/w4s32glv4gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
3496601.16jacfp128bkcrypto_dh/jacfp128bk/v01/w4s16glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
3553801.17jacfp128bkcrypto_dh/jacfp128bk/v01/w4s08glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
3669841.21jacfp128bkcrypto_dh/jacfp128bk/v01/w4s04glv4gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
3893401.29jacfp128bkcrypto_dh/jacfp128bk/v01/w4s02glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
4329761.43jacfp128bkcrypto_dh/jacfp128bk/v01/w4s01glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
4663521.54jacfp128bkcrypto_dh/jacfp128bk/v01/varglv4gcc -O2 -fomit-frame-pointer
4070521.00k277moncrypto_dh/k277mon/refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.4)
2678481.00k277taacrypto_dh/k277taa/refclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))
3062761.00k298crypto_dh/k298/refgcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer (4.8.4)
4365321.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -O3 -fomit-frame-pointer (4.8.4)
6311721.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.8.4)
kumfp61e2gcrypto_dh/kumfp61e2g/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
kumfp64e2gcrypto_dh/kumfp64e2g/v01/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
2815761.00kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s32gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer (4.8.4)
2826281.00kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s16gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer (4.8.4)
2849281.01kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s08gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer (4.8.4)
2900121.03kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s04gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer (4.8.4)
3001801.07kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s02gcc -m64 -march=corei7 -O -fomit-frame-pointer
3176841.13kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s32gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer (4.8.4)
3194361.13kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s01gcc -m64 -march=corei7-avx -O -fomit-frame-pointer
3203161.14kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s16gcc -m64 -march=core2 -O -fomit-frame-pointer
3247561.15kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s08gcc -m64 -march=core-avx-i -O -fomit-frame-pointer
3358441.19kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s04gcc -m64 -march=corei7-avx -O -fomit-frame-pointer
3563801.27kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s02gcc -m64 -march=corei7-avx -O -fomit-frame-pointer
3950361.40kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s01gcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer
6134442.18kumjacfp127gcrypto_dh/kumjacfp127g/v01/vargcc -fno-schedule-insns -O2 -fomit-frame-pointer
2433881.00kummercrypto_dh/kummer/refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.8.4)
48101161.00nist521gscrypto_dh/nist521gs/ref (1.0)gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.8.4)
19652921.00nistp256crypto_dh/nistp256/wbl (0.0.1)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))
29069721.48nistp256crypto_dh/nistp256/refgcc -m64 -march=k8 -O3 -fomit-frame-pointer
5152881.00prjfp127icrypto_dh/prjfp127i/v01/w8s32gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.8.4)
5161681.00prjfp127icrypto_dh/prjfp127i/v01/w8s16gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
5179521.01prjfp127icrypto_dh/prjfp127i/v01/w8s08gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
5241681.02prjfp127icrypto_dh/prjfp127i/v01/w8s04gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
5354161.04prjfp127icrypto_dh/prjfp127i/v01/w8s02gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
5562441.08prjfp127icrypto_dh/prjfp127i/v01/w4s32gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
5575641.08prjfp127icrypto_dh/prjfp127i/v01/w8s01gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
5587201.08prjfp127icrypto_dh/prjfp127i/v01/w4s16gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
5650641.10prjfp127icrypto_dh/prjfp127i/v01/w4s08gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
5768521.12prjfp127icrypto_dh/prjfp127i/v01/w4s04gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
6011441.17prjfp127icrypto_dh/prjfp127i/v01/w4s02gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
6465001.25prjfp127icrypto_dh/prjfp127i/v01/w4s01gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
9076481.76prjfp127icrypto_dh/prjfp127i/v01/vargcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
3709281.00prjfp128bkcrypto_dh/prjfp128bk/v01/w8s32glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.8.4)
3732561.01prjfp128bkcrypto_dh/prjfp128bk/v01/w8s16glv4gcc -fno-schedule-insns -O3 -fomit-frame-pointer
3757081.01prjfp128bkcrypto_dh/prjfp128bk/v01/w8s08glv4gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
3828121.03prjfp128bkcrypto_dh/prjfp128bk/v01/w8s04glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
3980521.07prjfp128bkcrypto_dh/prjfp128bk/v01/w8s02glv4gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
4261081.15prjfp128bkcrypto_dh/prjfp128bk/v01/w4s32glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
4289161.16prjfp128bkcrypto_dh/prjfp128bk/v01/w8s01glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.8.4)
4291681.16prjfp128bkcrypto_dh/prjfp128bk/v01/w4s16glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
4366481.18prjfp128bkcrypto_dh/prjfp128bk/v01/w4s08glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
4514681.22prjfp128bkcrypto_dh/prjfp128bk/v01/w4s04glv4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
4817241.30prjfp128bkcrypto_dh/prjfp128bk/v01/w4s02glv4gcc -m64 -march=core-avx2 -O3 -fomit-frame-pointer
5439801.47prjfp128bkcrypto_dh/prjfp128bk/v01/w4s01glv4gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
5771801.56prjfp128bkcrypto_dh/prjfp128bk/v01/varglv4gcc -march=barcelona -O3 -fomit-frame-pointer
8866081.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=corei7 -O3 -fomit-frame-pointer (4.8.4)
13942361.57sclaus1024crypto_dh/sclaus1024/cryptoppg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
44322281.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O3 -fomit-frame-pointer (4.8.4)
69846801.58sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=core-avx2 -Os -fomit-frame-pointer
8595721.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.8.4)
18865721.00surf2113crypto_dh/surf2113/mpfqclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6003321.00curve25519crypto_scalarmult/curve25519/sandy2x (1.0)clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))
6445401.07curve25519crypto_scalarmult/curve25519/amd64-51clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
7142761.19curve25519crypto_scalarmult/curve25519/amd64-64gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
7727681.29curve25519crypto_scalarmult/curve25519/donna_c64clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
10562841.76curve25519crypto_scalarmult/curve25519/donnagcc -march=barcelona -O3 -fomit-frame-pointer
14412802.40curve25519crypto_scalarmult/curve25519/ref10gcc -march=k8 -O -fomit-frame-pointer
2017505233.61curve25519crypto_scalarmult/curve25519/refclang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments
2418441.00kummercrypto_scalarmult/kummer/avx2intclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))
2878321.19kummercrypto_scalarmult/kummer/avx2gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
3744761.55kummercrypto_scalarmult/kummer/avxgcc -m64 -march=corei7-avx -O3 -fomit-frame-pointer
9419803.89kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
10055524.16kummercrypto_scalarmult/kummer/ref5ugcc -m64 -march=nocona -O3 -fomit-frame-pointer
29066561.00nistp256crypto_scalarmult/nistp256/mj32clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Ubuntu Clang 3.4.2 (tags/RELEASE 34/dot2-final))