#[repr(C)]pub struct ShaExtendCols<T> {Show 27 fields
pub shard: T,
pub clk: T,
pub w_ptr: T,
pub i: T,
pub cycle_16: T,
pub cycle_16_start: IsZeroOperation<T>,
pub cycle_16_end: IsZeroOperation<T>,
pub cycle_48: [T; 3],
pub cycle_48_start: T,
pub cycle_48_end: T,
pub w_i_minus_15: MemoryReadCols<T>,
pub w_i_minus_15_rr_7: FixedRotateRightOperation<T>,
pub w_i_minus_15_rr_18: FixedRotateRightOperation<T>,
pub w_i_minus_15_rs_3: FixedShiftRightOperation<T>,
pub s0_intermediate: XorOperation<T>,
pub s0: XorOperation<T>,
pub w_i_minus_2: MemoryReadCols<T>,
pub w_i_minus_2_rr_17: FixedRotateRightOperation<T>,
pub w_i_minus_2_rr_19: FixedRotateRightOperation<T>,
pub w_i_minus_2_rs_10: FixedShiftRightOperation<T>,
pub s1_intermediate: XorOperation<T>,
pub s1: XorOperation<T>,
pub w_i_minus_16: MemoryReadCols<T>,
pub w_i_minus_7: MemoryReadCols<T>,
pub s2: Add4Operation<T>,
pub w_i: MemoryWriteCols<T>,
pub is_real: T,
}Fields§
§shard: TInputs.
clk: T§w_ptr: T§i: TControl flags.
cycle_16: Tg^n where g is generator with order 16 and n is the row number.
cycle_16_start: IsZeroOperation<T>Checks whether current row is start of a 16-row cycle. Bool result is stored in result.
cycle_16_end: IsZeroOperation<T>Checks whether current row is end of a 16-row cycle. Bool result is stored in result.
cycle_48: [T; 3]Flags for when in the first, second, or third 16-row cycle.
cycle_48_start: TWhether the current row is the first of a 48-row cycle and is real.
cycle_48_end: TWhether the current row is the end of a 48-row cycle and is real.
w_i_minus_15: MemoryReadCols<T>Inputs to s0.
w_i_minus_15_rr_7: FixedRotateRightOperation<T>§w_i_minus_15_rr_18: FixedRotateRightOperation<T>§w_i_minus_15_rs_3: FixedShiftRightOperation<T>§s0_intermediate: XorOperation<T>§s0: XorOperation<T>s0 := (w[i-15] rightrotate 7) xor (w[i-15] rightrotate 18) xor (w[i-15] rightshift 3).
w_i_minus_2: MemoryReadCols<T>Inputs to s1.
w_i_minus_2_rr_17: FixedRotateRightOperation<T>§w_i_minus_2_rr_19: FixedRotateRightOperation<T>§w_i_minus_2_rs_10: FixedShiftRightOperation<T>§s1_intermediate: XorOperation<T>§s1: XorOperation<T>s1 := (w[i-2] rightrotate 17) xor (w[i-2] rightrotate 19) xor (w[i-2] rightshift 10).
w_i_minus_16: MemoryReadCols<T>Inputs to s2.
w_i_minus_7: MemoryReadCols<T>§s2: Add4Operation<T>w[i] := w[i-16] + s0 + w[i-7] + s1.
w_i: MemoryWriteCols<T>Result.
is_real: TSelector.
Implementations§
Source§impl<F: Field> ShaExtendCols<F>
impl<F: Field> ShaExtendCols<F>
pub fn populate_flags(&mut self, i: usize)
Trait Implementations§
Source§impl<T> Borrow<ShaExtendCols<T>> for [T]
impl<T> Borrow<ShaExtendCols<T>> for [T]
Source§fn borrow(&self) -> &ShaExtendCols<T>
fn borrow(&self) -> &ShaExtendCols<T>
Immutably borrows from an owned value. Read more
Source§impl<T> BorrowMut<ShaExtendCols<T>> for [T]
impl<T> BorrowMut<ShaExtendCols<T>> for [T]
Source§fn borrow_mut(&mut self) -> &mut ShaExtendCols<T>
fn borrow_mut(&mut self) -> &mut ShaExtendCols<T>
Mutably borrows from an owned value. Read more
Source§impl<T: Clone> Clone for ShaExtendCols<T>
impl<T: Clone> Clone for ShaExtendCols<T>
Source§fn clone(&self) -> ShaExtendCols<T>
fn clone(&self) -> ShaExtendCols<T>
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<T: Debug> Debug for ShaExtendCols<T>
impl<T: Debug> Debug for ShaExtendCols<T>
Source§impl<T: Default> Default for ShaExtendCols<T>
impl<T: Default> Default for ShaExtendCols<T>
Source§fn default() -> ShaExtendCols<T>
fn default() -> ShaExtendCols<T>
Returns the “default value” for a type. Read more
impl<T: Copy> Copy for ShaExtendCols<T>
Auto Trait Implementations§
impl<T> Freeze for ShaExtendCols<T>where
T: Freeze,
impl<T> RefUnwindSafe for ShaExtendCols<T>where
T: RefUnwindSafe,
impl<T> Send for ShaExtendCols<T>where
T: Send,
impl<T> Sync for ShaExtendCols<T>where
T: Sync,
impl<T> Unpin for ShaExtendCols<T>where
T: Unpin,
impl<T> UnwindSafe for ShaExtendCols<T>where
T: 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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
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