weikeng
a205f191f7
used AllocGadget for UInt64
4 years ago
Georgios Konstantopoulos
0ffa409ec1
Apply suggestions from code review
Co-Authored-By: Pratyush Mishra <pratyushmishra@berkeley.edu>
4 years ago
Georgios Konstantopoulos
f4e030793c
test: ensure the Counter and the System match
4 years ago
Georgios Konstantopoulos
695df979b5
chore: add helper
4 years ago
Georgios Konstantopoulos
951a6226c9
feat: TestConstraintCounter
4 years ago
Pratyush Mishra
b1913a9ca7
Change default `to_bits` and `to_bytes` functions to the safe versions
4 years ago
dependabot-preview[bot]
b24e705527
Update `derivative` requirement from 1 to 2 ( #140 )
4 years ago
dependabot-preview[bot]
9ca5a94f2e
Update digest requirement from 0.7 to 0.8 ( #141 )
* Update `digest` and `blake2` requirement from 0.7 to 0.8
Updates the requirements on [digest](https://github.com/RustCrypto/traits ) to permit the latest version.
- [Release notes](https://github.com/RustCrypto/traits/releases )
- [Commits](https://github.com/RustCrypto/traits/compare/digest_v0.7.2...digest-v0.8.1 )
Co-authored-by: dependabot-preview[bot] <27856297+dependabot-preview[bot]@users.noreply.github.com>
Co-authored-by: Pratyush Mishra <pratyushmishra@berkeley.edu>
4 years ago
ValarDragon
20af44e3c9
fix fmt check
4 years ago
ValarDragon
23c6bb4bd0
Rename arguments to CondSelectGadget for code clarity
4 years ago
Weikeng Chen
6c0ee7ffbc
Follow the nightly's suggested fmt change
4 years ago
weikeng
e524e46d0b
Add UInt64 used for representing Merkle tree node locations
4 years ago
Pratyush Mishra
0df0a15e1b
Blake PRF & R1CS Boolean Refactor ( #132 )
* refactor(r1cs-std/boolean): expose enforcing value less than functionality
* fix(r1cs-std/boolean): ensure num_bits is calculated correctly from the arg
* feat(primitives/blake2s): allow creating Blake2s with custom params
4 years ago
Pratyush Mishra
0b57cdd736
Add a pre-commit hook for rustfmt ( #102 )
* add a pre-commit hook for rustfmt
* make printing sccache stats optional
* fixup! add a pre-commit hook for rustfmt
4 years ago
Pratyush Mishra
50c0511ba3
Merge branch 'master' of https://github.com/scipr-lab/zexe
4 years ago
Pascal Berrang
b4b4e5553d
Implement CanonicalSerialize/Deserialize improvements ( #109 )
* Implement CanonicalSerialize/Deserialize improvements
* Improve code readability by using cursor
* Add tests for uncompressed serialization
* Improve serialization size (do not require full u64 limbs to be serialised)
* Change Flags to enum types
* Split up serialization with and without flags.
* Implement simple derive macro
* Derive traits for Groth16 and GM17 keys and proofs
4 years ago
ValarDragon
78e08aed97
Fix lint
4 years ago
ValarDragon
cba74c09d9
Fix error
4 years ago
ValarDragon
3cb1ed06d6
Fix linter errors
4 years ago
Pratyush Mishra
77837b4a1b
Fix ns issue
4 years ago
ValarDragon
cb1bcb1cbf
Fix ns
4 years ago
ValarDragon
b63d255ea3
Update to use bit iterator
4 years ago
ValarDragon
8cce6501b8
Add exponentiation by constant to Fp
4 years ago
Pratyush Mishra
7adcc69799
Generalize FFT infrastructure to work with group elements as well
4 years ago
Pratyush Mishra
faf179c43d
Export `algebra-core::error`
4 years ago
Pratyush Mishra
2298df2e78
Make benchmarks compile, and check them in CI
4 years ago
Pratyush Mishra
8bf042a029
Refactor `algebra` API, split into `algebra` and `algebra-core`. ( #100 )
4 years ago
Marek Kotewicz
d4896ade47
crypto-primitives no-std ( #96 )
4 years ago
howardwu
02e6b32d7d
Cargo fmt
4 years ago
howardwu
2949c0ef9d
Adds NIZK benchmarking, updates crypto-primitives benchmarks
4 years ago
Pratyush Mishra
bd501440cf
Add new additive and multiplcative ops for fields
4 years ago
Marek Kotewicz
9621bd34a4
r1cs-std works with no-std ( #92 )
4 years ago
Marek Kotewicz
a77972bf9a
no_std for algebra and r1cs-core ( #76 )
5 years ago
ValarDragon
5e57ac5621
Fix blake2s table alighnments
5 years ago
François Garillot
df6e235445
Add badge from deps.rs
5 years ago
François Garillot
a4a8116f1d
Update dependencies
5 years ago
François Garillot
b26867f267
Runs rustfmt on the repo
5 years ago
Pratyush Mishra
a3e1cd6cf2
Make libraries compile
5 years ago
Pratyush Mishra
762793ccbd
Update Cargo.toml
5 years ago
Pratyush Mishra
40cf13b7b8
num_traits:: -> algebra::
5 years ago
François Garillot
722a901ae7
[RFC] Convert identity functions in Field, Group, and {Projective,Affine}Curve traits with One/Zero traits from num_traits.
- contributes to #50 ,
- depends on #53 and builds on it,
- due to coherence & requirements of `num_traits::{Zero, One}` to implement `std::ops::Add<Self, ..>` and (resp.) `std::ops::Mul<Self, ..>`, I've had to replace the afferent `impl<'a, P: ..> (Add|Mul)<&'a Self> for Group(Affine|Projective)<P>` by direct implementations on `Self`,
- I did not have to fight the borrow checker for this conversion => I think this hints arithmetic operations are called in contexts where the operand is owned,
- hence should this end up on a merge track, we may want to open an issue to convert the `impl<'a, P:..> (Neg|Sub|..)<&'a Self> for ..<P>` trait usage to direct `impl<P:..> (Neg|Sub|..)<Self> for ..<P>`
- the `impl AddAssign for GroupAffine<P>` in curves/models/short_weierstrass_jacobian.rs is provided to fit trait bounds, and without any guarantee of suitability for any particular purpose
- and that, even though I don't think it's used.
5 years ago
Kobi Gurkan
b8a81b5dcb
r1cs-std: makes extension field to_bits create namespaces for the individual elements
5 years ago
Pratyush Mishra
2a8974e442
Boolean conditional select
5 years ago
François Garillot
ab65b01478
Clean up a few loop bounds
5 years ago
François Garillot
f1d8b122fc
Use operator syntax
eliminate a few redundant references
5 years ago
François Garillot
b42d5f8d36
Simplify a few "if" structures
5 years ago
François Garillot
53a51eb4dc
Use built-in iteration functions more
5 years ago
François Garillot
c42c7dd98a
Remove a few unnecessary clones
5 years ago
François Garillot
d71bc5a675
Prefer to return error rather than ? them,
avoid return when it cant be early (in a simple if-else)
5 years ago
François Garillot
10c6e85c1a
Remove a few unnecessary `.into_iter()` explicit calls, and some cloning.
See https://rust-lang.github.io/rust-clippy/master/#explicit_into_iter_loop
5 years ago