AdValue

Enum AdValue 

Source
pub enum AdValue<T> {
    Primal(T),
    Forward {
        primal: T,
        tangent: T,
    },
    Reverse {
        primal: T,
        node: NodeId,
        tape: TapeId,
        tangent: Option<T>,
    },
}
Expand description

Generic AD value that can wrap any user-defined payload type T.

This is the primary extension point of the crate.

§Examples

use ad_tensors_rs::{AdMode, AdValue, NodeId, TapeId};

let primal = AdValue::primal(3.0_f64);
assert_eq!(primal.mode(), AdMode::Primal);

let dual = AdValue::forward(3.0_f64, 1.0_f64);
assert_eq!(dual.mode(), AdMode::Forward);

let tracked = AdValue::reverse(3.0_f64, NodeId(1), TapeId(9), None);
assert_eq!(tracked.mode(), AdMode::Reverse);

Variants§

§

Primal(T)

Primal-only value.

§

Forward

Forward-mode value and tangent.

Fields

§primal: T
§tangent: T
§

Reverse

Reverse-mode value with graph metadata.

Fields

§primal: T
§node: NodeId
§tape: TapeId
§tangent: Option<T>

Implementations§

Source§

impl<T> AdValue<T>

Source

pub fn primal(value: T) -> Self

Creates a primal-only value.

§Examples
use ad_tensors_rs::AdValue;

let x = AdValue::primal(2_i32);
assert!(matches!(x, AdValue::Primal(2)));
Source

pub fn forward(primal: T, tangent: T) -> Self

Creates a forward-mode value.

§Examples
use ad_tensors_rs::AdValue;

let x = AdValue::forward(2.0_f64, 1.0_f64);
assert!(matches!(x, AdValue::Forward { .. }));
Source

pub fn reverse( primal: T, node: NodeId, tape: TapeId, tangent: Option<T>, ) -> Self

Creates a reverse-mode value.

§Examples
use ad_tensors_rs::{AdValue, NodeId, TapeId};

let x = AdValue::reverse(2.0_f64, NodeId(3), TapeId(5), Some(0.1));
assert!(matches!(x, AdValue::Reverse { .. }));
Source

pub fn mode(&self) -> AdMode

Returns the AD mode.

§Examples
use ad_tensors_rs::{AdMode, AdValue};

let x = AdValue::forward(1.0_f64, 1.0_f64);
assert_eq!(x.mode(), AdMode::Forward);
Source

pub fn primal_ref(&self) -> &T

Returns a reference to the primal payload.

§Examples
use ad_tensors_rs::AdValue;

let x = AdValue::forward(10_i32, 1_i32);
assert_eq!(x.primal_ref(), &10);
Source

pub fn primal_mut(&mut self) -> &mut T

Returns a mutable reference to the primal payload.

§Examples
use ad_tensors_rs::AdValue;

let mut x = AdValue::primal(1_i32);
*x.primal_mut() = 7;
assert_eq!(x.primal_ref(), &7);
Source

pub fn tangent_ref(&self) -> Option<&T>

Returns a reference to tangent payload when available.

§Examples
use ad_tensors_rs::AdValue;

let x = AdValue::forward(2.0_f64, 3.0_f64);
assert_eq!(x.tangent_ref(), Some(&3.0));
Source

pub fn node_id(&self) -> Option<NodeId>

Returns reverse-mode node id when available.

§Examples
use ad_tensors_rs::{AdValue, NodeId, TapeId};

let x = AdValue::reverse(1.0_f64, NodeId(4), TapeId(6), None);
assert_eq!(x.node_id(), Some(NodeId(4)));
Source

pub fn tape_id(&self) -> Option<TapeId>

Returns reverse-mode tape id when available.

§Examples
use ad_tensors_rs::{AdValue, NodeId, TapeId};

let x = AdValue::reverse(1.0_f64, NodeId(4), TapeId(6), None);
assert_eq!(x.tape_id(), Some(TapeId(6)));
Source

pub fn map<U>(self, f: impl FnMut(T) -> U) -> AdValue<U>

Maps the payload type while preserving AD mode.

§Examples
use ad_tensors_rs::AdValue;

let x = AdValue::forward(2_i32, 3_i32);
let y = x.map(|v| v as f64);
assert_eq!(y.primal_ref(), &2.0_f64);
assert_eq!(y.tangent_ref(), Some(&3.0_f64));

Trait Implementations§

Source§

impl<T: Clone> Clone for AdValue<T>

Source§

fn clone(&self) -> AdValue<T>

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<T: Debug> Debug for AdValue<T>

Source§

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

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

impl<T: Clone> Differentiable for AdValue<T>

Source§

type Primal = T

Underlying primal payload type.
Source§

fn ad_value(&self) -> &AdValue<T>

Borrow as an AdValue.
Source§

impl<T> From<AdScalar<T>> for AdValue<T>

Source§

fn from(value: AdScalar<T>) -> Self

Converts to this type from the input type.
Source§

impl<T: Scalar> From<AdTensor<T>> for AdValue<Tensor<T>>

Source§

fn from(value: AdTensor<T>) -> Self

Converts to this type from the input type.
Source§

impl From<AdValue<Complex<f32>>> for DynAdValue

Source§

fn from(value: AdValue<Complex32>) -> Self

Converts to this type from the input type.
Source§

impl From<AdValue<Complex<f64>>> for DynAdValue

Source§

fn from(value: AdValue<Complex64>) -> Self

Converts to this type from the input type.
Source§

impl<T> From<AdValue<T>> for AdScalar<T>

Source§

fn from(value: AdValue<T>) -> Self

Converts to this type from the input type.
Source§

impl<T: Scalar> From<AdValue<Tensor<T>>> for AdTensor<T>

Source§

fn from(value: AdValue<Tensor<T>>) -> Self

Converts to this type from the input type.
Source§

impl From<AdValue<f32>> for DynAdValue

Source§

fn from(value: AdValue<f32>) -> Self

Converts to this type from the input type.
Source§

impl From<AdValue<f64>> for DynAdValue

Source§

fn from(value: AdValue<f64>) -> Self

Converts to this type from the input type.
Source§

impl<T> From<T> for AdValue<T>

Source§

fn from(value: T) -> Self

Converts to this type from the input type.
Source§

impl<T: PartialEq> PartialEq for AdValue<T>

Source§

fn eq(&self, other: &AdValue<T>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T> StructuralPartialEq for AdValue<T>

Auto Trait Implementations§

§

impl<T> Freeze for AdValue<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for AdValue<T>
where T: RefUnwindSafe,

§

impl<T> Send for AdValue<T>
where T: Send,

§

impl<T> Sync for AdValue<T>
where T: Sync,

§

impl<T> Unpin for AdValue<T>
where T: Unpin,

§

impl<T> UnwindSafe for AdValue<T>
where T: 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
§

impl<T> ByRef<T> for T

§

fn by_ref(&self) -> &T

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
§

impl<T> DistributionExt for T
where T: ?Sized,

§

fn rand<T>(&self, rng: &mut (impl Rng + ?Sized)) -> T
where Self: Distribution<T>,

Source§

impl<T> From<!> for T

Source§

fn from(t: !) -> T

Converts to this type from the input type.
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> 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
§

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> 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.
§

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

§

fn vzip(self) -> V

§

impl<T, U> Imply<T> for U
where T: ?Sized, U: ?Sized,

§

impl<T> MaybeSend for T

§

impl<T> MaybeSendSync for T

§

impl<T> MaybeSync for T