pub struct ConvexChecker<'g, Base: HugrView, Checker> { /* private fields */ }
Expand description
Precompute convexity information for a HUGR.
This can be used when constructing multiple sibling subgraphs to speed up convexity checking.
This type is generic over the convexity checker used. If checking convexity
for circuit-like graphs, use LineConvexChecker
, otherwise use
TopoConvexChecker
.
Implementations§
Source§impl<'g, Base: HugrView, Checker> ConvexChecker<'g, Base, Checker>
impl<'g, Base: HugrView, Checker> ConvexChecker<'g, Base, Checker>
Source§impl<'g, Base: HugrView> ConvexChecker<'g, Base, LineConvexChecker<FlatRegion<'g, <Base as HugrInternals>::RegionPortgraph<'g>>>>
impl<'g, Base: HugrView> ConvexChecker<'g, Base, LineConvexChecker<FlatRegion<'g, <Base as HugrInternals>::RegionPortgraph<'g>>>>
Sourcepub fn get_intervals_from_nodes(
&self,
nodes: impl IntoIterator<Item = Base::Node>,
) -> Option<LineIntervals>
pub fn get_intervals_from_nodes( &self, nodes: impl IntoIterator<Item = Base::Node>, ) -> Option<LineIntervals>
Return the line intervals occupied by the given nodes in the region.
Sourcepub fn get_intervals_from_boundary_ports(
&self,
ports: impl IntoIterator<Item = (Base::Node, Port)>,
) -> Option<LineIntervals>
pub fn get_intervals_from_boundary_ports( &self, ports: impl IntoIterator<Item = (Base::Node, Port)>, ) -> Option<LineIntervals>
Return the line intervals defined by the given boundary ports in the region.
Incoming ports correspond to boundary inputs, outgoing ports correspond to boundary outputs.
Sourcepub fn nodes_in_intervals<'a>(
&'a self,
intervals: &'a LineIntervals,
) -> impl Iterator<Item = Base::Node> + 'a
pub fn nodes_in_intervals<'a>( &'a self, intervals: &'a LineIntervals, ) -> impl Iterator<Item = Base::Node> + 'a
Return the nodes that are within the given line intervals.
Sourcepub fn lines_at_port(
&self,
node: Base::Node,
port: impl Into<Port>,
) -> &[LineIndex]
pub fn lines_at_port( &self, node: Base::Node, port: impl Into<Port>, ) -> &[LineIndex]
Get the lines passing through the given port.
Sourcepub fn try_extend_intervals(
&self,
intervals: &mut LineIntervals,
node: Base::Node,
) -> bool
pub fn try_extend_intervals( &self, intervals: &mut LineIntervals, node: Base::Node, ) -> bool
Extend the given intervals to include the given node.
Return whether the interval was successfully extended to contain node
,
i.e. whether adding node
to the subgraph represented by the intervals
results in another subgraph that can be expressed as line intervals.
If false
is returned, the intervals
are left unchanged.
Sourcepub fn get_position(&self, node: Base::Node) -> Position
pub fn get_position(&self, node: Base::Node) -> Position
Get the position of a node on its lines.
Trait Implementations§
Source§impl<'g, Base, Checker> ConvexChecker for ConvexChecker<'g, Base, Checker>where
Base: HugrView,
Checker: CreateConvexChecker<FlatRegion<'g, <Base as HugrInternals>::RegionPortgraph<'g>>>,
impl<'g, Base, Checker> ConvexChecker for ConvexChecker<'g, Base, Checker>where
Base: HugrView,
Checker: CreateConvexChecker<FlatRegion<'g, <Base as HugrInternals>::RegionPortgraph<'g>>>,
Source§fn is_convex(
&self,
nodes: impl IntoIterator<Item = NodeIndex>,
inputs: impl IntoIterator<Item = PortIndex>,
outputs: impl IntoIterator<Item = PortIndex>,
) -> bool
fn is_convex( &self, nodes: impl IntoIterator<Item = NodeIndex>, inputs: impl IntoIterator<Item = PortIndex>, outputs: impl IntoIterator<Item = PortIndex>, ) -> bool
true
if the subgraph is convex. Read moreSource§impl<'a, 'c, G: HugrView, Checker: Clone> From<&'a ConvexChecker<'c, G, Checker>> for Cow<'a, ConvexChecker<'c, G, Checker>>
impl<'a, 'c, G: HugrView, Checker: Clone> From<&'a ConvexChecker<'c, G, Checker>> for Cow<'a, ConvexChecker<'c, G, Checker>>
Source§fn from(value: &'a ConvexChecker<'c, G, Checker>) -> Self
fn from(value: &'a ConvexChecker<'c, G, Checker>) -> Self
Auto Trait Implementations§
impl<'g, Base, Checker> !Freeze for ConvexChecker<'g, Base, Checker>
impl<'g, Base, Checker> !RefUnwindSafe for ConvexChecker<'g, Base, Checker>
impl<'g, Base, Checker> Send for ConvexChecker<'g, Base, Checker>where
<Base as HugrInternals>::Node: Send,
Base: Sync,
Checker: Send,
<Base as HugrInternals>::RegionPortgraphNodes: Send,
impl<'g, Base, Checker> !Sync for ConvexChecker<'g, Base, Checker>
impl<'g, Base, Checker> Unpin for ConvexChecker<'g, Base, Checker>where
<Base as HugrInternals>::Node: Unpin,
Checker: Unpin,
<Base as HugrInternals>::RegionPortgraphNodes: Unpin,
impl<'g, Base, Checker> UnwindSafe for ConvexChecker<'g, Base, Checker>where
<Base as HugrInternals>::Node: UnwindSafe,
Base: RefUnwindSafe,
Checker: UnwindSafe,
<Base as HugrInternals>::RegionPortgraphNodes: 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
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>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
, which can then be
downcast
into Box<dyn 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>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
, which 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)
&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)
&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> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.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> ⓘ
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> ⓘ
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 moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
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
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
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
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.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
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.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
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.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
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.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
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.