SmoothL1Loss

Struct SmoothL1Loss 

pub struct SmoothL1Loss {
    pub beta: f32,
}
Expand description

Computes the Smooth L1 Loss between predictions and targets.

This loss function uses L2 loss for small errors (below beta) and L1 loss for large errors (above beta), providing robustness to outliers while maintaining smooth gradients near |x - y| = 0.

§Mathematical Definition

For predictions x and targets y, the element-wise loss is:

  • L_i = 0.5 * (x_i - y_i)² / beta , if |x_i - y_i| < beta
  • L_i = |x_i - y_i| - 0.5 * beta , otherwise

§Notes

Smooth L1 loss is closely related to HuberLoss since it is equivalent to HuberLoss scaled by 1/beta: SmoothL1(x, y, beta) = Huber(x, y, beta) / beta

This leads to the following differences:

  • As beta approaches 0, Smooth L1 loss converges to L1Loss, while HuberLoss converges to 0. When beta = 0, Smooth L1 loss is equivalent to L1 loss. Thus, the beta parameter in Burn must be positive. L1Loss should be used for beta = 0.
  • As beta approaches positive infinity, Smooth L1 loss converges to a constant 0 loss, while HuberLoss converges to L2Loss.

§Example

use burn_nn::loss::{SmoothL1LossConfig, Reduction};
use burn::tensor::Tensor;

// Create Smooth L1 loss with the default beta=1.0
let smooth_l1 = SmoothL1LossConfig::new().init();

let predictions: Tensor<Backend, 2> = /* model output */;
let targets: Tensor<Backend, 2> = /* ground truth */;

// Compute element-wise loss without reduction
let element_wise = smooth_l1.forward(predictions.clone(), targets.clone());

// Compute loss with mean reduction
let loss = smooth_l1.forward_with_reduction(predictions.clone(), targets.clone(), Reduction::Mean);

// Per-image loss: reduce over C, H, W → [batch, 1, 1, 1]
let loss_per_image = smooth_l1.forward_reduce_dims(predictions, targets, &[1, 2, 3]);

Fields§

§beta: f32

Specifies the threshold at which to change between L1 and L2 loss. The value must be positive. Default: 1.0

Implementations§

§

impl SmoothL1Loss

pub fn forward<const D: usize, B>( &self, predictions: Tensor<B, D>, targets: Tensor<B, D>, ) -> Tensor<B, D>
where B: Backend,

Computes the element-wise smooth L1 loss without reduction.

§Arguments
  • predictions - The model’s predicted values.
  • targets - The ground truth target values.
§Returns

A tensor of the same shape as the inputs, containing the smooth L1 loss for each element.

§Shapes
  • predictions: [...dims] - Any shape
  • targets: [...dims] - Must match predictions shape
  • output: [...dims] - Same shape as inputs

pub fn forward_with_reduction<const D: usize, B>( &self, predictions: Tensor<B, D>, targets: Tensor<B, D>, reduction: Reduction, ) -> Tensor<B, 1>
where B: Backend,

Computes the smooth L1 loss with reduction.

§Arguments
  • predictions - The model’s predicted values.
  • targets - The ground truth target values.
  • reduction - Specifies how to reduce the element-wise losses:
    • Reduction::Mean or Reduction::Auto: Returns the mean of all element-wise losses.
    • Reduction::Sum: Returns the sum of all element-wise losses.
§Returns

A scalar tensor containing the reduced loss value.

§Shapes
  • predictions: [...dims] - Any shape
  • targets: [...dims] - Must match predictions shape
  • output: [1] - Scalar loss value

pub fn forward_reduce_dims<const D: usize, B>( &self, predictions: Tensor<B, D>, targets: Tensor<B, D>, dims: &[usize], ) -> Tensor<B, D>
where B: Backend,

Computes the smooth L1 loss with reduction over specified dimensions.

Calculates element-wise smooth L1 loss, then takes the mean over the specified dimensions. Useful for per-sample or per-channel losses.

Dimensions can be provided in any order. They are sorted internally and reduced from highest to lowest to ensure indices remain valid.

§Arguments
  • predictions - The model’s predicted values.
  • targets - The ground truth target values.
  • dims - Dimensions to reduce over.
§Returns

A tensor with the specified dimensions reduced to size 1.

§Example
// Consider image tensor with shape [batch, C, H, W]
let smooth_l1 = SmoothL1LossConfig::new().init();

// Per-image loss: reduce over C, H, W → [batch, 1, 1, 1]
let loss_per_image = smooth_l1.forward_reduce_dims(predictions, targets, &[1, 2, 3]);

Trait Implementations§

§

impl<B> AutodiffModule<B> for SmoothL1Loss
where B: AutodiffBackend,

