Skip to main content

IRStmt

Struct IRStmt 

Source
pub struct IRStmt<T>(/* private fields */);
Expand description

IR for operations that occur in the main circuit.

Implementations§

Source§

impl<T> IRStmt<T>

Source

pub fn call( callee: impl AsRef<str>, inputs: impl IntoIterator<Item = T>, outputs: impl IntoIterator<Item = Slot>, ) -> Self

Creates a call to another module.

Source

pub fn post_cond(cond: IRBexpr<T>) -> Self

Creates a post condition formula.

Source

pub fn constraint(op: CmpOp, lhs: T, rhs: T) -> Self

Creates a constraint between two expressions.

Source

pub fn eq(lhs: T, rhs: T) -> Self

Creates a constraint with CmpOp::Eq between two expressions.

Source

pub fn lt(lhs: T, rhs: T) -> Self

Creates a constraint with CmpOp::Lt between two expressions.

Source

pub fn le(lhs: T, rhs: T) -> Self

Creates a constraint with CmpOp::Le between two expressions.

Source

pub fn gt(lhs: T, rhs: T) -> Self

Creates a constraint with CmpOp::Gt between two expressions.

Source

pub fn ge(lhs: T, rhs: T) -> Self

Creates a constraint with CmpOp::Ge between two expressions.

Source

pub fn comment(s: impl AsRef<str>) -> Self

Creates a text comment.

Source

pub fn assume_deterministic(f: impl Into<Slot>) -> Self

Indicates that the Slot must be assumed deterministic by the backend.

Source

pub fn assert(cond: IRBexpr<T>) -> Self

Creates an assertion in the circuit.

Source

pub fn seq<I>(stmts: impl IntoIterator<Item = IRStmt<I>>) -> Self
where I: Into<T>,

Creates a statement that is a sequence of other statements.

Source

pub fn empty() -> Self

Creates an empty statement.

Source

pub fn is_empty(&self) -> bool

Returns true if the statement is empty.

Source

pub fn with_comment(self, comment: String) -> Self

Prepends a comment to the statement.

Source

pub fn map<O>(self, f: &mut impl FnMut(T) -> O) -> IRStmt<O>

Transforms the inner expression type into another.

Source

pub fn with<O>(self, other: O) -> IRStmt<(O, T)>
where O: Clone,

Maps the statement’s inner type to a tuple with the passed value.

Source

pub fn with_fn<O>(self, other: impl Fn() -> O) -> IRStmt<(O, T)>

Maps the statement’s inner type to a tuple with the result of the closure.

Source

pub fn into<O>(self) -> IRStmt<O>
where O: From<T> + Evaluate<ExprProperties>,

Transforms the inner expression type using Into::into.

Source

pub fn from<O>(value: IRStmt<O>) -> Self
where O: Into<T>,

Transforms the inner expression type using From::from.

Source

pub fn then(self, other: impl Into<Self>) -> Self

Appends the given statement to the current one.

Source

pub fn map_into<O>(&self, f: &mut impl FnMut(&T) -> O) -> IRStmt<O>

Transforms the inner expression type into another, without moving.

Source

pub fn try_map<O, E>( self, f: &mut impl FnMut(T) -> Result<O, E>, ) -> Result<IRStmt<O>, E>

Tries to transform the inner expression type into another.

Source

pub fn map_inplace(&mut self, f: &mut impl FnMut(&mut T))

Modifies the inner expression type in place.

Source

pub fn try_map_inplace<E>( &mut self, f: &mut impl FnMut(&mut T) -> Result<(), E>, ) -> Result<(), E>

Tries to modify the inner expression type in place.

Source

pub fn map_slot_inplace(&mut self, f: &mut impl FnMut(&mut Slot))

Modifies the inner slots in place.

Source

pub fn try_map_slot_inplace<E>( &mut self, f: &mut impl FnMut(&mut Slot) -> Result<(), E>, ) -> Result<(), E>

Tries to modify the inner slots n place.

Source

pub fn iter(&self) -> IRStmtRefIter<'_, T>

Returns an iterator of references to the statements.

Source

pub fn iter_mut(&mut self) -> IRStmtRefMutIter<'_, T>

Returns an iterator of mutable references to the statements.

Source

pub fn propagate_meta(&mut self)

Propagates the metadata of this statement to the inner statements.

Trait Implementations§

Source§

impl Canonicalize for IRStmt<IRAexpr>

Source§

fn canonicalize(&mut self)

Matches the statements against a series of known patterns and applies rewrites if able to.

Source§

fn canonicalized(self) -> Self
where Self: Sized,

Transforms the object into its canonical version.
Source§

impl<T: Clone> Clone for IRStmt<T>

Source§

fn clone(&self) -> Self

Returns a duplicate 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<T> ConstantFolding for IRStmt<T>
where T: ConstantFolding + Debug + Clone, Error: From<T::Error>, T::T: Eq + Ord,

Source§

fn constant_fold(&mut self) -> Result<(), Error>

Folds the statements if the expressions are constant. If a assert-like statement folds into a tautology (i.e. (= 0 0 )) gets removed. If it folds into a unsatisfiable proposition the method returns an error.

Source§

type Error = Error

Error type.
Source§

type T = ()

Object’s type for constants.
Source§

fn constant_folded(self) -> Result<Self, Self::Error>
where Self: Sized,

Moves the object after folding it.
Source§

fn const_value(&self) -> Option<Self::T>

May return the object as a constant value.
Source§

impl<T: Debug> Debug for IRStmt<T>

Source§

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

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

impl<T> Default for IRStmt<T>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<L, R> EqvRelation<IRStmt<L>, IRStmt<R>> for SymbolicEqv

IRStmt transilitively inherits the SymbolicEqv equivalence relation.

Source§

fn equivalent(lhs: &IRStmt<L>, rhs: &IRStmt<R>) -> bool

Two statements are equivalent if they are structurally equal and their inner entities are equivalent.

Source§

impl<I> FromIterator<IRStmt<I>> for IRStmt<I>

Source§

fn from_iter<T: IntoIterator<Item = IRStmt<I>>>(iter: T) -> Self

Creates a value from an iterator. Read more
Source§

impl<T> HasMeta for IRStmt<T>

Source§

fn meta(&self) -> &Meta

Returns a reference to the metadata.
Source§

fn meta_mut(&mut self) -> &mut Meta

Returns a mutable reference to the metadata.
Source§

impl<T: IRPrintable> IRPrintable for IRStmt<T>

Source§

fn fmt(&self, ctx: &mut IRPrinterCtx<'_, '_>) -> Result

Format the IR object using the given context.
Source§

fn depth(&self) -> usize

Computes the depth of the IR tree to give hints to the printer.
Source§

impl<'a, T> IntoIterator for &'a IRStmt<T>

Source§

type Item = &'a IRStmt<T>

The type of the elements being iterated over.
Source§

type IntoIter = IRStmtRefIter<'a, T>

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<'a, T> IntoIterator for &'a mut IRStmt<T>

Source§

type Item = &'a mut IRStmt<T>

The type of the elements being iterated over.
Source§

type IntoIter = IRStmtRefMutIter<'a, T>

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<T> IntoIterator for IRStmt<T>

Source§

type Item = IRStmt<T>

The type of the elements being iterated over.
Source§

type IntoIter = IRStmtIter<T>

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<T: LowerableExpr> LowerableStmt for IRStmt<T>
where CondBlock<T>: LowerableStmt,

Source§

fn lower<L>(self, l: &L) -> Result<()>
where L: Lowering + ?Sized,

Emits a statement from the value.
Source§

impl<T: PartialEq> PartialEq for IRStmt<T>

Source§

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

Equality is defined by the sequence of statements regardless of how they are structured inside.

For example: Seq([a, Seq([b, c])]) == Seq([a, b, c]) a == Seq([a])

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<T, D> Validatable for IRStmt<T>
where IRConstBexpr<T>: Validatable<Diagnostic = D, Context = ()>, D: Diagnostic,

Source§

type Diagnostic = D

The type used to represent diagnostics.
Source§

type Context = ()

Context necessary for validating the IR.
Source§

fn validate_with_context( &self, _: &Self::Context, ) -> Result<Vec<Self::Diagnostic>, Vec<Self::Diagnostic>>

Performs validation checks, returning either Ok with a list of non-error diagnostics or Err with a list of all the diagnostics.
Source§

fn validate(&self) -> Result<Vec<Self::Diagnostic>, Vec<Self::Diagnostic>>
where Self::Context: Default,

Performs validation checks, returning either Ok with a list of non-error diagnostics or Err with a list of all the diagnostics.

Auto Trait Implementations§

§

impl<T> Freeze for IRStmt<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for IRStmt<T>
where T: RefUnwindSafe,

§

impl<T> Send for IRStmt<T>
where T: Send,

§

impl<T> Sync for IRStmt<T>
where T: Sync,

§

impl<T> Unpin for IRStmt<T>
where T: Unpin,

§

impl<T> UnwindSafe for IRStmt<T>
where T: UnwindSafe,

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, dest: *mut u8)

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

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T, I> EmitIf<T> for I
where I: IntoIterator<Item = IRStmt<T>>,

Source§

fn emit_if(self, cond: IRConstBexpr<T>) -> IRStmt<T>

Creates a conditional block.
Source§

fn emit_unless_false(self, cond: IRBexpr<T>) -> IRStmt<T>

Creates a conditional block that only gets folded if the boolean expression folds to false.
Source§

impl<T, O> EquivalentTo<O> for T

Source§

fn is_equiv<E>(&self, other: &O) -> bool
where E: EqvRelation<T, O>,

Returns true if self is equivalent to other.
Source§

impl<L, R, E> EqvRelation<&[L], &[R]> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &&[L], rhs: &&[R]) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, R, E> EqvRelation<&L, &R> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &&L, rhs: &&R) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, R, E> EqvRelation<&mut L, &mut R> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &&mut L, rhs: &&mut R) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, R, E, const N: usize> EqvRelation<[L; N], [R; N]> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &[L; N], rhs: &[R; N]) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, R, E> EqvRelation<Box<L>, Box<R>> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &Box<L>, rhs: &Box<R>) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<'l, 'r, L, R, E> EqvRelation<Cow<'l, L>, Cow<'r, R>> for E
where L: ToOwned, R: ToOwned, E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &Cow<'l, L>, rhs: &Cow<'r, R>) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, R, E> EqvRelation<Option<L>, Option<R>> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &Option<L>, rhs: &Option<R>) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, R, E> EqvRelation<Rc<L>, Rc<R>> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &Rc<L>, rhs: &Rc<R>) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, LErr, R, RErr, E> EqvRelation<Result<L, LErr>, Result<R, RErr>> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &Result<L, LErr>, rhs: &Result<R, RErr>) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<L, R, E> EqvRelation<Vec<L>, Vec<R>> for E
where E: EqvRelation<L, R>,

Source§

fn equivalent(lhs: &Vec<L>, rhs: &Vec<R>) -> bool

Returns true if L and R are equivalent under the implementation’s definition of equivalency.
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. 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> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
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> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. 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.