triton_isa::op_stack

Struct OpStack

Source
pub struct OpStack {
    pub stack: Vec<BFieldElement>,
    /* private fields */
}
Expand description

The operational stack of Triton VM. It always contains at least OpStackElement::COUNT elements. Initially, the bottom-most Digest::LEN elements equal the digest of the program being executed. The remaining elements are initially 0.

The OpStack is represented as one contiguous piece of memory, and Triton VM uses it as such. For reasons of arithmetization, however, there is a distinction between the op-stack registers and the op-stack underflow memory. The op-stack registers are the first OpStackElement::COUNT elements of the op-stack, and the op-stack underflow memory is the remaining elements.

Fields§

§stack: Vec<BFieldElement>

The underlying, actual stack. When manually accessing, be aware of reversed indexing: while op_stack[0] is the top of the stack, op_stack.stack[0] is the lowest element in the stack.

Implementations§

Source§

impl OpStack

Source

pub fn new(program_digest: Digest) -> Self

Source

pub fn len(&self) -> usize

Source

pub fn push(&mut self, element: BFieldElement)

Source

pub fn pop(&mut self) -> Result<BFieldElement, OpStackError>

Source

pub fn insert(&mut self, index: OpStackElement, element: BFieldElement)

Source

pub fn remove(&mut self, index: OpStackElement) -> BFieldElement

Source

pub fn start_recording_underflow_io_sequence(&mut self)

Source

pub fn stop_recording_underflow_io_sequence(&mut self) -> Vec<UnderflowIO>

Source

pub fn push_extension_field_element(&mut self, element: XFieldElement)

Source

pub fn pop_extension_field_element( &mut self, ) -> Result<XFieldElement, OpStackError>

Source

pub fn is_u32(&self, stack_element: OpStackElement) -> Result<(), OpStackError>

Source

pub fn get_u32( &self, stack_element: OpStackElement, ) -> Result<u32, OpStackError>

Source

pub fn pop_u32(&mut self) -> Result<u32, OpStackError>

Source

pub fn pop_multiple<const N: usize>( &mut self, ) -> Result<[BFieldElement; N], OpStackError>

Source

pub fn peek_at_top_extension_field_element(&self) -> XFieldElement

Source

pub fn would_be_too_shallow(&self, stack_delta: i32) -> bool

Source

pub fn pointer(&self) -> BFieldElement

The address of the next free address of the op-stack. Equivalent to the current length of the op-stack.

Trait Implementations§

Source§

impl<'arbitrary> Arbitrary<'arbitrary> for OpStack

Source§

fn arbitrary(u: &mut Unstructured<'arbitrary>) -> Result<Self>

Generate an arbitrary value of Self from the given unstructured data. Read more
Source§

fn arbitrary_take_rest(u: Unstructured<'arbitrary>) -> Result<Self>

Generate an arbitrary value of Self from the entirety of the given unstructured data. Read more
Source§

fn size_hint(depth: usize) -> (usize, Option<usize>)

Get a size hint for how many bytes out of an Unstructured this type needs to construct itself. Read more
Source§

fn try_size_hint( depth: usize, ) -> Result<(usize, Option<usize>), MaxRecursionReached>

Get a size hint for how many bytes out of an Unstructured this type needs to construct itself. Read more
Source§

impl Clone for OpStack

Source§

fn clone(&self) -> OpStack

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for OpStack

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for OpStack

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Index<OpStackElement> for OpStack

Source§

type Output = BFieldElement

The returned type after indexing.
Source§

fn index(&self, stack_element: OpStackElement) -> &Self::Output

Performs the indexing (container[index]) operation. Read more
Source§

impl Index<usize> for OpStack

Source§

type Output = BFieldElement

The returned type after indexing.
Source§

fn index(&self, index: usize) -> &Self::Output

Performs the indexing (container[index]) operation. Read more
Source§

impl IndexMut<OpStackElement> for OpStack

Source§

fn index_mut(&mut self, stack_element: OpStackElement) -> &mut Self::Output

Performs the mutable indexing (container[index]) operation. Read more
Source§

impl IndexMut<usize> for OpStack

Source§

fn index_mut(&mut self, index: usize) -> &mut Self::Output

Performs the mutable indexing (container[index]) operation. Read more
Source§

impl IntoIterator for OpStack

Source§

type Item = BFieldElement

The type of the elements being iterated over.
Source§

type IntoIter = IntoIter<<OpStack as IntoIterator>::Item>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
Source§

impl PartialEq for OpStack

Source§

fn eq(&self, other: &OpStack) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for OpStack

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for OpStack

Source§

impl StructuralPartialEq for OpStack

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,