Implementation notes: amd64, sandy0, crypto_dh

Computer: sandy0
Architecture: amd64
CPU ID: GenuineIntel-000206a7-bfebfbff
CPU cycles/second: 3400000000...3400000000 (amd64cpuinfo)
SUPERCOP version: 20130419
Benchmark dates: 20120328...20130422

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
83139641.00clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer (4.6.1)
114075281.37clauscrypto_dh/claus/opensslgcc -m64 -march=corei7 -O2 -fomit-frame-pointer
clauscrypto_dh/claus/gmpg++ -m64 -O3 -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
6042561.00curve2251crypto_dh/curve2251/relic/amd64-avxgcc -funroll-loops -O2 -fomit-frame-pointer (4.6.1)
6768681.12curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
12421122.06curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -funroll-loops -m64 -O2 -fomit-frame-pointer
curve2251crypto_dh/curve2251/mpfqgcc -m64 -O3 -fomit-frame-pointer
7965121.00curve25519crypto_dh/curve25519/refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer (4.6.1)
curve25519crypto_dh/curve25519/mpfqgcc -m64 -O3 -fomit-frame-pointer
6049441.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=corei7 -O3 -fomit-frame-pointer (4.6.1)
6126841.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer
6239081.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
6505641.08ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
10005401.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
7136841.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=core2 -O3 -fomit-frame-pointer (4.6.1)
7223401.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -O3 -fomit-frame-pointer
7345561.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -march=nocona -O3 -fomit-frame-pointer
7630881.07ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
12126521.70ecfp256hcrypto_dh/ecfp256h/v01/vargcc -m64 -march=corei7 -O3 -fomit-frame-pointer
6471841.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.6.1)
6515081.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=core2 -O3 -fomit-frame-pointer
6618961.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.6.1)
6835121.06ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -O3 -fomit-frame-pointer
10481081.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -O3 -fomit-frame-pointer
6351521.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer (4.6.1)
6403321.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
6512601.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=corei7 -O3 -fomit-frame-pointer
6771801.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -O3 -fomit-frame-pointer
10264481.62ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=k8 -O3 -fomit-frame-pointer
7629441.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -O3 -fomit-frame-pointer (4.6.1)
7681601.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
7847721.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
8117001.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
12951441.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=corei7 -O3 -fomit-frame-pointer
7405361.00gls1271crypto_dh/gls1271/ref4gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.6.1)
3521241.00gls254crypto_dh/gls254/refgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer (4.6.1)
6114681.00hecfp127icrypto_dh/hecfp127i/v02/w8s32gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.1)
6127521.00hecfp127icrypto_dh/hecfp127i/v02/w8s08gcc -funroll-loops -m64 -O3 -fomit-frame-pointer
6140641.00hecfp127icrypto_dh/hecfp127i/v02/w8s16gcc -march=k8 -O -fomit-frame-pointer
6189081.01hecfp127icrypto_dh/hecfp127i/v02/w8s04gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
6291641.03hecfp127icrypto_dh/hecfp127i/v02/w8s02gcc -march=k8 -O3 -fomit-frame-pointer
6594681.08hecfp127icrypto_dh/hecfp127i/v02/w8s01gcc -O3 -fomit-frame-pointer
10734161.76hecfp127icrypto_dh/hecfp127i/v02/vargcc -m64 -march=core-avx-i -Os -fomit-frame-pointer
4868521.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s16glv4gcc -m64 -O3 -fomit-frame-pointer (4.6.1)
4876121.00hecfp128bkcrypto_dh/hecfp128bk/v02/w8s32glv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
4896961.01hecfp128bkcrypto_dh/hecfp128bk/v02/w8s08glv4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer
4979361.02hecfp128bkcrypto_dh/hecfp128bk/v02/w8s04glv4gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer
5182801.06hecfp128bkcrypto_dh/hecfp128bk/v02/w8s02glv4gcc -march=barcelona -O2 -fomit-frame-pointer
5573961.14hecfp128bkcrypto_dh/hecfp128bk/v02/w8s01glv4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
7552201.55hecfp128bkcrypto_dh/hecfp128bk/v02/varglv4gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
4872441.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s32glv4gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer (4.6.1)
4876601.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s16glv4gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
4879081.00hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s08glv4gcc -m64 -march=nocona -O2 -fomit-frame-pointer
4963681.02hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s04glv4gcc -m64 -march=corei7 -O2 -fomit-frame-pointer
5160961.06hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s02glv4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
5563721.14hecfp128fktcrypto_dh/hecfp128fkt/v02/w8s01glv4gcc -march=barcelona -O2 -fomit-frame-pointer
7521441.54hecfp128fktcrypto_dh/hecfp128fkt/v02/varglv4gcc -march=k8 -O2 -fomit-frame-pointer
9405161.00hecfp128icrypto_dh/hecfp128i/v02/w8s16gcc -O2 -fomit-frame-pointer (4.6.1)
9421081.00hecfp128icrypto_dh/hecfp128i/v02/w8s32gcc -funroll-loops -m64 -O -fomit-frame-pointer
9424601.00hecfp128icrypto_dh/hecfp128i/v02/w8s08gcc -m64 -march=barcelona -O3 -fomit-frame-pointer
9531761.01hecfp128icrypto_dh/hecfp128i/v02/w8s04gcc -funroll-loops -march=k8 -O -fomit-frame-pointer
9731841.03hecfp128icrypto_dh/hecfp128i/v02/w8s02gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
10147081.08hecfp128icrypto_dh/hecfp128i/v02/w8s01gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer
16600281.77hecfp128icrypto_dh/hecfp128i/v02/vargcc -m64 -march=nocona -O -fomit-frame-pointer
hectorcrypto_dh/hector/refgcc -m64 -O3 -fomit-frame-pointer
4847441.00kumfp127gcrypto_dh/kumfp127g/v02/vargcc -m64 -O2 -fomit-frame-pointer (4.6.1)
7502721.00kumfp128gcrypto_dh/kumfp128g/v02/vargcc -m64 -march=nocona -Os -fomit-frame-pointer (4.6.1)
14892241.00sclaus1024crypto_dh/sclaus1024/cryptoppg++ -m64 -Os -fomit-frame-pointer (4.6.1)
sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -O3 -fomit-frame-pointer
73825681.00sclaus2048crypto_dh/sclaus2048/cryptoppg++ -fno-schedule-insns -O2 -fomit-frame-pointer (4.6.1)
sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -O3 -fomit-frame-pointer
surf127epscrypto_dh/surf127eps/mpfqgcc -m64 -O3 -fomit-frame-pointer
surf2113crypto_dh/surf2113/mpfqgcc -m64 -O3 -fomit-frame-pointer

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
3882681.00curve25519crypto_scalarmult/curve25519/amd64-51gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer (4.6.1)
3915121.01curve25519crypto_scalarmult/curve25519/amd64-64gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
4580321.18curve25519crypto_scalarmult/curve25519/donna_c64gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
7178961.85curve25519crypto_scalarmult/curve25519/donnagcc -march=nocona -O3 -fomit-frame-pointer
8690962.24curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer
1398482436.02curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer