Measurements of public-key Diffie–Hellman secret-sharing systems on one machine: amd64; Kaby Lake (906e9); 2017 Intel Xeon E3-1220 v6; 4 x 3000MHz; kizomba, supercop-20250922
[Page version: 20251015 23:19:22]
eBATS
(ECRYPT Benchmarking
of Asymmetric Systems)
is a project
to measure the performance of public-key systems.
This page presents benchmark results collected in eBATS
for public-key Diffie–Hellman secret-sharing systems:
- Time (cycles) to generate a key pair:
a secret key and a corresponding public key.
- Time to compute a shared secret,
given one user's secret key and another user's public key.
- Space (bytes) for a secret key.
- Space for a public key.
- Space for a shared secret.
Each table row lists
the first quartile of many speed measurements,
the median of many speed measurements,
the third quartile of many speed measurements, and
the name of the primitive.
Measurements with large variance are indicated in red with question marks.
The symbol
T:
(starting with supercop-20200816)
means that the SUPERCOP database
at the time of benchmarking did not list constant time
as a goal for this implementation.
The symbol
T!!!
means that constant time was listed as a goal for this implementation,
but that the implementation failed TIMECOP.
(TIMECOP failures are not necessarily security issues;
they can sometimes be resolved by, e.g., declaring that a rejection-sampling condition is safe to declassify.)
There is a
separate page
with more information about each Diffie–Hellman system and each implementation.
Designers and implementors
interested in submitting new Diffie–Hellman systems
and new implementations of existing systems
should read the call for submissions.
Test results
Graphs:
old
(pkcycles,pkbytes)
(scycles,pkbytes)
Cycles to generate a key pair |
25% | 50% | 75% | system |
23169 | 24302 | 27091 | T: jacfp127i |
23409 | 24309 | 26224 | T: kumjacfp127g |
25071 | 25135 | 25188 | T: curve25519 |
24530 | 25252 | 28560 | T: prjfp127i |
25194 | 26420 | 29918 | T: hecfp127i |
31399 | 32574 | 35203 | T: jacfp128bk |
36782 | 37180 | 40268 | T: gls254 |
37121 | 37191 | 37273 | nistp256 |
35544 | 37244 | 39250 | T: prjfp128bk |
37496 | 38516 | 39666 | T: hecfp128i |
36830 | 38668 | 41794 | T: hecfp128bk |
38744 | 38801 | 39754 | T: gls254prot |
38498 | 39010 | 45982 | T: curve2251 |
38330 | 40516 | 44365 | T: hecfp128fkt |
41994 | 43293 | 46983 | T: ecfp256e |
42658 | 43818 | 48955 | T: ecfp256h |
45740 | 45791 | 51974 | T: k277taa |
44587 | 45873 | 51143 | T: ecfp256s |
46960 | 49242 | 54925 | T: ecfp256q |
50508 | 50710 | 56893 | T: k298 |
53944 | 58500 | 59127 | T: kummer |
69357 | 70823 | 72579 | T: gls1271 |
71407 | 71496 | 77750 | T: k277mon |
79542 | 80768 | 86147 | T: kumfp127g |
111182 | 112078 | 118391 | T: kumfp128g |
136709 | 138565 | 150096 | T: sclaus1024 |
153581 | 159373 | 169853 | T: ed448goldilocks |
178236 | 184110 | 196325 | T: ecfp256i |
183918 | 190633 | 203439 | T: surf127eps |
259316 | 276089 | 293260 | T: hector |
518685 | 533254 | 547923 | T: surf2113 |
665643 | 681986 | 709883 | T: sclaus2048 |
844752 | 858703 | 890385 | T: ed521gs |
875011 | 905123 | 932043 | T: claus |
995116 | 1009091 | 1045657 | T: nist521gs |
|
Cycles to compute a shared secret |
25% | 50% | 75% | system |
35649 | 35697 | 35792 | T: gls254 |
38488 | 38530 | 38601 | T: gls254prot |
45468 | 45502 | 48686 | T: k277taa |
50049 | 50164 | 54047 | T: k298 |
52500 | 53887 | 55851 | T: kummer |
71131 | 71201 | 77411 | T: k277mon |
73647 | 73744 | 73839 | T: curve25519 |
81073 | 81302 | 87798 | T: kumfp127g |
82833 | 82953 | 86192 | T: kumjacfp127g |
88427 | 88603 | 98825 | T: jacfp128bk |
108579 | 108831 | 115470 | T: prjfp128bk |
111960 | 112127 | 119728 | T: hecfp128bk |
115950 | 116133 | 122391 | T: hecfp128fkt |
115532 | 117070 | 124998 | T: kumfp128g |
124597 | 125032 | 134375 | T: jacfp127i |
138585 | 138732 | 138920 | nistp256 |
143131 | 148101 | 157379 | T: curve2251 |
159729 | 166181 | 179537 | T: ecfp256e |
166286 | 170365 | 183385 | T: prjfp127i |
167439 | 171470 | 187264 | T: hecfp127i |
170204 | 173728 | 187682 | T: ecfp256q |
170635 | 177105 | 189649 | T: ecfp256i |
173989 | 177471 | 183260 | T: gls1271 |
176308 | 180794 | 194218 | T: sclaus1024 |
177188 | 184047 | 194486 | T: surf127eps |
194260 | 200891 | 214871 | T: ecfp256h |
226619 | 234031 | 248088 | T: ecfp256s |
248470 | 251614 | 268911 | T: hecfp128i |
471565 | 483800 | 503064 | T: ed448goldilocks |
518936 | 531341 | 547230 | T: surf2113 |
839074 | 854782 | 884581 | T: ed521gs |
862335 | 869619 | 901198 | T: claus |
878502 | 898069 | 921448 | T: hector |
877236 | 900857 | 921565 | T: sclaus2048 |
997004 | 1013950 | 1037113 | T: nist521gs |
|
|
|