substrate::types

Struct MosIoView

Source
pub struct MosIoView<SubstrateV>
where InOut<Signal>: HasView<SubstrateV>, Input<Signal>: HasView<SubstrateV>,
{ pub d: <InOut<Signal> as HasView<SubstrateV>>::View, pub g: <Input<Signal> as HasView<SubstrateV>>::View, pub s: <InOut<Signal> as HasView<SubstrateV>>::View, pub b: <InOut<Signal> as HasView<SubstrateV>>::View, }
Expand description

The interface to a standard 4-terminal MOSFET.

Fields§

§d: <InOut<Signal> as HasView<SubstrateV>>::View

The drain.

§g: <Input<Signal> as HasView<SubstrateV>>::View

The gate.

§s: <InOut<Signal> as HasView<SubstrateV>>::View

The source.

§b: <InOut<Signal> as HasView<SubstrateV>>::View

The body.

Implementations§

Source§

impl MosIoView<NodeBundle>
where InOut<Signal>: HasSchematicBundleKindViews, Input<Signal>: 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 MosIoView<TerminalBundle>
where InOut<Signal>: HasSchematicBundleKindViews, Input<Signal>: 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 MosIoView<SubstrateV>
where InOut<Signal>: HasView<SubstrateV>, Input<Signal>: HasView<SubstrateV>, <InOut<Signal> as HasView<SubstrateV>>::View: FlatLen, <Input<Signal> 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 MosIoView<SubstrateV>
where InOut<Signal>: HasView<SubstrateV>, Input<Signal>: HasView<SubstrateV>, <InOut<Signal> as HasView<SubstrateV>>::View: Flatten<SubstrateF>, <Input<Signal> 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 MosIoView<SubstrateV>
where InOut<Signal>: HasView<SubstrateV> + HasBundleKind, Input<Signal>: HasView<SubstrateV> + HasBundleKind, <InOut<Signal> as HasView<SubstrateV>>::View: HasBundleKind<BundleKind = <InOut<Signal> as HasBundleKind>::BundleKind> + HasBundleKind, <Input<Signal> as HasView<SubstrateV>>::View: HasBundleKind<BundleKind = <Input<Signal> as HasBundleKind>::BundleKind> + HasBundleKind,

Source§

type BundleKind = MosIoKind

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 MosIoView<NestedNodeBundle>
where InOut<Signal>: HasSchematicBundleKindViews, Input<Signal>: HasSchematicBundleKindViews, <InOut<Signal> as HasView<NestedNodeBundle>>::View: HasNestedView<NestedView = <InOut<Signal> as HasView<NestedNodeBundle>>::View> + HasNestedView, <Input<Signal> as HasView<NestedNodeBundle>>::View: HasNestedView<NestedView = <Input<Signal> as HasView<NestedNodeBundle>>::View> + HasNestedView,

Source§

type NestedView = MosIoView<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 MosIoView<NestedTerminalBundle>
where InOut<Signal>: HasSchematicBundleKindViews, Input<Signal>: HasSchematicBundleKindViews, <InOut<Signal> as HasView<NestedTerminalBundle>>::View: HasNestedView<NestedView = <InOut<Signal> as HasView<NestedTerminalBundle>>::View> + HasNestedView, <Input<Signal> as HasView<NestedTerminalBundle>>::View: HasNestedView<NestedView = <Input<Signal> as HasView<NestedTerminalBundle>>::View> + HasNestedView,

Source§

type NestedView = MosIoView<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 MosIoView<NodeBundle>
where InOut<Signal>: HasSchematicBundleKindViews, Input<Signal>: HasSchematicBundleKindViews, <InOut<Signal> as HasView<NodeBundle>>::View: HasNestedView, <Input<Signal> as HasView<NodeBundle>>::View: HasNestedView,

Source§

type NestedView = MosIoView<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 MosIoView<TerminalBundle>
where InOut<Signal>: HasSchematicBundleKindViews, Input<Signal>: HasSchematicBundleKindViews, <InOut<Signal> as HasView<TerminalBundle>>::View: HasNestedView, <Input<Signal> as HasView<TerminalBundle>>::View: HasNestedView,

Source§

type NestedView = MosIoView<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 MosIoView<NestedNodeBundle>
where InOut<Signal>: HasView<NestedNodeBundle>, Input<Signal>: HasView<NestedNodeBundle>, <InOut<Signal> as HasView<NestedNodeBundle>>::View: Save<SubstrateS, SubstrateA>, <Input<Signal> as HasView<NestedNodeBundle>>::View: Save<SubstrateS, SubstrateA>, SubstrateS: Simulator, SubstrateA: Analysis,

Source§

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

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

type Saved = MosIoView<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 MosIoView<NestedTerminalBundle>
where InOut<Signal>: HasView<NestedTerminalBundle>, Input<Signal>: HasView<NestedTerminalBundle>, <InOut<Signal> as HasView<NestedTerminalBundle>>::View: Save<SubstrateS, SubstrateA>, <Input<Signal> as HasView<NestedTerminalBundle>>::View: Save<SubstrateS, SubstrateA>, SubstrateS: Simulator, SubstrateA: Analysis,

Source§

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

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

type Saved = MosIoView<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 MosIoView<SubstrateV>
where InOut<Signal>: HasView<SubstrateV>, Input<Signal>: HasView<SubstrateV>, <InOut<Signal> as HasView<SubstrateV>>::View: TransformRef, <Input<Signal> as HasView<SubstrateV>>::View: TransformRef,

Source§

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

Applies matrix-vector Transformation trans.
Source§

impl<SubstrateV> TranslateRef for MosIoView<SubstrateV>
where InOut<Signal>: HasView<SubstrateV>, Input<Signal>: HasView<SubstrateV>, <InOut<Signal> as HasView<SubstrateV>>::View: TranslateRef, <Input<Signal> 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<MosIoKind, SubstrateS> for MosIoView<SubstrateV>
where InOut<Signal>: HasView<SubstrateV> + HasBundleKind, Input<Signal>: HasView<SubstrateV> + HasBundleKind, <InOut<Signal> as HasView<SubstrateV>>::View: Unflatten<<InOut<Signal> as HasBundleKind>::BundleKind, SubstrateS>, <Input<Signal> as HasView<SubstrateV>>::View: Unflatten<<Input<Signal> as HasBundleKind>::BundleKind, SubstrateS>,

Source§

fn unflatten<SubstrateI>( __substrate_data: &MosIoKind, __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 MosIoView<SubstrateV>

§

impl<SubstrateV> !RefUnwindSafe for MosIoView<SubstrateV>

§

impl<SubstrateV> !Send for MosIoView<SubstrateV>

§

impl<SubstrateV> !Sync for MosIoView<SubstrateV>

§

impl<SubstrateV> !Unpin for MosIoView<SubstrateV>

§

impl<SubstrateV> !UnwindSafe for MosIoView<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> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
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