Implementation notes: amd64, utrecht, crypto_dh

Computer: utrecht
Architecture: amd64
CPU ID: GenuineIntel-000006fb-bfebfbff
CPU cycles/second: 2394000000...2394000000 (amd64cpuinfo)
SUPERCOP version: 20120310
Benchmark dates: 20100610...20120312

crypto_dh

TimeRelative timePrimitiveImplementationCompiler
106303861.00clauscrypto_dh/claus/gmpg++ -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.3)
128029951.20clauscrypto_dh/claus/cryptoppg++ -m64 -march=core2 -msse4 -Os -fomit-frame-pointer
186727591.76clauscrypto_dh/claus/opensslgcc -march=nocona -Os -fomit-frame-pointer
clauscrypto_dh/claus/ntlg++ -m64 -O3 -fomit-frame-pointer
13838401.00curve2251crypto_dh/curve2251/relic/amd64-ssse3gcc -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.3)
43708053.16curve2251crypto_dh/curve2251/mpfqgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-avxgcc -m64 -O3 -fomit-frame-pointer
curve2251crypto_dh/curve2251/relic/amd64-clmulgcc -m64 -O3 -fomit-frame-pointer
12524311.00curve25519crypto_dh/curve25519/refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.3)
15560011.24curve25519crypto_dh/curve25519/mpfqgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
8703001.00ecfp256ecrypto_dh/ecfp256e/v01/w8s8gcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
8772841.01ecfp256ecrypto_dh/ecfp256e/v01/w8s4gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
8946901.03ecfp256ecrypto_dh/ecfp256e/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
9329761.07ecfp256ecrypto_dh/ecfp256e/v01/w8s1gcc -m64 -march=core2 -O2 -fomit-frame-pointer
14333671.65ecfp256ecrypto_dh/ecfp256e/v01/vargcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer
10532791.00ecfp256hcrypto_dh/ecfp256h/v01/w8s8gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer (4.4.3)
10611991.01ecfp256hcrypto_dh/ecfp256h/v01/w8s4gcc -m64 -O2 -fomit-frame-pointer
10821061.03ecfp256hcrypto_dh/ecfp256h/v01/w8s2gcc -m64 -O2 -fomit-frame-pointer
11208871.06ecfp256hcrypto_dh/ecfp256h/v01/w8s1gcc -O2 -fomit-frame-pointer
17793811.69ecfp256hcrypto_dh/ecfp256h/v01/vargcc -fno-schedule-insns -O2 -fomit-frame-pointer
9395101.00ecfp256icrypto_dh/ecfp256i/v01/w8s8gcc -fno-schedule-insns -O2 -fomit-frame-pointer (4.4.3)
9469171.01ecfp256icrypto_dh/ecfp256i/v01/w8s4gcc -m64 -march=k8 -O2 -fomit-frame-pointer
9610021.02ecfp256icrypto_dh/ecfp256i/v01/w8s2gcc -march=k8 -O2 -fomit-frame-pointer
9896581.05ecfp256icrypto_dh/ecfp256i/v01/w8s1gcc -m64 -march=k8 -O2 -fomit-frame-pointer
15174001.62ecfp256icrypto_dh/ecfp256i/v01/vargcc -m64 -O2 -fomit-frame-pointer
9155521.00ecfp256qcrypto_dh/ecfp256q/v01/w8s8gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3)
9256321.01ecfp256qcrypto_dh/ecfp256q/v01/w8s4gcc -fno-schedule-insns -O2 -fomit-frame-pointer
9401041.03ecfp256qcrypto_dh/ecfp256q/v01/w8s2gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer
9759961.07ecfp256qcrypto_dh/ecfp256q/v01/w8s1gcc -march=k8 -O2 -fomit-frame-pointer
14748211.61ecfp256qcrypto_dh/ecfp256q/v01/vargcc -march=k8 -O2 -fomit-frame-pointer
10817011.00ecfp256scrypto_dh/ecfp256s/v01/w8s8gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer (4.4.3)
10914661.01ecfp256scrypto_dh/ecfp256s/v01/w8s4gcc -m64 -march=core2 -O2 -fomit-frame-pointer
11104291.03ecfp256scrypto_dh/ecfp256s/v01/w8s2gcc -m64 -march=core2 -O3 -fomit-frame-pointer
11489851.06ecfp256scrypto_dh/ecfp256s/v01/w8s1gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer
18346051.70ecfp256scrypto_dh/ecfp256s/v01/vargcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer
9544951.00gls1271crypto_dh/gls1271/ref4gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
37874161.00hectorcrypto_dh/hector/refgcc -m64 -march=k8 -O2 -fomit-frame-pointer (4.4.3)
nistp256crypto_dh/nistp256/nawazgcc -m64 -O3 -fomit-frame-pointer
17837731.00sclaus1024crypto_dh/sclaus1024/gmpg++ -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer (4.4.3)
22700611.27sclaus1024crypto_dh/sclaus1024/cryptoppg++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer
87232411.00sclaus2048crypto_dh/sclaus2048/gmpg++ -m64 -march=nocona -Os -fomit-frame-pointer (4.4.3)
110885041.27sclaus2048crypto_dh/sclaus2048/cryptoppg++ -m64 -march=nocona -Os -fomit-frame-pointer (4.4.3)
17095051.00surf127epscrypto_dh/surf127eps/mpfqgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer (4.4.3)
34863391.00surf2113crypto_dh/surf2113/mpfqgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer (4.4.3)

crypto_scalarmult

TimeRelative timePrimitiveImplementationCompiler
6151591.00curve25519crypto_scalarmult/curve25519/donna_c64 (2.0)gcc -O3 -fomit-frame-pointer (4.4.3)
6158971.00curve25519crypto_scalarmult/curve25519/amd64-64gcc -march=barcelona -O2 -fomit-frame-pointer
6640381.08curve25519crypto_scalarmult/curve25519/amd64-51gcc -m64 -O -fomit-frame-pointer
9902161.61curve25519crypto_scalarmult/curve25519/donnagcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
12848672.09curve25519crypto_scalarmult/curve25519/ref10gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
1882351830.60curve25519crypto_scalarmult/curve25519/refgcc -funroll-loops -O -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/athlongcc -m64 -O3 -fomit-frame-pointer
curve25519crypto_scalarmult/curve25519/costigan-schwabe/cbegcc -m64 -O3 -fomit-frame-pointer