pub struct RunningState<V> { /* private fields */ }
Expand description

A state that can be updated during the forward pass while being thread safe.

Note

The state value is the average of all updates on all threads.

Implementations§

source§

impl<const D: usize, B: Backend> RunningState<Tensor<B, D>>

source

pub fn new(value: Tensor<B, D>) -> Self

Create a new running state.

source

pub fn with_id(id: ParamId, value: Tensor<B, D>) -> Self

Create a new running state.

source

pub fn from_record(record: Param<Tensor<B, D>>) -> Self

Create a new running state from a record.

source

pub fn update(&self, value: Tensor<B, D>)

Update the value on the current thread.

source

pub fn value(&self) -> Tensor<B, D>

Get the current value,

Note

The current value might be outdated by one update.

source

pub fn value_sync(&self) -> Tensor<B, D>

Get the current value and make sure it is sync.

Note

Don’t use this function after an update on the same thread where other threads might have to register their update before the actual synchonization needs to happen.

Trait Implementations§

source§

impl<const D: usize, B: ADBackend> ADModule<B> for RunningState<Tensor<B, D>>

§

type InnerModule = RunningState<Tensor<<B as ADBackend>::InnerBackend, D, Float>>

source§

fn valid(&self) -> Self::InnerModule

Get the same module, but on the inner backend without auto-differentiation.
source§

impl<V: Clone> Clone for RunningState<V>

source§

fn clone(&self) -> RunningState<V>

Returns a copy 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<V: Debug> Debug for RunningState<V>

source§

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

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

impl<const D: usize, B: Backend> Module<B> for RunningState<Tensor<B, D>>

§

type Record = Param<Tensor<B, D, Float>>

Type to save and load the module.
source§

fn visit<V: ModuleVisitor<B>>(&self, visitor: &mut V)

Visit each tensor in the module with a visitor.
source§

fn map<M: ModuleMapper<B>>(self, mapper: &mut M) -> Self

Map each tensor in the module with a mapper.
source§

fn into_record(self) -> Self::Record

Convert the module into a record containing the state.
source§

fn load_record(self, record: Self::Record) -> Self

Load the module state from a record.
source§

fn devices(&self) -> Vec<B::Device>

Get the device list of the module and all of its sub-modules.
source§

fn fork(self, device: &B::Device) -> Self

Fork the module and all of its sub-modules to the given device. Read more
source§

fn to_device(self, device: &B::Device) -> Self

Move the module and all of its sub-modules to the given device. Read more
source§

fn no_grad(self) -> Self

Each tensor in the module tree will not require grad. Read more
source§

fn num_params(&self) -> usize

Get the number of parameters the module has, including all of its sub-modules.

Auto Trait Implementations§

§

impl<V> RefUnwindSafe for RunningState<V>

§

impl<V> Send for RunningState<V>where V: Send + Sync,

§

impl<V> Sync for RunningState<V>where V: Send + Sync,

§

impl<V> Unpin for RunningState<V>

§

impl<V> UnwindSafe for RunningState<V>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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 Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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 Twhere V: MultiLane<T>,

§

fn vzip(self) -> V