pub enum SymbolicExpression<F> {
Variable(SymbolicVariable<F>),
IsFirstRow,
IsLastRow,
IsTransition,
Constant(F),
Add {
x: Rc<Self>,
y: Rc<Self>,
degree_multiple: usize,
},
Sub {
x: Rc<Self>,
y: Rc<Self>,
degree_multiple: usize,
},
Neg {
x: Rc<Self>,
degree_multiple: usize,
},
Mul {
x: Rc<Self>,
y: Rc<Self>,
degree_multiple: usize,
},
}
Expand description
An expression over SymbolicVariable
s.
Variants§
Implementations§
Source§impl<F> SymbolicExpression<F>
impl<F> SymbolicExpression<F>
Sourcepub const fn degree_multiple(&self) -> usize
pub const fn degree_multiple(&self) -> usize
Returns the multiple of n
(the trace length) in this expression’s degree.
Trait Implementations§
Source§impl<F: Field, T> AddAssign<T> for SymbolicExpression<F>where
T: Into<Self>,
impl<F: Field, T> AddAssign<T> for SymbolicExpression<F>where
T: Into<Self>,
Source§fn add_assign(&mut self, rhs: T)
fn add_assign(&mut self, rhs: T)
Performs the
+=
operation. Read moreSource§impl<F: Clone> Clone for SymbolicExpression<F>
impl<F: Clone> Clone for SymbolicExpression<F>
Source§fn clone(&self) -> SymbolicExpression<F>
fn clone(&self) -> SymbolicExpression<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: Debug> Debug for SymbolicExpression<F>
impl<F: Debug> Debug for SymbolicExpression<F>
Source§impl<F: Field> Default for SymbolicExpression<F>
impl<F: Field> Default for SymbolicExpression<F>
Source§impl<F: Field> From<F> for SymbolicExpression<F>
impl<F: Field> From<F> for SymbolicExpression<F>
Source§impl<F: Field> From<SymbolicVariable<F>> for SymbolicExpression<F>
impl<F: Field> From<SymbolicVariable<F>> for SymbolicExpression<F>
Source§fn from(value: SymbolicVariable<F>) -> Self
fn from(value: SymbolicVariable<F>) -> Self
Converts to this type from the input type.
Source§impl<F: Field + InjectiveMonomial<N>, const N: u64> InjectiveMonomial<N> for SymbolicExpression<F>
impl<F: Field + InjectiveMonomial<N>, const N: u64> InjectiveMonomial<N> for SymbolicExpression<F>
Source§fn injective_exp_n(&self) -> Self
fn injective_exp_n(&self) -> Self
Compute
x -> x^n
for a given n > 1
such that this
map is injective.Source§impl<F: Field, T> MulAssign<T> for SymbolicExpression<F>where
T: Into<Self>,
impl<F: Field, T> MulAssign<T> for SymbolicExpression<F>where
T: Into<Self>,
Source§fn mul_assign(&mut self, rhs: T)
fn mul_assign(&mut self, rhs: T)
Performs the
*=
operation. Read moreSource§impl<F: Field> Neg for SymbolicExpression<F>
impl<F: Field> Neg for SymbolicExpression<F>
Source§impl<F: Field> PrimeCharacteristicRing for SymbolicExpression<F>
impl<F: Field> PrimeCharacteristicRing for SymbolicExpression<F>
Source§type PrimeSubfield = <F as PrimeCharacteristicRing>::PrimeSubfield
type PrimeSubfield = <F as PrimeCharacteristicRing>::PrimeSubfield
The field
ℤ/p
where the characteristic of this ring is p.Source§fn from_prime_subfield(f: Self::PrimeSubfield) -> Self
fn from_prime_subfield(f: Self::PrimeSubfield) -> Self
Source§fn from_usize(int: usize) -> Self
fn from_usize(int: usize) -> Self
Source§fn from_isize(int: isize) -> Self
fn from_isize(int: isize) -> Self
Source§fn xor(&self, y: &Self) -> Self
fn xor(&self, y: &Self) -> Self
Computes the arithmetic generalization of boolean
xor
. Read moreSource§fn xor3(&self, y: &Self, z: &Self) -> Self
fn xor3(&self, y: &Self, z: &Self) -> Self
Computes the arithmetic generalization of a triple
xor
. Read moreSource§fn bool_check(&self) -> Self
fn bool_check(&self) -> Self
The vanishing polynomial for boolean values:
x * (1 - x)
. Read moreSource§fn exp_const_u64<const POWER: u64>(&self) -> Self
fn exp_const_u64<const POWER: u64>(&self) -> Self
Exponentiation by a small constant power. Read more
Source§fn exp_power_of_2(&self, power_log: usize) -> Self
fn exp_power_of_2(&self, power_log: usize) -> Self
The elementary function
exp_power_of_2(a, power_log) = a^{2^power_log}
. Read moreSource§fn mul_2exp_u64(&self, exp: u64) -> Self
fn mul_2exp_u64(&self, exp: u64) -> Self
The elementary function
mul_2exp_u64(a, exp) = a * 2^{exp}
. Read moreSource§fn powers(&self) -> Powers<Self>
fn powers(&self) -> Powers<Self>
Construct an iterator which returns powers of
self
: self^0, self^1, self^2, ...
.Source§fn shifted_powers(&self, start: Self) -> Powers<Self>
fn shifted_powers(&self, start: Self) -> Powers<Self>
Construct an iterator which returns powers of
self
shifted by start
: start, start*self^1, start*self^2, ...
.Source§fn dot_product<const N: usize>(u: &[Self; N], v: &[Self; N]) -> Self
fn dot_product<const N: usize>(u: &[Self; N], v: &[Self; N]) -> Self
Compute the dot product of two vectors.
Source§fn sum_array<const N: usize>(input: &[Self]) -> Self
fn sum_array<const N: usize>(input: &[Self]) -> Self
Compute the sum of a slice of elements whose length is a compile time constant. Read more
Source§fn zero_vec(len: usize) -> Vec<Self>
fn zero_vec(len: usize) -> Vec<Self>
Allocates a vector of zero elements of length
len
. Many operating systems zero pages
before assigning them to a userspace process. In that case, our process should not need to
write zeros, which would be redundant. However, the compiler may not always recognize this. Read moreSource§impl<F: Field, T> SubAssign<T> for SymbolicExpression<F>where
T: Into<Self>,
impl<F: Field, T> SubAssign<T> for SymbolicExpression<F>where
T: Into<Self>,
Source§fn sub_assign(&mut self, rhs: T)
fn sub_assign(&mut self, rhs: T)
Performs the
-=
operation. Read moreimpl<F: Field> Algebra<F> for SymbolicExpression<F>
impl<F: Field> Algebra<SymbolicVariable<F>> for SymbolicExpression<F>
Auto Trait Implementations§
impl<F> Freeze for SymbolicExpression<F>where
F: Freeze,
impl<F> RefUnwindSafe for SymbolicExpression<F>where
F: RefUnwindSafe,
impl<F> !Send for SymbolicExpression<F>
impl<F> !Sync for SymbolicExpression<F>
impl<F> Unpin for SymbolicExpression<F>where
F: Unpin,
impl<F> UnwindSafe for SymbolicExpression<F>where
F: UnwindSafe + RefUnwindSafe,
Blanket Implementations§
Source§impl<F> BasedVectorSpace<F> for Fwhere
F: PrimeCharacteristicRing,
impl<F> BasedVectorSpace<F> for Fwhere
F: PrimeCharacteristicRing,
Source§const DIMENSION: usize = 1usize
const DIMENSION: usize = 1usize
The dimension of the vector space, i.e. the number of elements in
its basis.
Source§fn as_basis_coefficients_slice(&self) -> &[F]
fn as_basis_coefficients_slice(&self) -> &[F]
Fixes a basis for the algebra
A
and uses this to
map an element of A
to a slice of DIMENSION
F
elements. Read moreSource§fn from_basis_coefficients_fn<Fn>(f: Fn) -> F
fn from_basis_coefficients_fn<Fn>(f: Fn) -> F
Fixes a basis for the algebra
A
and uses this to
map DIMENSION
F
elements to an element of A
. Similar
to core:array::from_fn
, the DIMENSION
F
elements are
given by Fn(0), ..., Fn(DIMENSION - 1)
called in that order. Read moreSource§fn from_basis_coefficients_iter<I>(iter: I) -> Option<F>where
I: ExactSizeIterator<Item = F>,
fn from_basis_coefficients_iter<I>(iter: I) -> Option<F>where
I: ExactSizeIterator<Item = F>,
Fixes a basis for the algebra
A
and uses this to
map DIMENSION
F
elements to an element of A
. Read moreSource§fn flatten_to_base(vec: Vec<F>) -> Vec<F>
fn flatten_to_base(vec: Vec<F>) -> Vec<F>
Source§fn reconstitute_from_base(vec: Vec<F>) -> Vec<F>
fn reconstitute_from_base(vec: Vec<F>) -> Vec<F>
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<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 more