217 lines
11 KiB
HTML
217 lines
11 KiB
HTML
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd">
|
|
<HTML>
|
|
<HEAD>
|
|
<TITLE>Speed Comparison of Popular Crypto Algorithms</TITLE>
|
|
</HEAD>
|
|
<BODY>
|
|
<H1><a href="http://www.cryptopp.com">Crypto++</a> 5.6.5 Benchmarks</H1>
|
|
<P>Here are speed benchmarks for some commonly used cryptographic algorithms.</P>
|
|
CPU frequency of the test platform is 1.81899e+09 Hz.
|
|
<TABLE border=1><COLGROUP><COL align=left><COL align=right><COL align=right><COL align=right><COL align=right>
|
|
<THEAD><TR><TH>Algorithm<TH>MiB/Second<TH>Cycles Per Byte<TH>Microseconds to<br>Setup Key and IV<TH>Cycles to<br>Setup Key and IV
|
|
|
|
<TBODY style="background: yellow">
|
|
<TR><TH>AES/GCM<TD>887<TD>2.0<TD>0.491<TD>893
|
|
<TR><TH>AES/CCM (128-bit key)<TD>452<TD>3.8<TD>0.311<TD>565
|
|
<TR><TH>AES/EAX (128-bit key)<TD>460<TD>3.8<TD>0.400<TD>728
|
|
<TBODY style="background: white">
|
|
<TR><TH>GMAC(AES)<TD>1505<TD>1.2<TD>0.493<TD>896
|
|
<TR><TH>VMAC(AES)-64 (128-bit key)<TD>7744<TD>0.2<TD>0.653<TD>1188
|
|
<TR><TH>VMAC(AES)-128 (128-bit key)<TD>4007<TD>0.4<TD>0.740<TD>1346
|
|
<TR><TH>HMAC(SHA-1) (128-bit key)<TD>268<TD>6.5<TD>0.259<TD>472
|
|
<TR><TH>Two-Track-MAC (160-bit key)<TD>211<TD>8.2<TD>0.015<TD>28
|
|
<TR><TH>CMAC(AES) (128-bit key)<TD>584<TD>3.0<TD>0.153<TD>278
|
|
<TR><TH>DMAC(AES) (128-bit key)<TD>583<TD>3.0<TD>0.431<TD>784
|
|
<TR><TH>BLAKE2s (256-bit key)<TD>569<TD>3.0<TD>0.250<TD>455
|
|
<TR><TH>BLAKE2b (512-bit key)<TD>751<TD>2.3<TD>0.295<TD>536
|
|
<TBODY style="background: yellow">
|
|
<TR><TH>CRC32<TD>425<TD>4.1
|
|
<TR><TH>CRC32C<TD>4124<TD>0.4
|
|
<TR><TH>Adler32<TD>1281<TD>1.4
|
|
<TR><TH>MD5<TD>528<TD>3.3
|
|
<TR><TH>SHA-1<TD>265<TD>6.5
|
|
<TR><TH>SHA-256<TD>181<TD>9.6
|
|
<TR><TH>SHA-512<TD>229<TD>7.6
|
|
<TR><TH>Keccak-224<TD>151<TD>11.5
|
|
<TR><TH>Keccak-256<TD>147<TD>11.8
|
|
<TR><TH>Keccak-384<TD>112<TD>15.5
|
|
<TR><TH>Keccak-512<TD>79<TD>22.0
|
|
<TR><TH>SHA3-224<TD>158<TD>11.0
|
|
<TR><TH>SHA3-256<TD>148<TD>11.7
|
|
<TR><TH>SHA3-384<TD>114<TD>15.2
|
|
<TR><TH>SHA3-512<TD>79<TD>21.9
|
|
<TR><TH>Tiger<TD>436<TD>4.0
|
|
<TR><TH>Whirlpool<TD>135<TD>12.9
|
|
<TR><TH>RIPEMD-160<TD>217<TD>8.0
|
|
<TR><TH>RIPEMD-320<TD>233<TD>7.5
|
|
<TR><TH>RIPEMD-128<TD>318<TD>5.5
|
|
<TR><TH>RIPEMD-256<TD>346<TD>5.0
|
|
<TR><TH>BLAKE2s<TD>570<TD>3.0
|
|
<TR><TH>BLAKE2b<TD>745<TD>2.3
|
|
<TBODY style="background: white">
|
|
<TR><TH>Panama-LE (256-bit key)<TD>1606<TD>1.1<TD>0.771<TD>1403
|
|
<TR><TH>Panama-BE (256-bit key)<TD>640<TD>2.7<TD>1.425<TD>2592
|
|
<TR><TH>Salsa20 (256-bit key)<TD>210<TD>8.3<TD>0.141<TD>256
|
|
<TR><TH>Salsa20/12<TD>334<TD>5.2<TD>0.171<TD>311
|
|
<TR><TH>Salsa20/8<TD>478<TD>3.6<TD>0.175<TD>318
|
|
<TR><TH>ChaCha20 (256-bit key)<TD>317<TD>5.5<TD>0.095<TD>172
|
|
<TR><TH>ChaCha12 (256-bit key)<TD>517<TD>3.4<TD>0.093<TD>169
|
|
<TR><TH>ChaCha8 (256-bit key)<TD>713<TD>2.4<TD>0.093<TD>169
|
|
<TR><TH>Sosemanuk (128-bit key)<TD>1269<TD>1.4<TD>0.457<TD>830
|
|
<TR><TH>MARC4 (128-bit key)<TD>395<TD>4.4<TD>1.397<TD>2541
|
|
<TR><TH>SEAL-3.0-LE (160-bit key)<TD>651<TD>2.7<TD>37.303<TD>67855
|
|
<TR><TH>WAKE-OFB-LE (256-bit key)<TD>334<TD>5.2<TD>1.725<TD>3137
|
|
<TBODY style="background: yellow">
|
|
<TR><TH>AES/CTR (128-bit key)<TD>2350<TD>0.7<TD>0.236<TD>430
|
|
<TR><TH>AES/CTR (192-bit key)<TD>2000<TD>0.9<TD>0.228<TD>415
|
|
<TR><TH>AES/CTR (256-bit key)<TD>1736<TD>1.0<TD>0.248<TD>451
|
|
<TR><TH>AES/CBC (128-bit key)<TD>590<TD>2.9<TD>0.180<TD>327
|
|
<TR><TH>AES/CBC (192-bit key)<TD>499<TD>3.5<TD>0.170<TD>310
|
|
<TR><TH>AES/CBC (256-bit key)<TD>433<TD>4.0<TD>0.190<TD>345
|
|
<TR><TH>AES/OFB (128-bit key)<TD>553<TD>3.1<TD>0.232<TD>422
|
|
<TR><TH>AES/CFB (128-bit key)<TD>574<TD>3.0<TD>0.258<TD>469
|
|
<TR><TH>AES/ECB (128-bit key)<TD>2824<TD>0.6<TD>0.083<TD>151
|
|
<TR><TH>Camellia/CTR (128-bit key)<TD>116<TD>14.9<TD>0.229<TD>416
|
|
<TR><TH>Camellia/CTR (256-bit key)<TD>92<TD>18.9<TD>0.253<TD>460
|
|
<TR><TH>Twofish/CTR (128-bit key)<TD>146<TD>11.9<TD>2.531<TD>4604
|
|
<TR><TH>Serpent/CTR (128-bit key)<TD>71<TD>24.5<TD>0.461<TD>838
|
|
<TR><TH>CAST-256/CTR (128-bit key)<TD>75<TD>23.3<TD>1.222<TD>2223
|
|
<TR><TH>RC6/CTR (128-bit key)<TD>121<TD>14.3<TD>2.120<TD>3857
|
|
<TR><TH>MARS/CTR (128-bit key)<TD>85<TD>20.4<TD>1.489<TD>2708
|
|
<TR><TH>SHACAL-2/CTR (128-bit key)<TD>114<TD>15.2<TD>0.312<TD>568
|
|
<TR><TH>SHACAL-2/CTR (512-bit key)<TD>115<TD>15.1<TD>0.318<TD>578
|
|
<TR><TH>DES/CTR (64-bit key)<TD>61<TD>28.4<TD>2.570<TD>4674
|
|
<TR><TH>DES-XEX3/CTR (192-bit key)<TD>57<TD>30.4<TD>2.593<TD>4716
|
|
<TR><TH>DES-EDE3/CTR (192-bit key)<TD>24<TD>73.4<TD>8.212<TD>14938
|
|
<TR><TH>IDEA/CTR (128-bit key)<TD>71<TD>24.4<TD>0.261<TD>474
|
|
<TR><TH>RC5 (r=16)<TD>102<TD>17.0<TD>1.702<TD>3096
|
|
<TR><TH>Blowfish/CTR (128-bit key)<TD>103<TD>16.8<TD>36.860<TD>67048
|
|
<TR><TH>TEA/CTR (128-bit key)<TD>59<TD>29.5<TD>0.230<TD>418
|
|
<TR><TH>XTEA/CTR (128-bit key)<TD>58<TD>29.9<TD>0.230<TD>419
|
|
<TR><TH>CAST-128/CTR (128-bit key)<TD>83<TD>20.9<TD>0.344<TD>625
|
|
<TR><TH>SKIPJACK/CTR (80-bit key)<TD>35<TD>49.1<TD>1.850<TD>3366
|
|
<TR><TH>SEED/CTR (1/2 K table)<TD>54<TD>32.3<TD>0.282<TD>514</TABLE>
|
|
<TABLE border=1><COLGROUP><COL align=left><COL align=right><COL align=right>
|
|
<THEAD><TR><TH>Operation<TH>Milliseconds/Operation<TH>Megacycles/Operation
|
|
|
|
<TBODY style="background: yellow">
|
|
<TR><TH>RSA 1024 Encryption<TD>0.02<TD>0.04
|
|
<TR><TH>RSA 1024 Decryption<TD>0.34<TD>0.62
|
|
<TR><TH>LUC 1024 Encryption<TD>0.02<TD>0.04
|
|
<TR><TH>LUC 1024 Decryption<TD>0.56<TD>1.02
|
|
<TR><TH>DLIES 1024 Encryption<TD>0.23<TD>0.41
|
|
<TR><TH>DLIES 1024 Encryption with precomputation<TD>0.42<TD>0.77
|
|
<TR><TH>DLIES 1024 Decryption<TD>0.32<TD>0.59
|
|
<TR><TH>LUCELG 512 Encryption<TD>0.14<TD>0.25
|
|
<TR><TH>LUCELG 512 Encryption with precomputation<TD>0.14<TD>0.25
|
|
<TR><TH>LUCELG 512 Decryption<TD>0.15<TD>0.27
|
|
<TBODY style="background: white">
|
|
<TR><TH>RSA 2048 Encryption<TD>0.04<TD>0.07
|
|
<TR><TH>RSA 2048 Decryption<TD>1.57<TD>2.85
|
|
<TR><TH>LUC 2048 Encryption<TD>0.05<TD>0.08
|
|
<TR><TH>LUC 2048 Decryption<TD>2.54<TD>4.62
|
|
<TR><TH>DLIES 2048 Encryption<TD>1.09<TD>1.98
|
|
<TR><TH>DLIES 2048 Encryption with precomputation<TD>1.25<TD>2.27
|
|
<TR><TH>DLIES 2048 Decryption<TD>1.04<TD>1.90
|
|
<TR><TH>LUCELG 1024 Encryption<TD>0.50<TD>0.91
|
|
<TR><TH>LUCELG 1024 Encryption with precomputation<TD>0.50<TD>0.90
|
|
<TR><TH>LUCELG 1024 Decryption<TD>0.43<TD>0.78
|
|
<TBODY style="background: yellow">
|
|
<TR><TH>RSA 1024 Signature<TD>0.35<TD>0.63
|
|
<TR><TH>RSA 1024 Verification<TD>0.02<TD>0.04
|
|
<TR><TH>RW 1024 Signature<TD>0.37<TD>0.68
|
|
<TR><TH>RW 1024 Signature with precomputation<TD>0.37<TD>0.67
|
|
<TR><TH>RW 1024 Verification<TD>0.01<TD>0.02
|
|
<TR><TH>LUC 1024 Signature<TD>0.56<TD>1.02
|
|
<TR><TH>LUC 1024 Verification<TD>0.02<TD>0.04
|
|
<TR><TH>NR 1024 Signature<TD>0.12<TD>0.22
|
|
<TR><TH>NR 1024 Signature with precomputation<TD>0.12<TD>0.22
|
|
<TR><TH>NR 1024 Verification<TD>0.13<TD>0.24
|
|
<TR><TH>NR 1024 Verification with precomputation<TD>0.19<TD>0.34
|
|
<TR><TH>DSA 1024 Signature<TD>0.12<TD>0.22
|
|
<TR><TH>DSA 1024 Signature with precomputation<TD>0.12<TD>0.22
|
|
<TR><TH>DSA 1024 Verification<TD>0.13<TD>0.24
|
|
<TR><TH>DSA 1024 Verification with precomputation<TD>0.19<TD>0.35
|
|
<TR><TH>LUC-HMP 512 Signature<TD>0.14<TD>0.25
|
|
<TR><TH>LUC-HMP 512 Signature with precomputation<TD>0.14<TD>0.25
|
|
<TR><TH>LUC-HMP 512 Verification<TD>0.14<TD>0.25
|
|
<TR><TH>LUC-HMP 512 Verification with precomputation<TD>0.14<TD>0.25
|
|
<TR><TH>ESIGN 1023 Signature<TD>0.06<TD>0.11
|
|
<TR><TH>ESIGN 1023 Verification<TD>0.02<TD>0.03
|
|
<TR><TH>ESIGN 1536 Signature<TD>0.10<TD>0.17
|
|
<TR><TH>ESIGN 1536 Verification<TD>0.03<TD>0.06
|
|
<TBODY style="background: white">
|
|
<TR><TH>RSA 2048 Signature<TD>1.60<TD>2.91
|
|
<TR><TH>RSA 2048 Verification<TD>0.04<TD>0.07
|
|
<TR><TH>RW 2048 Signature<TD>1.64<TD>2.98
|
|
<TR><TH>RW 2048 Signature with precomputation<TD>1.67<TD>3.04
|
|
<TR><TH>RW 2048 Verification<TD>0.02<TD>0.04
|
|
<TR><TH>LUC 2048 Signature<TD>2.60<TD>4.74
|
|
<TR><TH>LUC 2048 Verification<TD>0.05<TD>0.08
|
|
<TR><TH>NR 2048 Signature<TD>0.57<TD>1.03
|
|
<TR><TH>NR 2048 Signature with precomputation<TD>0.28<TD>0.51
|
|
<TR><TH>NR 2048 Verification<TD>0.63<TD>1.14
|
|
<TR><TH>NR 2048 Verification with precomputation<TD>0.41<TD>0.74
|
|
<TR><TH>LUC-HMP 1024 Signature<TD>0.50<TD>0.90
|
|
<TR><TH>LUC-HMP 1024 Signature with precomputation<TD>0.52<TD>0.94
|
|
<TR><TH>LUC-HMP 1024 Verification<TD>0.51<TD>0.92
|
|
<TR><TH>LUC-HMP 1024 Verification with precomputation<TD>0.51<TD>0.92
|
|
<TR><TH>ESIGN 2046 Signature<TD>0.12<TD>0.21
|
|
<TR><TH>ESIGN 2046 Verification<TD>0.04<TD>0.07
|
|
<TBODY style="background: yellow">
|
|
<TR><TH>XTR-DH 171 Key-Pair Generation<TD>0.17<TD>0.31
|
|
<TR><TH>XTR-DH 171 Key Agreement<TD>0.33<TD>0.61
|
|
<TR><TH>XTR-DH 342 Key-Pair Generation<TD>0.44<TD>0.79
|
|
<TR><TH>XTR-DH 342 Key Agreement<TD>0.88<TD>1.59
|
|
<TR><TH>DH 1024 Key-Pair Generation<TD>0.12<TD>0.22
|
|
<TR><TH>DH 1024 Key-Pair Generation with precomputation<TD>0.22<TD>0.40
|
|
<TR><TH>DH 1024 Key Agreement<TD>0.33<TD>0.60
|
|
<TR><TH>DH 2048 Key-Pair Generation<TD>0.56<TD>1.02
|
|
<TR><TH>DH 2048 Key-Pair Generation with precomputation<TD>0.64<TD>1.16
|
|
<TR><TH>DH 2048 Key Agreement<TD>1.05<TD>1.91
|
|
<TR><TH>LUCDIF 512 Key-Pair Generation<TD>0.07<TD>0.13
|
|
<TR><TH>LUCDIF 512 Key-Pair Generation with precomputation<TD>0.07<TD>0.13
|
|
<TR><TH>LUCDIF 512 Key Agreement<TD>0.15<TD>0.27
|
|
<TR><TH>LUCDIF 1024 Key-Pair Generation<TD>0.25<TD>0.46
|
|
<TR><TH>LUCDIF 1024 Key-Pair Generation with precomputation<TD>0.25<TD>0.46
|
|
<TR><TH>LUCDIF 1024 Key Agreement<TD>0.43<TD>0.79
|
|
<TR><TH>MQV 1024 Key-Pair Generation<TD>0.11<TD>0.21
|
|
<TR><TH>MQV 1024 Key-Pair Generation with precomputation<TD>0.11<TD>0.20
|
|
<TR><TH>MQV 1024 Key Agreement<TD>0.22<TD>0.41
|
|
<TR><TH>MQV 2048 Key-Pair Generation<TD>0.55<TD>1.00
|
|
<TR><TH>MQV 2048 Key-Pair Generation with precomputation<TD>0.27<TD>0.49
|
|
<TR><TH>MQV 2048 Key Agreement<TD>1.01<TD>1.85
|
|
<TBODY style="background: white">
|
|
<TR><TH>ECIES over GF(p) 256 Encryption<TD>1.41<TD>2.56
|
|
<TR><TH>ECIES over GF(p) 256 Encryption with precomputation<TD>1.20<TD>2.18
|
|
<TR><TH>ECIES over GF(p) 256 Decryption<TD>0.99<TD>1.79
|
|
<TR><TH>ECDSA over GF(p) 256 Signature<TD>0.72<TD>1.31
|
|
<TR><TH>ECDSA over GF(p) 256 Signature with precomputation<TD>0.61<TD>1.12
|
|
<TR><TH>ECDSA over GF(p) 256 Verification<TD>2.50<TD>4.54
|
|
<TR><TH>ECDSA over GF(p) 256 Verification with precomputation<TD>1.00<TD>1.82
|
|
<TR><TH>ECDHC over GF(p) 256 Key-Pair Generation<TD>0.71<TD>1.28
|
|
<TR><TH>ECDHC over GF(p) 256 Key-Pair Generation with precomputation<TD>0.62<TD>1.13
|
|
<TR><TH>ECDHC over GF(p) 256 Key Agreement<TD>0.72<TD>1.31
|
|
<TR><TH>ECMQVC over GF(p) 256 Key-Pair Generation<TD>0.71<TD>1.29
|
|
<TR><TH>ECMQVC over GF(p) 256 Key-Pair Generation with precomputation<TD>0.60<TD>1.09
|
|
<TR><TH>ECMQVC over GF(p) 256 Key Agreement<TD>2.54<TD>4.62<TBODY style="background: yellow">
|
|
|
|
<TR><TH>ECIES over GF(2^n) 233 Encryption<TD>7.77<TD>14.13
|
|
<TR><TH>ECIES over GF(2^n) 233 Encryption with precomputation<TD>2.14<TD>3.89
|
|
<TR><TH>ECIES over GF(2^n) 233 Decryption<TD>4.42<TD>8.04
|
|
<TR><TH>ECDSA over GF(2^n) 233 Signature<TD>3.94<TD>7.16
|
|
<TR><TH>ECDSA over GF(2^n) 233 Signature with precomputation<TD>1.08<TD>1.97
|
|
<TR><TH>ECDSA over GF(2^n) 233 Verification<TD>4.85<TD>8.83
|
|
<TR><TH>ECDSA over GF(2^n) 233 Verification with precomputation<TD>1.79<TD>3.25
|
|
<TR><TH>ECDHC over GF(2^n) 233 Key-Pair Generation<TD>3.89<TD>7.08
|
|
<TR><TH>ECDHC over GF(2^n) 233 Key-Pair Generation with precomputation<TD>1.07<TD>1.95
|
|
<TR><TH>ECDHC over GF(2^n) 233 Key Agreement<TD>3.93<TD>7.15
|
|
<TR><TH>ECMQVC over GF(2^n) 233 Key-Pair Generation<TD>3.88<TD>7.05
|
|
<TR><TH>ECMQVC over GF(2^n) 233 Key-Pair Generation with precomputation<TD>1.08<TD>1.96
|
|
<TR><TH>ECMQVC over GF(2^n) 233 Key Agreement<TD>4.90<TD>8.91</TABLE>
|
|
Throughput Geometric Average: 1110.724645
|
|
|
|
Test ended at Mon Sep 26 23:32:16 2016
|
|
</BODY>
|
|
</HTML>
|