Implementation notes: amd64, hydra2, crypto_dh

Computer: hydra2
Architecture: amd64
CPU ID: GenuineIntel-000206c2-bfebfbff
CPU cycles/second: 2400000000...2400000000 (amd64cpuinfo)
SUPERCOP version: 20120310
Benchmark dates: 20110627...20120311

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
102410121.00clauscrypto_dh/claus/gmpg++ -march=k8 -O2 -fomit-frame-pointer (4.4.5)
105615121.03clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
177829521.74clauscrypto_dh/claus/opensslgcc -m64 -march=core2 -O2 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
6894161.00curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.4.5)
12812721.86curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
34389884.99curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -m64 -O2 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
9326841.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.5)
14578361.56curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
7471961.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.5)
7529161.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.5)
7675121.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
8005161.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
12340441.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.5)
8973641.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -O2 -fomit-frame-pointer (4.4.5)
9046841.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
9221961.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -O2 -fomit-frame-pointer (4.4.5)
9560001.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
15178041.69ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -O2 -fomit-frame-pointer
8036161.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -O2 -fomit-frame-pointer (4.4.5)
8086001.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
8205481.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -fno-schedule-insns -O3 -fomit-frame-pointer
8453561.05ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
13010081.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -fno-schedule-insns -O2 -fomit-frame-pointer
7890161.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -march=k8 -O2 -fomit-frame-pointer (4.4.5)
7951121.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
8086361.02ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -fno-schedule-insns -O3 -fomit-frame-pointer
8388561.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
12737121.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc -O3 -fomit-frame-pointer
9515521.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.4.5)
9604441.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.4.5)
9768881.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.4.5)
10129721.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
16233041.71ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -O2 -fomit-frame-pointer
8207361.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (4.4.5)
28058481.00hectorcrypto_dh/hector/refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer (4.4.5)
17318121.00sclaus1024crypto_dh/sclaus1024/gmpg++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer (4.4.5)
18786801.08sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -march=core2 -O -fomit-frame-pointer
83343641.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O3 -fomit-frame-pointer (4.4.5)
92850041.11sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer
15474601.00surf127epscrypto_dh/surf127eps/mpfqgcc -march=barcelona -O3 -fomit-frame-pointer (4.4.5)
26318361.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -m64 -O3 -fomit-frame-pointer (4.4.5)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
4538201.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer (4.4.5)
5313281.17curve25519crypto_scalarmult/curve25519/amd64-64gcc -m64 -march=nocona -Os -fomit-frame-pointer
5601081.23curve25519crypto_scalarmult/curve25519/donna_c64gcc -O3 -fomit-frame-pointer
8348561.84curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
9825802.17curve25519crypto_scalarmult/curve25519/ref10gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
1988673243.82curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer