Implementation notes: amd64, cryptothinkx, crypto_sign

Computer: cryptothinkx
Architecture: amd64
CPU ID: GenuineIntel-00040651-bfebfbff
CPU cycles/second: 3300000000...3300000000 (amd64cpuinfo)
SUPERCOP version: 20170105
Benchmark dates: 20170130...20170216

crypto_sign

TimeRelative timePrimitiveImplementationCompiler
2640331.003icpcrypto_sign/3icp/refg++ -m64 -march=corei7-avx -O3 -fomit-frame-pointer (5.4.0 20160609)
blscrypto_sign/bls/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
7083451.00donald1024crypto_sign/donald1024/opensslgcc -funroll-loops -O3 -fomit-frame-pointer (5.4.0 20160609)
19895251.00donald2048crypto_sign/donald2048/opensslgcc -fno-schedule-insns -O2 -fomit-frame-pointer (5.4.0 20160609)
donald2048crypto_sign/donald2048/cryptoppg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
3261511.00donald512crypto_sign/donald512/opensslgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (5.4.0 20160609)
19394131.00ecdonaldb163crypto_sign/ecdonaldb163/opensslclang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
24909121.00ecdonaldb233crypto_sign/ecdonaldb233/opensslgcc -m64 -march=core2 -Os -fomit-frame-pointer (5.4.0 20160609)
43531771.00ecdonaldb283crypto_sign/ecdonaldb283/opensslgcc -O -fomit-frame-pointer (5.4.0 20160609)
73447411.00ecdonaldb409crypto_sign/ecdonaldb409/opensslgcc -fno-schedule-insns -O3 -fomit-frame-pointer (5.4.0 20160609)
172318741.00ecdonaldb571crypto_sign/ecdonaldb571/opensslgcc -m64 -march=core-avx2 -O -fomit-frame-pointer (5.4.0 20160609)
18594631.00ecdonaldk163crypto_sign/ecdonaldk163/opensslgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer (5.4.0 20160609)
24082141.00ecdonaldk233crypto_sign/ecdonaldk233/opensslclang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
40983421.00ecdonaldk283crypto_sign/ecdonaldk283/opensslgcc -m64 -march=corei7-avx -O -fomit-frame-pointer (5.4.0 20160609)
68016061.00ecdonaldk409crypto_sign/ecdonaldk409/opensslclang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
160423261.00ecdonaldk571crypto_sign/ecdonaldk571/opensslgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (5.4.0 20160609)
12033811.00ecdonaldp160crypto_sign/ecdonaldp160/opensslgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv (5.4.0 20160609)
15040381.00ecdonaldp192crypto_sign/ecdonaldp192/opensslgcc -fno-schedule-insns -Os -fomit-frame-pointer (5.4.0 20160609)
6119911.00ecdonaldp224crypto_sign/ecdonaldp224/opensslgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (5.4.0 20160609)
5559481.00ecdonaldp256crypto_sign/ecdonaldp256/opensslgcc -m64 -march=barcelona -O3 -fomit-frame-pointer (5.4.0 20160609)
44022511.00ecdonaldp384crypto_sign/ecdonaldp384/opensslgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv (5.4.0 20160609)
29539891.00ecdonaldp521crypto_sign/ecdonaldp521/opensslgcc -funroll-loops -O2 -fomit-frame-pointer (5.4.0 20160609)
2211091.00ed25519crypto_sign/ed25519/amd64-51-30kclang -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
2392171.08ed25519crypto_sign/ed25519/amd64-64-24kgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer
5068802.29ed25519crypto_sign/ed25519/ref10gcc -m64 -march=barcelona -O -fomit-frame-pointer
434667019.66ed25519crypto_sign/ed25519/refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments
7392781.00ed448goldilockscrypto_sign/ed448goldilocks/amd64 (2014-10-12)clang -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
8828971.19ed448goldilockscrypto_sign/ed448goldilocks/64gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer
13473571.82ed448goldilockscrypto_sign/ed448goldilocks/arm32clang -O3 -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
22796973.08ed448goldilockscrypto_sign/ed448goldilocks/32gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer
ed448goldilockscrypto_sign/ed448goldilocks/neongcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe25crypto_sign/fslwe25/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe37crypto_sign/fslwe37/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe47crypto_sign/fslwe47/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
fslwe69crypto_sign/fslwe69/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
hectorcrypto_sign/hector/refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
3177001.00lattisigns512crypto_sign/lattisigns512/avxgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer (5.4.0 20160609)
349561.00mqqsig160crypto_sign/mqqsig160/ref (1.00)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
499891.00mqqsig192crypto_sign/mqqsig192/ref (1.00)gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv (5.4.0 20160609)
606001.00mqqsig224crypto_sign/mqqsig224/ref (1.00)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
689911.00mqqsig256crypto_sign/mqqsig256/ref (1.00)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
9445381.00ntrumls401xcrypto_sign/ntrumls401x/ref (1.0)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
7345711.00ntrumls439xcrypto_sign/ntrumls439x/ref (1.0)clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
16415611.00ntrumls593xcrypto_sign/ntrumls593x/ref (1.0)clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
15505801.00ntrumls743xcrypto_sign/ntrumls743x/ref (1.0)clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
8487901.00pass769crypto_sign/pass769/ref-karatsuba (1.0k)gcc -m64 -march=k8 -O3 -fomit-frame-pointer (5.4.0 20160609)
13333471.00pass863crypto_sign/pass863/ref-karatsuba (1.0k)clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
8040661.00pflash1crypto_sign/pflash1/refgcc -funroll-loops -O2 -fomit-frame-pointer (5.4.0 20160609)
rainbowcrypto_sign/rainbow/refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
959311.00rainbow5640crypto_sign/rainbow5640/refclang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
1320211.00rainbow6440crypto_sign/rainbow6440/refclang++ -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
640891.00rainbowbinary16242020crypto_sign/rainbowbinary16242020/refg++ -m64 -march=core-avx2 -O3 -fomit-frame-pointer (5.4.0 20160609)
489961.00rainbowbinary256181212crypto_sign/rainbowbinary256181212/refg++ -m64 -march=core-avx2 -O3 -fomit-frame-pointer (5.4.0 20160609)
9148711.00ronald1024crypto_sign/ronald1024/opensslgcc -m64 -march=core2 -O3 -fomit-frame-pointer (5.4.0 20160609)
24260311.00ronald1536crypto_sign/ronald1536/opensslgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer (5.4.0 20160609)
32635411.00ronald2048crypto_sign/ronald2048/opensslgcc -m64 -march=core-avx-i -O3 -fomit-frame-pointer (5.4.0 20160609)
109774261.00ronald3072crypto_sign/ronald3072/opensslgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer (5.4.0 20160609)
231591721.00ronald4096crypto_sign/ronald4096/opensslgcc -funroll-loops -march=k8 -O -fomit-frame-pointer (5.4.0 20160609)
4013611.00ronald512crypto_sign/ronald512/opensslgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer (5.4.0 20160609)
6713521.00ronald768crypto_sign/ronald768/opensslclang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))
rwb0fuz1024crypto_sign/rwb0fuz1024/gmpgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
1714801.00sflashv2crypto_sign/sflashv2/refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer (5.4.0 20160609)
452143741.00sphincs256crypto_sign/sphincs256/avx2gcc -funroll-loops -m64 -O3 -fomit-frame-pointer (5.4.0 20160609)
2055724024.55sphincs256crypto_sign/sphincs256/refgcc -m64 -march=corei7 -O3 -fomit-frame-pointer
863701.00tts6440crypto_sign/tts6440/refclang++ -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments (4.2.1 Compatible Clang 3.8.0 (tags/RELEASE 380/final))