Struct nalgebra::linalg::SVD [] [src]

pub struct SVD<N: Real, R: DimMin<C>, C: Dim> where
    DefaultAllocator: Allocator<N, DimMinimum<R, C>, C> + Allocator<N, R, DimMinimum<R, C>> + Allocator<N, DimMinimum<R, C>>, 
{ pub u: Option<MatrixMN<N, R, DimMinimum<R, C>>>, pub v_t: Option<MatrixMN<N, DimMinimum<R, C>, C>>, pub singular_values: VectorN<N, DimMinimum<R, C>>, }

Singular Value Decomposition of a general matrix.

Fields

The left-singular vectors U of this SVD.

The right-singular vectors V^t of this SVD.

The singular values of this SVD.

Methods

impl<N: Real, R: DimMin<C>, C: Dim> SVD<N, R, C> where
    DimMinimum<R, C>: DimSub<U1>,
    DefaultAllocator: Allocator<N, R, C> + Allocator<N, C> + Allocator<N, R> + Allocator<N, DimDiff<DimMinimum<R, C>, U1>> + Allocator<N, DimMinimum<R, C>, C> + Allocator<N, R, DimMinimum<R, C>> + Allocator<N, DimMinimum<R, C>>, 
[src]

[src]

Computes the Singular Value Decomposition of matrix using implicit shift.

[src]

Attempts to compute the Singular Value Decomposition of matrix using implicit shift.

Arguments

  • compute_u − set this to true to enable the computation of left-singular vectors.
  • compute_v − set this to true to enable the computation of left-singular vectors.
  • eps − tolerence used to determine when a value converged to 0.
  • max_niter − maximum total number of iterations performed by the algorithm. If this number of iteration is exceeded, None is returned. If niter == 0, then the algorithm continues indefinitely until convergence.

[src]

Computes the rank of the decomposed matrix, i.e., the number of singular values greater than eps.

[src]

Rebuild the original matrix.

This is useful if some of the singular values have been manually modified. Panics if the right- and left- singular vectors have not been computed at construction-time.

[src]

Computes the pseudo-inverse of the decomposed matrix.

Any singular value smaller than eps is assumed to be zero. Panics if the right- and left- singular vectors have not been computed at construction-time.

[src]

Solves the system self * x = b where self is the decomposed matrix and x the unknown.

Any singular value smaller than eps is assumed to be zero. Returns None if the singular vectors U and V have not been computed.

Trait Implementations

impl<N: Clone + Real, R: Clone + DimMin<C>, C: Clone + Dim> Clone for SVD<N, R, C> where
    DefaultAllocator: Allocator<N, DimMinimum<R, C>, C> + Allocator<N, R, DimMinimum<R, C>> + Allocator<N, DimMinimum<R, C>>, 
[src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl<N: Debug + Real, R: Debug + DimMin<C>, C: Debug + Dim> Debug for SVD<N, R, C> where
    DefaultAllocator: Allocator<N, DimMinimum<R, C>, C> + Allocator<N, R, DimMinimum<R, C>> + Allocator<N, DimMinimum<R, C>>, 
[src]

[src]

Formats the value using the given formatter.

impl<N: Real, R: DimMin<C>, C: Dim> Copy for SVD<N, R, C> where
    DefaultAllocator: Allocator<N, DimMinimum<R, C>, C> + Allocator<N, R, DimMinimum<R, C>> + Allocator<N, DimMinimum<R, C>>,
    MatrixMN<N, R, DimMinimum<R, C>>: Copy,
    MatrixMN<N, DimMinimum<R, C>, C>: Copy,
    VectorN<N, DimMinimum<R, C>>: Copy
[src]