librustzcash/bellman
Jack Grigg ad96a38750 group: Make Wnaf generic over Group
Wnaf was originally generic over CurveProjective; in the prior refactor
commit, we renamed this to CofactorCurve. But w-NAF only requires scalar
multiplication, which is provided by the Group trait, so we relax the
bounds on Wnaf to enable it to be used with any group. We move the
generic w-NAF helper methods from the Curve trait to a new WnafGroup
extension trait, to keep the w-NAF API surface self-contained, and not
expose it to users who aren't using it.
2020-06-17 11:42:11 +12:00
..
src group: Make Wnaf generic over Group 2020-06-17 11:42:11 +12:00
tests ff: Remove ScalarEngine 2020-05-31 02:06:24 +12:00
.gitignore Squashed 'bellman/' changes from 4272cfa..2279da4 2020-03-03 17:46:04 -07:00
COPYRIGHT Squashed 'bellman/' changes from 4272cfa..2279da4 2020-03-03 17:46:04 -07:00
Cargo.toml Merge branch 'develop' 2020-03-14 10:36:58 +13:00
LICENSE-APACHE Squashed 'bellman/' changes from 4272cfa..2279da4 2020-03-03 17:46:04 -07:00
LICENSE-MIT Squashed 'bellman/' changes from 4272cfa..2279da4 2020-03-03 17:46:04 -07:00
README.md Squashed 'bellman/' changes from 4272cfa..2279da4 2020-03-03 17:46:04 -07:00

README.md

bellman Crates.io

bellman is a crate for building zk-SNARK circuits. It provides circuit traits and primitive structures, as well as basic gadget implementations such as booleans and number abstractions.

Roadmap

bellman is being refactored into a generic proving library. Currently it is pairing-specific, and different types of proving systems need to be implemented as sub-modules. After the refactor, bellman will be generic using the ff and group crates, while specific proving systems will be separate crates that pull in the dependencies they require.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.