Implementation notes: amd64, gcc16, crypto_dh

Computer: gcc16
Architecture: amd64
CPU ID: AuthenticAMD-00100f23-178bfbff
CPU cycles/second: 2194151000...2194799000 (amd64cpuinfo)
SUPERCOP version: 20170105
Benchmark dates: 20160724...20170213

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
63290491.00clauscrypto_dh/claus/gmpg++ -m64 -march=core2 -O3 -fomit-frame-pointer (4.4.5)
87291841.38clauscrypto_dh/claus/cryptoppg++ -m64 -O3 -fomit-frame-pointer
153834962.43clauscrypto_dh/claus/opensslgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
38076171.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.5)
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
8800421.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.5)
11838201.35curve25519crypto_dh/curve25519/mpfqgcc -march=barcelona -O3 -fomit-frame-pointer
6760781.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.4.5)
6829831.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
6960061.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -O2 -fomit-frame-pointer
7221581.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=k8 -O2 -fomit-frame-pointer
10581611.57ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
8305391.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.5)
8365041.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -O2 -fomit-frame-pointer
8517451.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -O2 -fomit-frame-pointer
8798591.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=k8 -O2 -fomit-frame-pointer
13525221.63ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
11198761.00ecfp256icrypto_dh/ecfp256i/v01/vargcc -march=k8 -O2 -fomit-frame-pointer (4.4.5)
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
7030221.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.4.5)
7083561.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -march=k8 -O2 -fomit-frame-pointer
7211781.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -fno-schedule-insns -O2 -fomit-frame-pointer
7454601.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -O2 -fomit-frame-pointer
10877161.55ecfp256qcrypto_dh/ecfp256q/v01/vargcc -m64 -march=k8 -O2 -fomit-frame-pointer
8122501.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.4.5)
8185201.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
8300401.02ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.4.5)
8582861.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
13191941.62ecfp256scrypto_dh/ecfp256s/v01/vargcc -O2 -fomit-frame-pointer
28127051.00ed448goldilockscrypto_dh/ed448goldilocks/amd64 (2014-10-12)gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer (4.4.5)
30932211.10ed448goldilockscrypto_dh/ed448goldilocks/64gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
88006323.13ed448goldilockscrypto_dh/ed448goldilocks/32gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ed448goldilockscrypto_dh/ed448goldilocks/arm32gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
ed521gscrypto_dh/ed521gs/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
7646041.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (4.4.5)
gls254crypto_dh/gls254/optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254crypto_dh/gls254/protgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254crypto_dh/gls254/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254protcrypto_dh/gls254prot/optgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
gls254protcrypto_dh/gls254prot/protgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
6381681.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.5)
6388411.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
6419051.01hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
6485561.02hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
6633061.04hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
6919101.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
11304371.77hecfp127icrypto_dh/hecfp127i/v02/vargcc -fno-schedule-insns -O3 -fomit-frame-pointer
5428501.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.5)
5437851.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
5482601.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
5588801.03hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
5799191.07hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
6231081.15hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
8497681.57hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
5402211.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (4.4.5)
5416341.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
5459951.01hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
5570531.03hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
5774121.07hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -funroll-loops -O3 -fomit-frame-pointer
6215741.15hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
8472991.57hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer
10255471.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.4.5)
10273311.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
10321531.01hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
10440031.02hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
10660051.04hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
11117881.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
18196101.77hecfp128icrypto_dh/hecfp128i/v02/vargcc -funroll-loops -m64 -march=barcelona -O3 -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
31579511.00hectorcrypto_dh/hector/refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.4.5)
4900581.00jacfp127icrypto_dh/jacfp127i/v01/w8s16gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
4905691.00jacfp127icrypto_dh/jacfp127i/v01/w8s32gcc -march=nocona -O3 -fomit-frame-pointer
4926581.01jacfp127icrypto_dh/jacfp127i/v01/w8s08gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
4978941.02jacfp127icrypto_dh/jacfp127i/v01/w8s04gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
5088711.04jacfp127icrypto_dh/jacfp127i/v01/w8s02gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
5306951.08jacfp127icrypto_dh/jacfp127i/v01/w8s01gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
5313511.08jacfp127icrypto_dh/jacfp127i/v01/w4s32gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
5344961.09jacfp127icrypto_dh/jacfp127i/v01/w4s16gcc -m64 -march=nocona -O3 -fomit-frame-pointer
5399431.10jacfp127icrypto_dh/jacfp127i/v01/w4s08gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
5510481.12jacfp127icrypto_dh/jacfp127i/v01/w4s04gcc -march=nocona -O3 -fomit-frame-pointer
5729051.17jacfp127icrypto_dh/jacfp127i/v01/w4s02gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
6167371.26jacfp127icrypto_dh/jacfp127i/v01/w4s01gcc -m64 -march=nocona -O3 -fomit-frame-pointer
8568951.75jacfp127icrypto_dh/jacfp127i/v01/vargcc -funroll-loops -march=barcelona -O -fomit-frame-pointer
4306831.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s32glv4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.5)
4314771.00jacfp128bkcrypto_dh/jacfp128bk/v01/w8s16glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
4362361.01jacfp128bkcrypto_dh/jacfp128bk/v01/w8s08glv4gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (4.4.5)
4429691.03jacfp128bkcrypto_dh/jacfp128bk/v01/w8s04glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
4594071.07jacfp128bkcrypto_dh/jacfp128bk/v01/w8s02glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
4924511.14jacfp128bkcrypto_dh/jacfp128bk/v01/w8s01glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
4999341.16jacfp128bkcrypto_dh/jacfp128bk/v01/w4s32glv4gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
5044121.17jacfp128bkcrypto_dh/jacfp128bk/v01/w4s16glv4gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
5119171.19jacfp128bkcrypto_dh/jacfp128bk/v01/w4s08glv4gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
5294861.23jacfp128bkcrypto_dh/jacfp128bk/v01/w4s04glv4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
5609821.30jacfp128bkcrypto_dh/jacfp128bk/v01/w4s02glv4gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer
6272711.46jacfp128bkcrypto_dh/jacfp128bk/v01/w4s01glv4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
6630251.54jacfp128bkcrypto_dh/jacfp128bk/v01/varglv4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
k277moncrypto_dh/k277mon/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
k277taacrypto_dh/k277taa/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
k298crypto_dh/k298/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
5234211.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.5)
9072721.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (4.4.5)
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
3325321.00kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s16gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)
3339421.00kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s32gcc -m64 -O2 -fomit-frame-pointer
3350711.01kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s08gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
3404591.02kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s04gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)
3514141.06kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s02gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)
3733421.12kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s32gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
3740951.12kumjacfp127gcrypto_dh/kumjacfp127g/v01/w8s01gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
3767711.13kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s16gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
3819711.15kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s08gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
3934921.18kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s04gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
4161681.25kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s02gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)
4609281.39kumjacfp127gcrypto_dh/kumjacfp127g/v01/w4s01gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)
7040052.12kumjacfp127gcrypto_dh/kumjacfp127g/v01/vargcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer
16958261.00kummercrypto_dh/kummer/refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.5)
nist521gscrypto_dh/nist521gs/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
36774971.00nistp256crypto_dh/nistp256/wbl (0.0.1)gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.5)
67000951.82nistp256crypto_dh/nistp256/refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
6216871.00prjfp127icrypto_dh/prjfp127i/v01/w8s16gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
6249391.01prjfp127icrypto_dh/prjfp127i/v01/w8s08gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
6255331.01prjfp127icrypto_dh/prjfp127i/v01/w8s32gcc -march=nocona -O3 -fomit-frame-pointer
6321321.02prjfp127icrypto_dh/prjfp127i/v01/w8s04gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
6460611.04prjfp127icrypto_dh/prjfp127i/v01/w8s02gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
6724991.08prjfp127icrypto_dh/prjfp127i/v01/w4s32gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
6741851.08prjfp127icrypto_dh/prjfp127i/v01/w8s01gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
6767131.09prjfp127icrypto_dh/prjfp127i/v01/w4s16gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
6834541.10prjfp127icrypto_dh/prjfp127i/v01/w4s08gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
6977131.12prjfp127icrypto_dh/prjfp127i/v01/w4s04gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
7255841.17prjfp127icrypto_dh/prjfp127i/v01/w4s02gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
7809641.26prjfp127icrypto_dh/prjfp127i/v01/w4s01gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
11020461.77prjfp127icrypto_dh/prjfp127i/v01/vargcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
5258961.00prjfp128bkcrypto_dh/prjfp128bk/v01/w8s32glv4gcc -m64 -O3 -fomit-frame-pointer (4.4.5)
5280191.00prjfp128bkcrypto_dh/prjfp128bk/v01/w8s16glv4gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
5318421.01prjfp128bkcrypto_dh/prjfp128bk/v01/w8s08glv4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
5427171.03prjfp128bkcrypto_dh/prjfp128bk/v01/w8s04glv4gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer
5637331.07prjfp128bkcrypto_dh/prjfp128bk/v01/w8s02glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
6079201.16prjfp128bkcrypto_dh/prjfp128bk/v01/w8s01glv4gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
6096841.16prjfp128bkcrypto_dh/prjfp128bk/v01/w4s32glv4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
6138331.17prjfp128bkcrypto_dh/prjfp128bk/v01/w4s16glv4gcc -m64 -O2 -fomit-frame-pointer
6255411.19prjfp128bkcrypto_dh/prjfp128bk/v01/w4s08glv4gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer
6468831.23prjfp128bkcrypto_dh/prjfp128bk/v01/w4s04glv4gcc -m64 -O2 -fomit-frame-pointer
6897691.31prjfp128bkcrypto_dh/prjfp128bk/v01/w4s02glv4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
7761311.48prjfp128bkcrypto_dh/prjfp128bk/v01/w4s01glv4gcc -m64 -O2 -fomit-frame-pointer
8244611.57prjfp128bkcrypto_dh/prjfp128bk/v01/varglv4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
10807391.00sclaus1024crypto_dh/sclaus1024/gmpg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5)
15667761.45sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -Os -fomit-frame-pointer
51710691.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.5)
73768151.43sclaus2048crypto_dh/sclaus2048/cryptoppg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
11934821.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.4.5)
30309811.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.5)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
8785481.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5)
11338721.29curve25519crypto_scalarmult/curve25519/donna_c64gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.4.5)
12682361.44curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer
16856241.92curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer
27006383.07curve25519crypto_scalarmult/curve25519/ref10gcc -O3 -fomit-frame-pointer
4830602354.98curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O2 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/sandy2xgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
16942121.00kummercrypto_scalarmult/kummer/ref5gcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)
17963551.06kummercrypto_scalarmult/kummer/ref5ugcc -funroll-loops -O3 -fomit-frame-pointer (4.4.5)
kummercrypto_scalarmult/kummer/avxgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
kummercrypto_scalarmult/kummer/avx2gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
kummercrypto_scalarmult/kummer/avx2intgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
67045201.00nistp256crypto_scalarmult/nistp256/mj32gcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.4.5)