pub struct CpDecomposition<R: Runtime> {
pub factors: Vec<Tensor<R>>,
pub weights: Tensor<R>,
}Expand description
CP/PARAFAC decomposition result: T ≈ Σᵣ λᵣ × a₁ʳ ⊗ a₂ʳ ⊗ … ⊗ aₙʳ
The Canonical Polyadic (CP) decomposition, also known as PARAFAC (Parallel Factor Analysis), factors an N-dimensional tensor as a sum of R rank-one tensors.
§Mathematical Definition
For a tensor T of shape [I₁, I₂, ..., Iₙ], the CP decomposition is:
T ≈ Σᵣ₌₁ᴿ λᵣ × a₁ʳ ⊗ a₂ʳ ⊗ ... ⊗ aₙʳwhere:
- R is the CP rank (number of components)
λᵣare scalar weights (can be absorbed into factors)aₖʳare column vectors of factor matrixAₖ[Iₖ, R]- ⊗ denotes outer product
§Matrix Notation
Using factor matrices A₁, A₂, ..., Aₙ where Aₖ has shape [Iₖ, R]:
T_{(1)} ≈ A₁ @ diag(λ) @ (Aₙ ⊙ ... ⊙ A₂)ᵀwhere ⊙ denotes Khatri-Rao (column-wise Kronecker) product.
§Element-wise Formula
T[i₁, i₂, ..., iₙ] ≈ Σᵣ₌₁ᴿ λᵣ × A₁[i₁, r] × A₂[i₂, r] × ... × Aₙ[iₙ, r]§Properties
- Uniqueness: Unique under mild conditions (unlike Tucker)
- Interpretability: Each component is a rank-1 tensor (separable)
- Compression: Parameters =
R × (1 + Σ Iₖ)vs∏ Iₖfor full tensor - Diagonal core: Equivalent to Tucker with superdiagonal core
§Use Cases
- Chemometrics (fluorescence spectroscopy)
- Psychometrics (multi-trait, multi-method)
- Signal processing (source separation)
- Recommender systems (user-item-context)
- Topic modeling
Fields§
§factors: Vec<Tensor<R>>Factor matrices [A₁, A₂, ..., Aₙ], one per mode
Each Aₖ has shape [Iₖ, R] where Iₖ is the dimension along mode k
and R is the CP rank.
Column r of each factor matrix corresponds to component r.
weights: Tensor<R>Weights (lambda) for each rank-1 component [R]
Scalar weights that can optionally be absorbed into factor matrices. For normalized factors (columns have unit norm), weights capture the “strength” of each component.
Auto Trait Implementations§
impl<R> Freeze for CpDecomposition<R>
impl<R> RefUnwindSafe for CpDecomposition<R>
impl<R> Send for CpDecomposition<R>
impl<R> Sync for CpDecomposition<R>
impl<R> Unpin for CpDecomposition<R>
impl<R> UnsafeUnpin for CpDecomposition<R>
impl<R> UnwindSafe for CpDecomposition<R>
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.