Commit Graph

214 Commits

Author SHA1 Message Date
Jack Grigg a77b2c8623 group: Renaming prior to trait refactor
This will reduce the size of the subsequent refactor diff.
2020-08-25 23:11:18 +01:00
Jack Grigg 8142ece846 group: Remove "compressed" notion from GroupEncoding
A generic group has a single encoding; for elliptic curves, this
happens to be the compressed encoding.
2020-08-25 23:11:18 +01:00
Jack Grigg 9397e78789 group: Extract compressed encodings from CurveAffine trait 2020-08-25 23:11:18 +01:00
Jack Grigg f490cdc674 group: Default implementation of CurveProjective::batch_normalize
For convenience. Implementations will usually override this to take
advantage of implementation-specific batching optimisations.
2020-08-25 23:11:18 +01:00
Jack Grigg 06c2c37b28 group: Move uncompressed encodings to an UncompressedEncoding trait
Specifications of deployed elliptic curves fall into one of two
categories:
- They specify both compressed and uncompressed encodings, allowing
  implementations to use either depending on performance vs data size
  considerations.
- They specify a single point encoding format using point compression.

I am unaware of any elliptic curve specification that explicitly forbids
compressed encodings.

To support both categories of elliptic curves, we provide the
CurveAffine::Compressed associated type which all curves must define,
and then curves that additionally specify an uncompressed encoding may
implement the UncompressedEncoding trait and its Uncompressed associated
type.

pairing::PairingCurveAffine continues to require that its groups provide
uncompressed encodings, because this is relied upon by bellman::groth16.
We can revisit this restriction when that module is refactored as a
separate crate.
2020-08-25 23:11:18 +01:00
Jack Grigg a1a27128f2 pairing: Move PairingCurveAffine::Prepared to MultiMillerLoop trait
Prepared elements are only used by MultiMillerLoop, and we don't need
the ability to "prepare" G1 elements there.
2020-08-25 23:11:18 +01:00
Jack Grigg 02dc1763a3 pairing: Extract Engine::miller_loop into a MultiMillerLoop trait
This enables MultiMillerLoop to be conditionally implemented, for
example in libraries where Engine::pairing supports no-std, but
MultiMillerLoop requires an allocator.
2020-08-25 23:11:18 +01:00
Jack Grigg ee6e00b0e7 pairing: Pass affine references to Engine::pairing 2020-08-25 23:11:17 +01:00
Jack Grigg 5eb58836ce pairing: Move final_exponentiation into a MillerLoopResult trait 2020-08-25 23:11:17 +01:00
Jack Grigg fd53dbc6f2 pairing: Separate associated types for MillerLoopResult and Gt 2020-08-25 23:11:17 +01:00
Jack Grigg f5254a1b8a pairing: Remove Engine::Fq and Engine::Fqe
These are unused now that the Base associated types have been removed
from the group traits.
2020-08-25 23:11:17 +01:00
Jack Grigg 2215865538 group: Remove CurveProjective::Base and CurveAffine::Base
These associated types were completly unused. The only place we need
information about the base field of an elliptic curve is inside Jubjub
when operating over its coordinates to implement EC math inside the
circuit, and we can handle that either concretely, or with a future
trait specifically for that use-case.
2020-08-25 23:11:17 +01:00
Jack Grigg 025746cdc8 ff: Remove ScalarEngine 2020-08-25 23:11:17 +01:00
Jack Grigg 2e540e681c bellman: Replace E: ScalarEngine with Scalar: PrimeField
Instead of imposing the requirement that bellman users explicitly
specify an engine for every proving system, we allow the Rust type
system to figure it out for us. An engine is specifically useful in
places where we require defined relationships between several types;
ff::ScalarEngine only has one type, and thus any usage of it can be
trivially replaced by an explicit Scalar type. This is also more
readable :)
2020-08-25 23:11:05 +01:00
Jack Grigg 027847f543 Fix various lints 2020-08-25 23:09:47 +01:00
Jack Grigg cbe8c5de67 group: Rename into_*(&self) -> to_*(&self)
Rust naming convention uses the into_ prefix for methods that consume
self, and the to_ prefix for methods that take an immutable reference.
2020-08-25 23:09:47 +01:00
Jack Grigg 392a107b31 group: Remove EncodedPoint::from_affine
The EncodedPoint trait is replaced by explicit bounds on the
CurveAffine::{Uncompressed, Compressed} associated types.
2020-08-25 23:09:47 +01:00
Jack Grigg 180e54d4b3 group: Remove EncodedPoint::{into_affine, into_affine_unchecked}
Replaced by explicit APIs on the CurveAffine trait.

GroupDecodingError has been moved into pairing::bls12_381::ec, as it is
no longer used by the group traits.
2020-08-25 23:09:47 +01:00
Jack Grigg 32c85391dc group: Add mixed-addition scalar multiplication bounds to CurveAffine
Replaces the explicit CurveAffine::mul trait method.
2020-08-25 23:09:47 +01:00
Jack Grigg 9c291bfb72 group: Return subtle::Choice from CurveAffine::is_identity 2020-08-25 23:09:47 +01:00
Jack Grigg 0ef1cc1034 group: Direct-to-affine CurveProjective::batch_normalize
Replaces the mutating CurveProjective::batch_normalization API, and
removes the need for CurveProjective::is_normalized.

