pub struct PolynomialPredicate<F: Field> {
pub polynomial: SparsePolynomial<F, SparseTerm>,
}Expand description
A polynomial predicat is just a polynomial
Fields§
§polynomial: SparsePolynomial<F, SparseTerm>The sparse polynomial for the predicate
Implementations§
Source§impl<F: Field> PolynomialPredicate<F>
impl<F: Field> PolynomialPredicate<F>
Sourcepub fn new(
arity: usize,
terms: impl IntoIterator<Item = (F, Vec<(usize, usize)>)>,
) -> Self
pub fn new( arity: usize, terms: impl IntoIterator<Item = (F, Vec<(usize, usize)>)>, ) -> Self
Create a new polynomial predicate with a given number of variables (= arity) and number of terms.
Here terms is a list of tuples of the form (variable, power) where
variable is the index of the variable and power is the exponent of the variable.
So, for example, if terms is [F::ONE, [(0, 1), (1, 2)]], then the polynomial is
x_0 + x_1^2.
Source§impl<F: Field> PolynomialPredicate<F>
This is the implementation of the Predicate trait for PolynomialPredicate.
The evaluation of a polynomial predicate is the evaluation of the underlying
polynomial and the arity is the number of variables in the polynomial.
impl<F: Field> PolynomialPredicate<F>
This is the implementation of the Predicate trait for PolynomialPredicate. The evaluation of a polynomial predicate is the evaluation of the underlying polynomial and the arity is the number of variables in the polynomial.
Trait Implementations§
Source§impl<F: Field> CanonicalDeserialize for PolynomialPredicate<F>
impl<F: Field> CanonicalDeserialize for PolynomialPredicate<F>
Source§fn deserialize_with_mode<R: Read>(
reader: R,
compress: Compress,
validate: Validate,
) -> Result<Self, SerializationError>
fn deserialize_with_mode<R: Read>( reader: R, compress: Compress, validate: Validate, ) -> Result<Self, SerializationError>
The general deserialize method that takes in customization flags.
Source§fn deserialize_compressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_compressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the compressed form if applicable.
Performs validation if applicable.Source§fn deserialize_compressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_compressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the compressed form if applicable, without validating the
deserialized value. Read moreSource§fn deserialize_uncompressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed<R>(reader: R) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the uncompressed form. Performs validation if applicable.Source§fn deserialize_uncompressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
fn deserialize_uncompressed_unchecked<R>(
reader: R,
) -> Result<Self, SerializationError>where
R: Read,
Reads
Self from reader using the uncompressed form, without validating the deserialized
value. Read moreSource§impl<F: Field> CanonicalSerialize for PolynomialPredicate<F>
impl<F: Field> CanonicalSerialize for PolynomialPredicate<F>
Source§fn serialize_with_mode<W: Write>(
&self,
writer: W,
compress: Compress,
) -> Result<(), SerializationError>
fn serialize_with_mode<W: Write>( &self, writer: W, compress: Compress, ) -> Result<(), SerializationError>
The general serialize method that takes in customization flags.
Source§fn serialized_size(&self, compress: Compress) -> usize
fn serialized_size(&self, compress: Compress) -> usize
Returns the size in bytes of the serialized version of
self with the given compression mode.Source§fn serialize_compressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn serialize_compressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
Serializes
self into writer using the compressed form if applicable.Source§fn compressed_size(&self) -> usize
fn compressed_size(&self) -> usize
Returns the size in bytes of the compressed serialized version of
self.Source§fn serialize_uncompressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
fn serialize_uncompressed<W>(&self, writer: W) -> Result<(), SerializationError>where
W: Write,
Serializes
self into writer using the uncompressed form.Source§fn uncompressed_size(&self) -> usize
fn uncompressed_size(&self) -> usize
Returns the size in bytes of the uncompressed serialized version of
self.Source§impl<F: Clone + Field> Clone for PolynomialPredicate<F>
impl<F: Clone + Field> Clone for PolynomialPredicate<F>
Source§fn clone(&self) -> PolynomialPredicate<F>
fn clone(&self) -> PolynomialPredicate<F>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<F: Field> Valid for PolynomialPredicate<F>
impl<F: Field> Valid for PolynomialPredicate<F>
Source§const TRIVIAL_CHECK: bool = <SparsePolynomial<F, SparseTerm> as ark_serialize::Valid>::TRIVIAL_CHECK
const TRIVIAL_CHECK: bool = <SparsePolynomial<F, SparseTerm> as ark_serialize::Valid>::TRIVIAL_CHECK
Whether the
check method is trivial (i.e. always returns Ok(())). If this is true,
the batch_check method will skip all checks and return Ok(()).
This should be set to true for types where check is trivial, e.g.
integers, field elements, etc.
This is false by default.
This is primarily an optimization to skip unnecessary checks in batch_check.Source§fn check(&self) -> Result<(), SerializationError>
fn check(&self) -> Result<(), SerializationError>
Checks whether
self is valid. If self is valid, returns Ok(()). Otherwise, returns
an error describing the failure.
This method is called by deserialize_with_mode if validate is Validate::Yes.Source§fn batch_check<'a>(
batch: impl Iterator<Item = &'a Self> + Send,
) -> Result<(), SerializationError>where
Self: 'a,
fn batch_check<'a>(
batch: impl Iterator<Item = &'a Self> + Send,
) -> Result<(), SerializationError>where
Self: 'a,
Checks whether all items in
batch are valid. If all items are valid, returns Ok(()).
Otherwise, returns an error describing the first failure.Auto Trait Implementations§
impl<F> Freeze for PolynomialPredicate<F>
impl<F> RefUnwindSafe for PolynomialPredicate<F>where
F: RefUnwindSafe,
impl<F> Send for PolynomialPredicate<F>
impl<F> Sync for PolynomialPredicate<F>
impl<F> Unpin for PolynomialPredicate<F>where
F: Unpin,
impl<F> UnsafeUnpin for PolynomialPredicate<F>
impl<F> UnwindSafe for PolynomialPredicate<F>where
F: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more