Implement Bulletproofs in Rust (#69)

* Initial attempt at Bulletproofs

I don't know why this doesn't work. The generators and hash_cache lines
up without issue. AFAICT, the inner product proof is valid as well, as
are all included formulas.

* Add yinvpow asserts

* Clean code

* Correct bad imports

* Fix the definition of TWO_N

Bulletproofs work now :D

* Tidy up a bit

* fmt + clippy

* Compile a variety of XMR dependencies with optimizations, even under dev

The Rust bulletproof implementation is 8% slower than C right now, under 
release. This is acceptable, even if suboptimal. Under debug, they take 
a quarter of a second to two seconds though, depending on the amount of 
outputs, which justifies this move.

* Remove unnecessary deref in BPs
This commit is contained in:
Luke Parker
2022-07-26 02:05:15 -05:00
committed by GitHub
parent 3711e13009
commit ee29f6d6d8
9 changed files with 382 additions and 45 deletions

1
Cargo.lock generated
View File

@@ -4581,6 +4581,7 @@ dependencies = [
"modular-frost",
"monero",
"monero-epee-bin-serde",
"multiexp",
"rand 0.8.5",
"rand_chacha 0.3.1",
"rand_core 0.6.3",