Mamy Ratsimbazafy
e5612f5705
Multi-Scalar-Multiplication / Linear combination ( #220 )
...
* unoptimized msm
* MSM: reorder loops
* add a signed windowed recoding technique
* improve wNAF table access
* use batchAffine
* revamp EC tests
* MSM signed digit support
* refactor MSM: recode signed ahead of time
* missing test vector
* refactor allocs and Alloca sideeffect
* add an endomorphism threshold
* Add Jacobian extended coordinates
* refactor recodings, prepare for parallelizable on-the-fly signed recoding
* recoding changes, introduce proper NAF for pairings
* more pairings refactoring, introduce miller accumulator for EVM
* some optim to the addchain miller loop
* start optimizing multi-pairing
* finish multi-miller loop refactoring
* minor tuning
* MSM: signed encoding suitable for parallelism (no precompute)
* cleanup signed window encoding
* add prefetching
* add metering
* properly init result to infinity
* comment on prefetching
* introduce vartime inversion for batch additions
* fix JacExt infinity conversion
* add batchAffine for MSM, though slower than JacExtended at the moment
* add a batch affine scheduler for MSM
* Add Multi-Scalar-Multiplication endomorphism acceleration
* some tuning
* signed integer fixes + 32-bit + tuning
* Some more tuning
* common msm bench + don't use affine for c < 9
* nit
2023-02-16 12:45:05 +01:00
..
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-01-12 20:25:57 +01:00
2023-01-12 20:25:57 +01:00
2023-01-12 20:25:57 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2022-04-27 00:58:48 +02:00
2022-04-27 00:58:48 +02:00
2023-02-16 12:45:05 +01:00
2022-04-27 00:58:48 +02:00
2023-02-16 12:45:05 +01:00
2022-04-27 00:58:48 +02:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2023-01-12 01:27:23 +01:00
2023-01-12 01:27:23 +01:00
2023-01-12 01:27:23 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-01-12 20:25:57 +01:00
2022-04-27 00:58:48 +02:00
2022-04-27 00:58:48 +02:00
2023-02-16 12:45:05 +01:00
2022-04-27 00:58:48 +02:00
2023-02-16 12:45:05 +01:00
2022-04-27 00:58:48 +02:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2023-01-12 01:27:23 +01:00
2023-01-12 01:27:23 +01:00
2023-01-12 01:27:23 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-01-12 20:25:57 +01:00
2022-02-28 09:23:26 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-08-14 09:48:10 +02:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-02-27 01:49:08 +01:00
2022-08-14 09:48:10 +02:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00
2023-01-27 00:42:12 +01:00
2023-02-16 12:45:05 +01:00
2023-02-16 12:45:05 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-02-16 12:45:05 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-01-27 00:42:12 +01:00
2023-02-16 12:45:05 +01:00
2023-02-07 13:11:44 +01:00
2023-02-16 12:45:05 +01:00
2022-02-27 01:49:08 +01:00
2023-02-16 12:45:05 +01:00