OpenHypergraph

Struct OpenHypergraph 

Source
pub struct OpenHypergraph<K: ArrayKind, O, A> {
    pub s: FiniteFunction<K>,
    pub t: FiniteFunction<K>,
    pub h: Hypergraph<K, O, A>,
}
Expand description

Open Hypergraphs

§Invariants

We must have the following invariants:

These are checked by the OpenHypergraph::validate method

§Panics

Most operations assume the invariants hold, and will panic if not.

Fields§

§s: FiniteFunction<K>§t: FiniteFunction<K>§h: Hypergraph<K, O, A>

Implementations§

Source§

impl<K: ArrayKind, O, A> OpenHypergraph<K, O, A>
where K::Type<K::I>: NaturalArray<K>, K::Type<O>: Array<K, O>, K::Type<A>: Array<K, A>,

Source

pub fn new( s: FiniteFunction<K>, t: FiniteFunction<K>, h: Hypergraph<K, O, A>, ) -> Result<Self, InvalidOpenHypergraph<K>>

Source

pub fn validate(self) -> Result<Self, InvalidOpenHypergraph<K>>

Source

pub fn singleton( x: A, a: SemifiniteFunction<K, O>, b: SemifiniteFunction<K, O>, ) -> OpenHypergraph<K, O, A>

Source

pub fn tensor_operations( operations: Operations<K, O, A>, ) -> OpenHypergraph<K, O, A>

Source

pub fn source(&self) -> SemifiniteFunction<K, O>

Source

pub fn target(&self) -> SemifiniteFunction<K, O>

Source

pub fn identity(w: SemifiniteFunction<K, O>) -> OpenHypergraph<K, O, A>

Source

pub fn spider( s: FiniteFunction<K>, t: FiniteFunction<K>, w: SemifiniteFunction<K, O>, ) -> Option<Self>

Trait Implementations§

Source§

impl<K: ArrayKind, O, A> Arrow for OpenHypergraph<K, O, A>
where K::Type<K::I>: NaturalArray<K>, K::Type<O>: Array<K, O> + PartialEq, K::Type<A>: Array<K, A>,

Source§

type Object = SemifiniteFunction<K, O>

Source§

fn source(&self) -> Self::Object

Source§

fn target(&self) -> Self::Object

Source§

fn identity(w: Self::Object) -> Self

the identity morphism on a
Source§

fn compose(&self, other: &Self) -> Option<Self>

Compose morphisms in diagrammatic order: self ; other Read more
Source§

impl<K: ArrayKind, O, A> BitOr<&OpenHypergraph<K, O, A>> for &OpenHypergraph<K, O, A>
where K::Type<K::I>: NaturalArray<K>, K::Type<O>: Array<K, O> + PartialEq, K::Type<A>: Array<K, A>,

Source§

type Output = OpenHypergraph<K, O, A>

The resulting type after applying the | operator.
Source§

fn bitor(self, rhs: &OpenHypergraph<K, O, A>) -> OpenHypergraph<K, O, A>

Performs the | operation. Read more
Source§

impl<K: ArrayKind, O, A> Clone for OpenHypergraph<K, O, A>
where K::Type<O>: Clone, K::Type<A>: Clone, K::Type<K::I>: Clone,

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<K: ArrayKind, O: Debug, A: Debug> Debug for OpenHypergraph<K, O, A>
where K::Index: Debug, K::Type<K::I>: Debug, K::Type<O>: Debug, K::Type<A>: Debug,

Source§

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

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

impl<K: ArrayKind, O, A> Monoidal for OpenHypergraph<K, O, A>
where K::Type<K::I>: NaturalArray<K>, K::Type<O>: Array<K, O> + PartialEq, K::Type<A>: Array<K, A>,

Source§

fn unit() -> Self::Object

the monoidal unit object
Source§

fn tensor(&self, other: &Self) -> Self

f \otimes g of two morphisms
Source§

impl<K: ArrayKind, O, A> Shr<&OpenHypergraph<K, O, A>> for &OpenHypergraph<K, O, A>
where K::Type<K::I>: NaturalArray<K>, K::Type<O>: Array<K, O> + PartialEq, K::Type<A>: Array<K, A>,

Source§

type Output = Option<OpenHypergraph<K, O, A>>

The resulting type after applying the >> operator.
Source§

fn shr(self, rhs: &OpenHypergraph<K, O, A>) -> Option<OpenHypergraph<K, O, A>>

Performs the >> operation. Read more
Source§

impl<K: ArrayKind, O, A> Spider<K> for OpenHypergraph<K, O, A>
where K::Type<K::I>: NaturalArray<K>, K::Type<O>: Array<K, O> + PartialEq, K::Type<A>: Array<K, A>,

Source§

fn dagger(&self) -> Self

Given an Arrow with type f : A → B, construct its dagger f† : B → A by using Hypergraph structure to bend sources to targets and vice-versa.
Source§

fn spider( s: FiniteFunction<K>, t: FiniteFunction<K>, w: Self::Object, ) -> Option<Self>

Construct a spider using a type w, and source s and target t interface maps.
Source§

fn half_spider(s: FiniteFunction<K>, w: Self::Object) -> Option<Self>

Construct a “half-spider”: a spider whose t leg is identity.
Source§

impl<K: ArrayKind, O, A> SymmetricMonoidal for OpenHypergraph<K, O, A>
where K::Type<K::I>: NaturalArray<K>, K::Type<O>: Array<K, O> + PartialEq, K::Type<A>: Array<K, A>,

Source§

fn twist(a: Self::Object, b: Self::Object) -> Self

Construct the symmetry \sigma_{a,b} from a and b.

Auto Trait Implementations§

§

impl<K, O, A> Freeze for OpenHypergraph<K, O, A>
where <K as ArrayKind>::Index: Freeze, <K as ArrayKind>::I: Freeze, <K as ArrayKind>::Type<O>: Freeze, <K as ArrayKind>::Type<A>: Freeze,

§

impl<K, O, A> RefUnwindSafe for OpenHypergraph<K, O, A>

§

impl<K, O, A> Send for OpenHypergraph<K, O, A>
where <K as ArrayKind>::Index: Send, <K as ArrayKind>::I: Send, <K as ArrayKind>::Type<O>: Send, <K as ArrayKind>::Type<A>: Send,

§

impl<K, O, A> Sync for OpenHypergraph<K, O, A>
where <K as ArrayKind>::Index: Sync, <K as ArrayKind>::I: Sync, <K as ArrayKind>::Type<O>: Sync, <K as ArrayKind>::Type<A>: Sync,

§

impl<K, O, A> Unpin for OpenHypergraph<K, O, A>
where <K as ArrayKind>::Index: Unpin, <K as ArrayKind>::I: Unpin, <K as ArrayKind>::Type<O>: Unpin, <K as ArrayKind>::Type<A>: Unpin,

§

impl<K, O, A> UnwindSafe for OpenHypergraph<K, O, A>
where <K as ArrayKind>::Index: UnwindSafe, <K as ArrayKind>::I: UnwindSafe, <K as ArrayKind>::Type<O>: UnwindSafe, <K as ArrayKind>::Type<A>: 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> 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> 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.