§

type InnerModule = SmoothL1Loss

Inner module without auto-differentiation.
§

fn valid(&self) -> <SmoothL1Loss as AutodiffModule<B>>::InnerModule

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

fn from_inner( module: <SmoothL1Loss as AutodiffModule<B>>::InnerModule, ) -> SmoothL1Loss

Wraps an inner module back into an auto-diff module.
§

impl Clone for SmoothL1Loss

§

fn clone(&self) -> SmoothL1Loss

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
§

impl Debug for SmoothL1Loss

§

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

Formats the value using the given formatter. Read more
§

impl Display for SmoothL1Loss

§

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

Formats the value using the given formatter. Read more
§

impl<B> Module<B> for SmoothL1Loss
where B: Backend,

§

type Record = EmptyRecord

Type to save and load the module.
§

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

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

fn map<M>(self, _mapper: &mut M) -> SmoothL1Loss
where M: ModuleMapper<B>,

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

fn load_record( self, _record: <SmoothL1Loss as Module<B>>::Record, ) -> SmoothL1Loss

Load the module state from a record.
§

fn into_record(self) -> <SmoothL1Loss as Module<B>>::Record

Convert the module into a record containing the state.
§

fn to_device(self, _: &<B as BackendTypes>::Device) -> SmoothL1Loss

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

fn fork(self, _: &<B as BackendTypes>::Device) -> SmoothL1Loss

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

fn collect_devices( &self, devices: Vec<<B as BackendTypes>::Device>, ) -> Vec<<B as BackendTypes>::Device>

Return all the devices found in the underneath module tree added to the given vector without duplicates.
§

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

Return all the devices found in the underneath module tree without duplicates.
§

fn no_grad(self) -> Self

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

fn train<AB>(self) -> Self::TrainModule
where AB: AutodiffBackend<InnerBackend = B>, Self: HasAutodiffModule<AB>,

Move the module and all of its sub-modules to the autodiff backend. Read more
§

fn num_params(&self) -> usize

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

fn save_file<FR, PB>( self, file_path: PB, recorder: &FR, ) -> Result<(), RecorderError>
where FR: FileRecorder<B>, PB: Into<PathBuf>,

Save the module to a file using the provided file recorder. Read more
§

fn load_file<FR, PB>( self, file_path: PB, recorder: &FR, device: &<B as BackendTypes>::Device, ) -> Result<Self, RecorderError>
where FR: FileRecorder<B>, PB: Into<PathBuf>,

Load the module from a file using the provided file recorder. Read more
§

fn quantize_weights(self, quantizer: &mut Quantizer) -> Self

Quantize the weights of the module.
§

impl ModuleDisplay for SmoothL1Loss

§

fn format(&self, passed_settings: DisplaySettings) -> String

Formats the module with provided display settings. Read more
§

fn custom_settings(&self) -> Option<DisplaySettings>

Custom display settings for the module. Read more
§

fn custom_content(&self, _content: Content) -> Option<Content>

Custom attributes for the module. Read more
§

impl ModuleDisplayDefault for SmoothL1Loss

§

fn content(&self, content: Content) -> Option<Content>

Attributes of the module used for display purposes. Read more
§

fn num_params(&self) -> usize

Gets the number of the parameters of the module.

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Adaptor<()> for T

§

fn adapt(&self)

Adapt the type to be passed to a metric.
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<C> CloneExpand for C
where C: Clone,

§

fn __expand_clone_method(&self, _scope: &mut Scope) -> C

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

§

fn downcast(&self) -> &T

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.

§

impl<T> IntoComptime for T

§

fn comptime(self) -> Self

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
§

impl<T> ToCompactString for T
where T: Display,

§

fn try_to_compact_string(&self) -> Result<CompactString, ToCompactStringError>

Fallible version of [ToCompactString::to_compact_string()] Read more
§

fn to_compact_string(&self) -> CompactString

Converts the given value to a [CompactString]. Read more
§

impl<T> ToLine for T
where T: Display,

§

fn to_line(&self) -> Line<'_>

Converts the value to a [Line].
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
§

impl<T> ToSpan for T
where T: Display,

§

fn to_span(&self) -> Span<'_>

Converts the value to a [Span].
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
§

impl<T> ToText for T
where T: Display,

§

fn to_text(&self) -> Text<'_>

Converts the value to a [Text].
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<T> TuneInputs for T
where T: Clone + Send + Sync + 'static,

§

type At<'a> = T

The concrete input type at lifetime 'a.
§

impl<T> Upcast<T> for T

§

fn upcast(&self) -> Option<&T>

§

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
§

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

§

impl<T> WasmNotSendSync for T
where T: WasmNotSend + WasmNotSync,

§

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