The new temporary implementation in pairing::bls12_381::ec is adapted
from bls12_381::g1.
2020-08-25 23:09:47 +01:00
Jack Grigg ac47effa05 group: Return subtle::Choice from Group::is_identity 2020-08-25 23:09:47 +01:00
Jack Grigg b72d0935b4 group: Add scalar multiplication bounds to Group
The Scalar associated type is moved from CurveProjective to Group.
2020-08-25 23:09:47 +01:00
Jack Grigg 3f0efc3a66 group: Add Group::Subgroup associated type
For prime-order groups, this may be Self.
2020-08-25 23:09:47 +01:00
Jack Grigg ac9b139d29 group: Move CurveProjective::double to Group 2020-08-25 23:09:47 +01:00
Jack Grigg bca06de21c group: Sum + for<'a> Sum<&'a Self> bounds for Group 2020-08-25 23:09:47 +01:00
Jack Grigg 78db26b713 group: Introduce Group and PrimeGroup traits
Group represents a cryptographic group with a large prime-order subgroup
and a small cofactor. PrimeGroup further constrains the group to have a
cofactor of one.
2020-08-25 23:09:47 +01:00
Jack Grigg e75b850fe5 Remove Engine associated type from CurveAffine and CurveProjective
The type Curve*::Engine::Fr is equivalent to Curve*::Scalar, making
Engine a redundant associated type.
2020-08-25 23:09:47 +01:00
Jack Grigg 8db20b4466 Make CurveProjective::double take &self and return Self 2020-08-25 23:09:47 +01:00
Jack Grigg 3d1af5bed8 group: Rename zero and one to identity and generator 2020-08-25 23:09:47 +01:00
Jack Grigg 145747c08b Remove explicit std::marker from Sized bound
Sized is always part of the prelude, and binding on std causes
compilation issues for no-std crates.
2020-08-25 23:09:47 +01:00
Jack Grigg d7e727255c ff: Rename PrimeField::into_repr -> PrimeField::to_repr 2020-08-25 23:09:47 +01:00
Jack Grigg 80a0c777bb ff: Move pow_vartime back into Field trait
The only places we don't use constant u64 limbs, we use PrimeField::char
instead (except in a single test where we use a field element).
2020-08-25 23:09:47 +01:00
Jack Grigg a0177b6108 ff: Remove Ord bound from PrimeField
ff_derive still implements Ord and PartialOrd for the fields it
implements, because pairing::bls12_381 internally assumes that those are
implemented. Once we delete that implementation, we will remove the Ord
and PartialOrd implementations from ff_derive.
2020-08-25 23:09:47 +01:00
Jack Grigg 9243a6d8bd ff: Add PrimeField::ReprEndianness associated type
This enables generic code to reliably operate on the bits of an encoded
field element, by converting them to and from a known (little)
endianness.

The BitAnd and Shr bounds on PrimeField are now removed, as users can
perform these operations themselves as needed.
2020-08-25 23:09:47 +01:00
Jack Grigg f8ed66ec97 ff: Remove frobenius_map from Field trait
It is only used internally in the bls12_381 crate, and field extensions
aren't exposed anywhere in the Zcash stack.
2020-08-25 23:09:47 +01:00
Jack Grigg 8318d2f481 ff: Remove SqrtField trait
The sqrt() function is now part of the Field trait. ff_derive returns an
error on fields for which it does not support generating a square root
function.

Note that Fq6 and Fq12 in pairing::bls12_381 leave the function
unimplemented. They will be dropped once the migration to the bls12_381
crate is complete. The equivalent structs in that crate are not exposed.
2020-08-25 23:09:47 +01:00
Jack Grigg d6a1581f83 ff: Remove PrimeFieldRepr trait
The ff::PrimeField::Repr associated type now has the minimal necessary
bounds, which can be satisfied by a newtype around a byte array.
2020-08-25 23:09:47 +01:00
Jack Grigg b269d6ab44 ff: Add Ord bound to PrimeField 2020-08-25 23:09:47 +01:00
Jack Grigg dfea841123 ff: PrimeField: BitAnd<u64, Output = u64> + Shr<u32, Output = Self> 2020-08-25 23:09:46 +01:00
Jack Grigg 027cb982dc ff: PrimeField::{is_even, is_odd} 2020-08-25 23:09:46 +01:00
Jack Grigg 43573a953b ff: Rework BitIterator to work with both u8 and u64 limb sizes
This enables BitIterator to be used with both the byte encoding and limb
representation of scalars.
2020-08-25 23:09:46 +01:00
Jack Grigg 0f49ddc2c0 ff: Add PrimeField: From<u64> constraint 2020-08-25 23:09:46 +01:00
Jack Grigg 0980462d4b ff: Move pow_vartime into a trait that is generic over the limb size
The trait is implemented by default for u8 and u64, allowing pow_vartime
to be used with both the byte encoding and limb representation of field
elements.
2020-08-25 23:09:46 +01:00
Jack Grigg f067548b44 group: Rewrite wNAF to remove dependency on ff::PrimeFieldRepr
Adapted from Scalar::non_adjacent_form in curve25519-dalek.
2020-08-25 23:09:46 +01:00
Jack Grigg 5552955ab8 group: Take scalar by reference in CurveProjective::recommended_wnaf_for_scalar 2020-08-25 23:09:46 +01:00
Jack Grigg 1a54252784 Move from CurveProjective::add_assign_mixed to traits 2020-08-25 23:09:46 +01:00
Jack Grigg 23443c7e8d Move from Curve*::negate to Neg operator 2020-08-25 23:09:46 +01:00
Jack Grigg 2013561f4c Move additive CurveProjective operators to traits 2020-08-25 23:09:46 +01:00
Jack Grigg 6db281d137 no_std support for ff crate 2020-08-25 23:09:46 +01:00