Implementation notes: amd64, hydra3, crypto_dh

Computer: hydra3
Architecture: amd64
CPU ID: AuthenticAMD-00100fa0-178bfbff
CPU cycles/second: 3300000000...3300000000 (amd64cpuinfo)
SUPERCOP version: 20120310
Benchmark dates: 20120221...20120311

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
59725361.00clauscrypto_dh/claus/gmpg++ -m64 -march=nocona -O3 -fomit-frame-pointer (4.6.1)
79486361.33clauscrypto_dh/claus/cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/opensslgcc -m64 -O3 -fomit-frame-pointer
42252011.00curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -march=nocona -O -fomit-frame-pointer (4.6.1)
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -O3 -fomit-frame-pointer
7767481.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.6.1)
10709271.38curve25519crypto_dh/curve25519/mpfqgcc -m64 -march=nocona -O3 -fomit-frame-pointer
6301161.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=barcelona -O3 -fomit-frame-pointer (4.6.1)
6326891.00ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
6439441.02ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
6719811.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
9961151.58ecfp256ecrypto_dh/ecfp256e/v01/vargcc -funroll-loops -m64 -O3 -fomit-frame-pointer
7837331.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=k8 -O3 -fomit-frame-pointer (4.6.1)
7978141.02ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -march=nocona -O2 -fomit-frame-pointer
8055731.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -O3 -fomit-frame-pointer
8290511.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
12806391.63ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer
6727321.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.1)
6787071.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
6842291.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=k8 -O3 -fomit-frame-pointer
7042811.05ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -march=nocona -O3 -fomit-frame-pointer
10437161.55ecfp256icrypto_dh/ecfp256i/v01/vargcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer
6514991.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.1)
6588141.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
6700341.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -march=barcelona -O3 -fomit-frame-pointer
6923771.06ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
10176621.56ecfp256qcrypto_dh/ecfp256q/v01/vargcc -O3 -fomit-frame-pointer
7512041.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -fno-schedule-insns -O3 -fomit-frame-pointer (4.6.1)
7575721.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=k8 -O3 -fomit-frame-pointer
7706591.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -O3 -fomit-frame-pointer
7944231.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -O3 -fomit-frame-pointer
12276201.63ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=core2 -O3 -fomit-frame-pointer
6814521.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.1)
36052631.00hectorcrypto_dh/hector/refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer (4.6.1)
10170021.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=core2 -msse4 -Os -fomit-frame-pointer (4.6.1)
14040851.38sclaus1024crypto_dh/sclaus1024/cryptoppg++ -march=barcelona -O2 -fomit-frame-pointer
47589781.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.6.1)
74005681.56sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=barcelona -O3 -fomit-frame-pointer
10941561.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -O3 -fomit-frame-pointer (4.6.1)
31629791.00surf2113crypto_dh/surf2113/mpfqgcc -march=k8 -O -fomit-frame-pointer (4.6.1)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
3802471.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.6.1)
5197681.37curve25519crypto_scalarmult/curve25519/donna_c64gcc -O3 -fomit-frame-pointer
5655141.49curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (4.6.1)
7534701.98curve25519crypto_scalarmult/curve25519/donnagcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
12223123.21curve25519crypto_scalarmult/curve25519/ref10gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer
2314853360.88curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer