calyx_opt::analysis

Struct ControlOrder

Source
pub struct ControlOrder<const BETTER_ERR: bool>;
Expand description

Extract the dependency order of a list of control programs. Dependencies are defined using read/write sets used in the control program. The read/write sets ignore ports on constants and ThisComponent.

For example, if we have control programs C1 and C2 with read sets R1 and R2 and write sets W1 and W2 respectively, we can define an order relationship:

C1 < C2 if (R1 subset of W2) and (R2 disjoint W1) C1 > C2 if (R2 subset of W1) and (R1 disjoint W2) C1 =!= if (R1 subset of W2) and (R2 subset of W1)

Setting BETTER_ERR turns on additional machinery to generate an explanation for what caused the error but may require expensive computations. Turn on when cycles should be a hard error.

Implementations§

Source§

impl<const BETTER_ERR: bool> ControlOrder<BETTER_ERR>

Source

pub fn get_total_order( stmts: impl Iterator<Item = Control>, ) -> CalyxResult<Vec<Control>>

Return a total order for the control programs. Returns an error if there is a cycle

Source

pub fn get_dependency_graph_seq( stmts: impl Iterator<Item = Control>, (cont_reads, cont_writes): (&Vec<RRC<Cell>>, &Vec<RRC<Cell>>), dependency: &mut HashMap<NodeIndex, Vec<NodeIndex>>, latency_map: &mut HashMap<NodeIndex, u64>, ) -> DiGraph<Option<Control>, ()>

Auto Trait Implementations§

§

impl<const BETTER_ERR: bool> Freeze for ControlOrder<BETTER_ERR>

§

impl<const BETTER_ERR: bool> RefUnwindSafe for ControlOrder<BETTER_ERR>

§

impl<const BETTER_ERR: bool> Send for ControlOrder<BETTER_ERR>

§

impl<const BETTER_ERR: bool> Sync for ControlOrder<BETTER_ERR>

§

impl<const BETTER_ERR: bool> Unpin for ControlOrder<BETTER_ERR>

§

impl<const BETTER_ERR: bool> UnwindSafe for ControlOrder<BETTER_ERR>

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