Struct bellperson::gadgets::num::AllocatedNum [−][src]
pub struct AllocatedNum<E: ScalarEngine> { /* fields omitted */ }
Implementations
pub fn alloc<CS, F>(cs: CS, value: F) -> Result<Self, SynthesisError> where
CS: ConstraintSystem<E>,
F: FnOnce() -> Result<E::Fr, SynthesisError>,
[src]pub fn inputize<CS>(&self, cs: CS) -> Result<(), SynthesisError> where
CS: ConstraintSystem<E>,
[src]pub fn to_bits_le_strict<CS>(
&self,
cs: CS
) -> Result<Vec<Boolean>, SynthesisError> where
CS: ConstraintSystem<E>,
[src]
pub fn to_bits_le_strict<CS>(
&self,
cs: CS
) -> Result<Vec<Boolean>, SynthesisError> where
CS: ConstraintSystem<E>,
[src]Deconstructs this allocated number into its boolean representation in little-endian bit order, requiring that the representation strictly exists “in the field” (i.e., a congruency is not allowed.)
pub fn to_bits_le<CS>(&self, cs: CS) -> Result<Vec<Boolean>, SynthesisError> where
CS: ConstraintSystem<E>,
[src]
pub fn to_bits_le<CS>(&self, cs: CS) -> Result<Vec<Boolean>, SynthesisError> where
CS: ConstraintSystem<E>,
[src]Convert the allocated number into its little-endian representation. Note that this does not strongly enforce that the commitment is “in the field.”
pub fn mul<CS>(&self, cs: CS, other: &Self) -> Result<Self, SynthesisError> where
CS: ConstraintSystem<E>,
[src]pub fn square<CS>(&self, cs: CS) -> Result<Self, SynthesisError> where
CS: ConstraintSystem<E>,
[src]pub fn assert_nonzero<CS>(&self, cs: CS) -> Result<(), SynthesisError> where
CS: ConstraintSystem<E>,
[src]pub fn conditionally_reverse<CS>(
cs: CS,
a: &Self,
b: &Self,
condition: &Boolean
) -> Result<(Self, Self), SynthesisError> where
CS: ConstraintSystem<E>,
[src]
pub fn conditionally_reverse<CS>(
cs: CS,
a: &Self,
b: &Self,
condition: &Boolean
) -> Result<(Self, Self), SynthesisError> where
CS: ConstraintSystem<E>,
[src]Takes two allocated numbers (a, b) and returns (b, a) if the condition is true, and (a, b) otherwise.
Trait Implementations
Performs the conversion.
Auto Trait Implementations
impl<E> RefUnwindSafe for AllocatedNum<E> where
<E as ScalarEngine>::Fr: RefUnwindSafe,
impl<E> Send for AllocatedNum<E>
impl<E> Sync for AllocatedNum<E>
impl<E> Unpin for AllocatedNum<E> where
<E as ScalarEngine>::Fr: Unpin,
impl<E> UnwindSafe for AllocatedNum<E> where
<E as ScalarEngine>::Fr: UnwindSafe,
Blanket Implementations
Mutably borrows from an owned value. Read more
type Output = T
type Output = T
Should always be Self
pub fn vzip(self) -> V