spectre::blocks

Struct NportIoView

Source
pub struct NportIoView<SubstrateV>
where Array<TwoTerminalIo>: HasView<SubstrateV>,
{ pub ports: <Array<TwoTerminalIo> as HasView<SubstrateV>>::View, }
Expand description

The interface of an Nport.

Fields§

§ports: <Array<TwoTerminalIo> as HasView<SubstrateV>>::View

The ports.

Each port contains two signals: a p terminal and an n terminal.

Implementations§

Source§

impl NportIoView<NodeBundle>
where Array<TwoTerminalIo>: HasSchematicBundleKindViews, Self: HasBundleKind<BundleKind: SchematicBundleKind<NodeBundle = Self>>,

Source

pub fn view_as<SubstrateT: HasBundleKind<BundleKind: SchematicBundleKind>>( &self, ) -> NodeBundle<<SubstrateT as HasBundleKind>::BundleKind>
where <Self as HasBundleKind>::BundleKind: DataView<<SubstrateT as HasBundleKind>::BundleKind>,

Views this bundle as a bundle of a different kind.

Source§

impl NportIoView<TerminalBundle>
where Array<TwoTerminalIo>: HasSchematicBundleKindViews, Self: HasBundleKind<BundleKind: SchematicBundleKind<TerminalBundle = Self>>,

Source

pub fn view_as<SubstrateT: HasBundleKind<BundleKind: SchematicBundleKind>>( &self, ) -> TerminalBundle<<SubstrateT as HasBundleKind>::BundleKind>
where <Self as HasBundleKind>::BundleKind: DataView<<SubstrateT as HasBundleKind>::BundleKind>,

Views this bundle as a bundle of a different kind.

Source

pub fn node_bundle(&self) -> NodeBundle<<Self as HasBundleKind>::BundleKind>

Views this terminal bundle as a node bundle of the same kind.

Trait Implementations§

Source§

impl<SubstrateV> FlatLen for NportIoView<SubstrateV>
where Array<TwoTerminalIo>: HasView<SubstrateV>, <Array<TwoTerminalIo> as HasView<SubstrateV>>::View: FlatLen,

Source§

fn len(&self) -> usize

The length of the flattened list.
Source§

fn is_empty(&self) -> bool

Whether or not the flattened representation is empty.
Source§

impl<SubstrateV, SubstrateF> Flatten<SubstrateF> for NportIoView<SubstrateV>
where Array<TwoTerminalIo>: HasView<SubstrateV>, <Array<TwoTerminalIo> as HasView<SubstrateV>>::View: Flatten<SubstrateF>,

Source§

fn flatten<E>(&self, __substrate_output_sink: &mut E)
where E: Extend<SubstrateF>,

Flatten a structure into a list.
Source§

fn flatten_vec(&self) -> Vec<T>

Flatten into a Vec.
Source§

impl<SubstrateV> HasBundleKind for NportIoView<SubstrateV>
where Array<TwoTerminalIo>: HasView<SubstrateV> + HasBundleKind, <Array<TwoTerminalIo> as HasView<SubstrateV>>::View: HasBundleKind<BundleKind = <Array<TwoTerminalIo> as HasBundleKind>::BundleKind> + HasBundleKind,

Source§

type BundleKind = NportIoKind

The Rust type of the BundleKind associated with this bundle.
Source§

fn kind(&self) -> <Self as HasBundleKind>::BundleKind

Returns the BundleKind of this bundle.
Source§

impl HasNestedView for NportIoView<NestedNodeBundle>
where Array<TwoTerminalIo>: HasSchematicBundleKindViews, <Array<TwoTerminalIo> as HasView<NestedNodeBundle>>::View: HasNestedView<NestedView = <Array<TwoTerminalIo> as HasView<NestedNodeBundle>>::View> + HasNestedView,

Source§

type NestedView = NportIoView<NestedNodeBundle>

A view of the nested object. Read more
Source§

fn nested_view(&self, __substrate_parent: &InstancePath) -> NestedView<Self>

Creates a nested view of the object given a parent node.
Source§

impl HasNestedView for NportIoView<NestedTerminalBundle>
where Array<TwoTerminalIo>: HasSchematicBundleKindViews, <Array<TwoTerminalIo> as HasView<NestedTerminalBundle>>::View: HasNestedView<NestedView = <Array<TwoTerminalIo> as HasView<NestedTerminalBundle>>::View> + HasNestedView,

Source§

type NestedView = NportIoView<NestedTerminalBundle>

A view of the nested object. Read more
Source§

fn nested_view(&self, __substrate_parent: &InstancePath) -> NestedView<Self>

Creates a nested view of the object given a parent node.
Source§

impl HasNestedView for NportIoView<NodeBundle>
where Array<TwoTerminalIo>: HasSchematicBundleKindViews, <Array<TwoTerminalIo> as HasView<NodeBundle>>::View: HasNestedView,

Source§

type NestedView = NportIoView<NestedNodeBundle>

A view of the nested object. Read more
Source§

fn nested_view(&self, __substrate_parent: &InstancePath) -> NestedView<Self>

Creates a nested view of the object given a parent node.
Source§

impl HasNestedView for NportIoView<TerminalBundle>
where Array<TwoTerminalIo>: HasSchematicBundleKindViews, <Array<TwoTerminalIo> as HasView<TerminalBundle>>::View: HasNestedView,

