pub struct HornerEvaluation {
pub num_coefficients: usize,
}
Expand description
Evaluate a polynomial in a point using the Horner method.
HornerEvaluation
takes an array of coefficients (representing a
polynomial) and a scalar (representing an indeterminate) and computes the
value of the polynomial in that point. It can be used for univariate
batching, whereby the object is to compute a random linear sum of a given
set of points, and the weights are given by the powers of one challenge.
§Behavior
BEFORE: _ *coefficients [indeterminate: XFieldElement]
AFTER: _ [evaluation: XFieldElement]
§Preconditions
None.
§Postconditions
None.
Fields§
§num_coefficients: usize
Implementations§
Trait Implementations§
Source§impl BasicSnippet for HornerEvaluation
impl BasicSnippet for HornerEvaluation
fn inputs(&self) -> Vec<(DataType, String)>
fn outputs(&self) -> Vec<(DataType, String)>
fn entrypoint(&self) -> String
fn code(&self, _: &mut Library) -> Vec<LabelledInstruction>
Source§fn sign_offs(&self) -> HashMap<Reviewer, SignOffFingerprint>
fn sign_offs(&self) -> HashMap<Reviewer, SignOffFingerprint>
Contains an entry for every sign off. Read more
fn annotated_code(&self, library: &mut Library) -> Vec<LabelledInstruction>
fn link_for_isolated_run(&self) -> Vec<LabelledInstruction>
Source§fn init_stack_for_isolated_run(&self) -> Vec<BFieldElement>
fn init_stack_for_isolated_run(&self) -> Vec<BFieldElement>
Initial stack on program start, when the snippet runs in isolation.
fn stack_diff(&self) -> isize
Source§impl Clone for HornerEvaluation
impl Clone for HornerEvaluation
Source§fn clone(&self) -> HornerEvaluation
fn clone(&self) -> HornerEvaluation
Returns a copy 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 Debug for HornerEvaluation
impl Debug for HornerEvaluation
Source§impl Hash for HornerEvaluation
impl Hash for HornerEvaluation
Source§impl PartialEq for HornerEvaluation
impl PartialEq for HornerEvaluation
impl Copy for HornerEvaluation
impl Eq for HornerEvaluation
impl StructuralPartialEq for HornerEvaluation
Auto Trait Implementations§
impl Freeze for HornerEvaluation
impl RefUnwindSafe for HornerEvaluation
impl Send for HornerEvaluation
impl Sync for HornerEvaluation
impl Unpin for HornerEvaluation
impl UnwindSafe for HornerEvaluation
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> SignedOffSnippet for Twhere
T: BasicSnippet + ?Sized,
impl<T> SignedOffSnippet for Twhere
T: BasicSnippet + ?Sized,
Source§fn fingerprint(&self) -> SignOffFingerprint
fn fingerprint(&self) -> SignOffFingerprint
The unique fingerprint as used for signing off on
this snippet.
Source§fn assert_all_sign_offs_are_up_to_date(&self)
fn assert_all_sign_offs_are_up_to_date(&self)
Panics if any sign-offs disagree with the actual
fingerprint.