Struct miden_processor::ExecutionTrace

source ·
pub struct ExecutionTrace { /* private fields */ }
Expand description

Execution trace which is generated when a program is executed on the VM.

The trace consists of the following components:

  • Main traces of System, Decoder, Operand Stack, Range Checker, and Auxiliary Co-Processor components.
  • Hints used during auxiliary trace segment construction.
  • Metadata needed by the STARK prover.

Implementations§

source§

impl ExecutionTrace

source

pub const NUM_RAND_ROWS: usize = 1usize

Number of rows at the end of an execution trace which are injected with random values.

source

pub fn program_info(&self) -> &ProgramInfo

Returns the program info of this execution trace.

source

pub fn program_hash(&self) -> &Digest

Returns hash of the program execution of which resulted in this execution trace.

source

pub fn stack_outputs(&self) -> &StackOutputs

Returns outputs of the program execution which resulted in this execution trace.

source

pub fn init_stack_state(&self) -> StackTopState

Returns the initial state of the top 16 stack registers.

source

pub fn last_stack_state(&self) -> StackTopState

Returns the final state of the top 16 stack registers.

source

pub fn get_user_op_helpers_at(&self, clk: u32) -> [Felt; 6]

Returns helper registers state at the specified clk of the VM

source

pub fn get_trace_len(&self) -> usize

source

pub fn trace_len_summary(&self) -> &TraceLenSummary

Returns a summary of the lengths of main, range and chiplet traces.

source

pub fn print(&self)

Trait Implementations§

source§

impl Trace for ExecutionTrace

§

type BaseField = BaseElement

Base field for this execution trace. Read more
source§

fn layout(&self) -> &TraceLayout

Returns a description of how columns of this trace are arranged into trace segments.
source§

fn length(&self) -> usize

Returns the number of rows in this trace.
source§

fn meta(&self) -> &[u8]

Returns metadata associated with this trace.
source§

fn main_segment(&self) -> &ColMatrix<Felt>

Returns a reference to a [Matrix] describing the main segment of this trace.
source§

fn build_aux_segment<E: FieldElement<BaseField = Felt>>( &mut self, aux_segments: &[ColMatrix<E>], rand_elements: &[E] ) -> Option<ColMatrix<E>>

Builds and returns the next auxiliary trace segment. If there are no more segments to build (i.e., the trace is complete), None is returned. Read more
source§

fn read_main_frame(&self, row_idx: usize, frame: &mut EvaluationFrame<Felt>)

Reads an evaluation frame from the main trace segment at the specified row.
source§

fn get_info(&self) -> TraceInfo

Returns trace info for this trace.
source§

fn main_trace_width(&self) -> usize

Returns the number of columns in the main segment of this trace.
source§

fn aux_trace_width(&self) -> usize

Returns the number of columns in all auxiliary trace segments.
source§

fn validate<A, E>( &self, air: &A, aux_segments: &[ColMatrix<E>], aux_rand_elements: &AuxTraceRandElements<E> )
where A: Air<BaseField = Self::BaseField>, E: FieldElement<BaseField = Self::BaseField>,

Checks if this trace is valid against the specified AIR, and panics if not. Read more

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> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Same for T

§

type Output = T

Should always be Self
source§

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

§

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>,

§

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> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more