Skip to main content

BayesianLinear

Struct BayesianLinear 

Source
pub struct BayesianLinear {
    pub in_features: usize,
    pub out_features: usize,
    pub w_mu: Vec<f64>,
    pub w_log_sigma: Vec<f64>,
    pub b_mu: Vec<f64>,
    pub b_log_sigma: Vec<f64>,
    pub prior_std: f64,
}
Expand description

A single variational Bayesian linear layer.

Weights: w_{ij} ~ N(w_mu_{ij}, exp(w_log_sigma_{ij})^2) Biases: b_j ~ N(b_mu_j, exp(b_log_sigma_j)^2)

Stored as flat row-major vectors of length out_features * in_features.

Fields§

§in_features: usize

Number of input features

§out_features: usize

Number of output features

§w_mu: Vec<f64>

Weight posterior means, length out_features * in_features

§w_log_sigma: Vec<f64>

Weight posterior log-std, length out_features * in_features

§b_mu: Vec<f64>

Bias posterior means, length out_features

§b_log_sigma: Vec<f64>

Bias posterior log-std, length out_features

§prior_std: f64

Prior standard deviation

Implementations§

Source§

impl BayesianLinear

Source

pub fn new( in_features: usize, out_features: usize, prior_std: f64, ) -> Result<Self, StatsError>

Create a new BayesianLinear layer.

Weights are initialized from N(0, 0.1) and log-sigma initialized to -3.0 (corresponding to sigma ≈ 0.05, tight initial posterior).

§Arguments
  • in_features - Input dimensionality
  • out_features - Output dimensionality
  • prior_std - Standard deviation of the weight prior
§Errors

Returns an error if in_features or out_features is zero.

Source

pub fn forward_sample( &self, x: &[f64], rng: &mut impl FnMut() -> f64, ) -> Result<Vec<f64>, StatsError>

Forward pass with sampled weights (reparameterization trick).

Samples w = w_mu + eps * exp(w_log_sigma) for each weight and bias, then computes the matrix-vector product.

§Arguments
  • x - Input vector of length in_features
  • rng - Closure producing standard normal samples N(0,1)
§Returns

Output vector of length out_features

§Errors

Returns an error if x has incorrect length.

Source

pub fn forward_mean(&self, x: &[f64]) -> Result<Vec<f64>, StatsError>

Deterministic forward pass using posterior means only.

Computes output = W_mu @ x + b_mu. Useful for fast predictive mean.

§Arguments
  • x - Input vector of length in_features
§Errors

Returns an error if x has incorrect length.

Source

pub fn kl_divergence(&self, prior_std: f64) -> f64

Compute the KL divergence KL[q(w) || p(w)] for all weights and biases.

For q = N(mu, sigma^2) and p = N(0, prior_std^2): KL = -0.5 * sum(1 + 2*log_sigma - log(prior_std^2) - mu^2/prior_std^2 - sigma^2/prior_std^2)

§Arguments
  • prior_std - Prior standard deviation (can differ from initialization value)
Source

pub fn update( &mut self, grad_w_mu: &[f64], grad_w_log_sigma: &[f64], grad_b_mu: &[f64], grad_b_log_sigma: &[f64], lr: f64, ) -> Result<(), StatsError>

Apply a gradient step (SGD) to the variational parameters.

§Arguments
  • grad_w_mu - Gradient of loss w.r.t. w_mu, length out*in
  • grad_w_log_sigma - Gradient of loss w.r.t. w_log_sigma, length out*in
  • grad_b_mu - Gradient of loss w.r.t. b_mu, length out
  • grad_b_log_sigma - Gradient of loss w.r.t. b_log_sigma, length out
  • lr - Learning rate
§Errors

Returns an error if gradient dimensions are inconsistent.

Source

pub fn n_params(&self) -> usize

Total number of variational parameters (for KL / ELBO scaling)

Trait Implementations§

Source§

impl Clone for BayesianLinear

Source§

fn clone(&self) -> BayesianLinear

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for BayesianLinear

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

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

impl<T> Downcast<T> for T

Source§

fn downcast(&self) -> &T

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

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

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
Source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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.
Source§

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

Source§

impl<T> Upcast<T> for T

Source§

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

Source§

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

Source§

fn vzip(self) -> V

Source§

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

Source§

impl<T> WasmNotSendSync for T

Source§

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

Source§

impl<T> WithSubscriber for T

Source§

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

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more