Source§

type NestedView = NportIoView<NestedTerminalBundle>

A view of the nested object. Read more
Source§

fn nested_view(&self, __substrate_parent: &InstancePath) -> NestedView<Self>

Creates a nested view of the object given a parent node.
Source§

impl<SubstrateS, SubstrateA> Save<SubstrateS, SubstrateA> for NportIoView<NestedNodeBundle>
where Array<TwoTerminalIo>: HasView<NestedNodeBundle>, <Array<TwoTerminalIo> as HasView<NestedNodeBundle>>::View: Save<SubstrateS, SubstrateA>, SubstrateS: Simulator, SubstrateA: Analysis,

Source§

type SaveKey = NportIoView<NestedNodeSaveKeyView<SubstrateS, SubstrateA>>

The key type used to address the saved output within the analysis. Read more
Source§

type Saved = NportIoView<NestedNodeSavedView<SubstrateS, SubstrateA>>

The saved data associated with things object.
Source§

fn save( &self, __substrate_ctx: &SimulationContext<SubstrateS>, __substrate_opts: &mut <SubstrateS as Simulator>::Options, ) -> <Self as Save<SubstrateS, SubstrateA>>::SaveKey

Marks the given output for saving, returning a key that can be used to recover the output once the simulation is complete.
Source§

fn from_saved( __substrate_output: &<SubstrateA as Analysis>::Output, __substrate_key: &<Self as Save<SubstrateS, SubstrateA>>::SaveKey, ) -> <Self as Save<SubstrateS, SubstrateA>>::Saved

Recovers the desired simulation output from the analysis’s output.
Source§

impl<SubstrateS, SubstrateA> Save<SubstrateS, SubstrateA> for NportIoView<NestedTerminalBundle>
where Array<TwoTerminalIo>: HasView<NestedTerminalBundle>, <Array<TwoTerminalIo> as HasView<NestedTerminalBundle>>::View: Save<SubstrateS, SubstrateA>, SubstrateS: Simulator, SubstrateA: Analysis,

Source§

type SaveKey = NportIoView<NestedTerminalSaveKeyView<SubstrateS, SubstrateA>>

The key type used to address the saved output within the analysis. Read more
Source§

type Saved = NportIoView<NestedTerminalSavedView<SubstrateS, SubstrateA>>

The saved data associated with things object.
Source§

fn save( &self, __substrate_ctx: &SimulationContext<SubstrateS>, __substrate_opts: &mut <SubstrateS as Simulator>::Options, ) -> <Self as Save<SubstrateS, SubstrateA>>::SaveKey

Marks the given output for saving, returning a key that can be used to recover the output once the simulation is complete.
Source§

fn from_saved( __substrate_output: &<SubstrateA as Analysis>::Output, __substrate_key: &<Self as Save<SubstrateS, SubstrateA>>::SaveKey, ) -> <Self as Save<SubstrateS, SubstrateA>>::Saved

Recovers the desired simulation output from the analysis’s output.
Source§

impl<SubstrateV> TransformRef for NportIoView<SubstrateV>
where Array<TwoTerminalIo>: HasView<SubstrateV>, <Array<TwoTerminalIo> as HasView<SubstrateV>>::View: TransformRef,

Source§

fn transform_ref(&self, __substrate_transformation: Transformation) -> Self

Applies matrix-vector Transformation trans.
Source§

impl<SubstrateV> TranslateRef for NportIoView<SubstrateV>
where Array<TwoTerminalIo>: HasView<SubstrateV>, <Array<TwoTerminalIo> as HasView<SubstrateV>>::View: TranslateRef,

Source§

fn translate_ref(&self, __substrate_point: Point) -> Self

Translates the shape by Point, returning a new shape.
Source§

impl<SubstrateV, SubstrateS> Unflatten<NportIoKind, SubstrateS> for NportIoView<SubstrateV>
where Array<TwoTerminalIo>: HasView<SubstrateV> + HasBundleKind, <Array<TwoTerminalIo> as HasView<SubstrateV>>::View: Unflatten<<Array<TwoTerminalIo> as HasBundleKind>::BundleKind, SubstrateS>,

Source§

fn unflatten<SubstrateI>( __substrate_data: &NportIoKind, __substrate_source: &mut SubstrateI, ) -> Option<Self>
where SubstrateI: Iterator<Item = SubstrateS>,

Unflatten a structure from an iterator. Read more

Auto Trait Implementations§

§

impl<SubstrateV> !Freeze for NportIoView<SubstrateV>

§

impl<SubstrateV> !RefUnwindSafe for NportIoView<SubstrateV>

§

impl<SubstrateV> !Send for NportIoView<SubstrateV>

§

impl<SubstrateV> !Sync for NportIoView<SubstrateV>

§

impl<SubstrateV> !Unpin for NportIoView<SubstrateV>

§

impl<SubstrateV> !UnwindSafe for NportIoView<SubstrateV>

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
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Converts Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Converts &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Converts &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSend for T
where T: Any + Send,

§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Sync + Send>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<T> Directed for T
where T: Flatten<Direction>,

Source§

impl<T> LayoutData for T
where T: TransformRef + Send + Sync,

Source§

impl<T> NestedData for T
where T: HasNestedView + Send + Sync,

Source§

impl<T> Primitive for T