Skip to main content

LossContext

Struct LossContext 

Source
pub struct LossContext<'a> {
    pub output: &'a Variable,
    pub batch: &'a Batch,
    pub tags: &'a HashMap<String, Variable>,
    pub traces: &'a HashMap<String, Vec<Variable>>,
}
Expand description

Context passed to the per-batch loss closure during El Che distributed training. All fields carry live autograd graphs, so the returned loss scalar can be backpropagated immediately.

model.set_loss_fn(|ctx: &LossContext| {
    let cls  = cross_entropy_loss(&ctx.tags["head"], &ctx.batch["label"])?;
    let rec  = mse_loss(&ctx.tags["recon"], &ctx.batch["image"])?;
    Ok(cls + rec)
});

Fields§

§output: &'a Variable

Forward output (live autograd).

§batch: &'a Batch

The per-device batch with all named fields (inputs + targets).

§tags: &'a HashMap<String, Variable>

Tagged outputs from this forward pass (live autograd).

§traces: &'a HashMap<String, Vec<Variable>>

Loop traces keyed by tag name (live autograd).

Auto Trait Implementations§

§

impl<'a> Freeze for LossContext<'a>

§

impl<'a> !RefUnwindSafe for LossContext<'a>

§

impl<'a> !Send for LossContext<'a>

§

impl<'a> !Sync for LossContext<'a>

§

impl<'a> Unpin for LossContext<'a>

§

impl<'a> UnsafeUnpin for LossContext<'a>

§

impl<'a> !UnwindSafe for LossContext<'a>

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