Represents a factorization of a system of equations with no exact solution such that the singular value method of least squares can be used. More...
#include <rw/lapack/lssv.h>
Public Member Functions | |
RWLeastSqSV () | |
RWLeastSqSV (const RWGenMat< TypeT > &A, double tol=0) | |
RWLeastSqSV (const RWSVDecomp< TypeT, SVDCalc > &A, double tol=0) | |
RWMathVec< TypeT > | residual (const RWMathVec< TypeT > &b) const |
rw_numeric_traits< TypeT >::norm_type | residualNorm (const RWMathVec< TypeT > &b) const |
RWMathVec< TypeT > | solve (const RWMathVec< TypeT > &b) const |
Public Member Functions inherited from RWSVDecomp< TypeT, SVDCalc > | |
RWSVDecomp () | |
RWSVDecomp (const RWSVDecomp< TypeT, SVDCalc > &A) | |
RWSVDecomp (const RWGenMat< TypeT > &A, norm_type tol=0) | |
unsigned | cols () const |
void | factor (const RWGenMat< TypeT > &A, norm_type tol=0) |
bool | fail () const |
bool | good () const |
const RWMathVec< TypeT > | leftVector (int i) const |
const RWGenMat< TypeT > | leftVectors () const |
unsigned | numLeftVectors () const |
unsigned | numRightVectors () const |
RWSVDecomp< TypeT, SVDCalc > & | operator= (const RWSVDecomp< TypeT, SVDCalc > &x) |
unsigned | rank () const |
const RWMathVec< TypeT > | rightVector (int i) const |
const RWGenMat< TypeT > | rightVectors () const |
unsigned | rows () const |
norm_type | singularValue (int i) const |
const RWMathVec< norm_type > | singularValues () const |
void | truncate (norm_type tol) |
Additional Inherited Members | |
Public Types inherited from RWSVDecomp< TypeT, SVDCalc > | |
typedef rw_numeric_traits< TypeT >::norm_type | norm_type |
A linear system of equations has the form \( Ax = b \), where A contains more rows than columns and generally has no exact solution; it is overdetermined. The best that we can do is to find a solution vector x such that the norm of the residual vector, \( Ax-b \), is made as small as possible. The vector x is then a solution in the least squares sense, and this sort of problem is called a least squares problem.
There are three classes in the Linear Algebra Module for solving least squares problems. The approach is to construct a factorization of the matrix A that can be used to solve the problem. The classes RWLeastSqCh RWLeastSqQR and RWLeastSqSV encapsulate this factorization object. There are three methods provided:
Ch
QR
SV
.Which method you choose depends on the trade-off between speed and robustness that you want to make. As you move down the list, the methods decrease in speed, but increase in accuracy and robustness.
A system of equations \( Ax = b \) is underdetermined if the columns of A are linearly dependent. In this case, there are infinitely many solutions. Often, the one that is desired is the one with minimum norm. The classes RWLeastSqQR and RWLeastSqSV allow you to compute this solution.
Note that the classes RWLeastSqQR and RWLeastSqSV are publicly derived from their underlying decomposition types, so that advanced users can manipulate the underlying decomposition directly.
RWLeastSqSV< TypeT, SVDCalc >::RWLeastSqSV | ( | ) |
Default constructor. Builds an empty decomposition. The decomposition is filled in using the factor function.
RWLeastSqSV< TypeT, SVDCalc >::RWLeastSqSV | ( | const RWGenMat< TypeT > & | A, |
double | tol = 0 |
||
) |
Constructs a factorization representing the given matrix. The supplied tolerance tells when to consider entries along the diagonal of the underlying decomposition as 0. The tolerance should indicate the accuracy to which you know entries in A.
RWLeastSqSV< TypeT, SVDCalc >::RWLeastSqSV | ( | const RWSVDecomp< TypeT, SVDCalc > & | A, |
double | tol = 0 |
||
) |
Constructs a factorization representing the linear system represented by the given decomposition. The parameter tol tells when to consider entries along the diagonal of the given SV decomposition as 0. The tolerance should indicate the accuracy to which you know the entries in the matrix.
RWMathVec<TypeT> RWLeastSqSV< TypeT, SVDCalc >::residual | ( | const RWMathVec< TypeT > & | b | ) | const |
Returns the residual vector, \( b-Ax \), associated with the right-hand side vector b and the corresponding least squares solution vector x
rw_numeric_traits<TypeT>::norm_type RWLeastSqSV< TypeT, SVDCalc >::residualNorm | ( | const RWMathVec< TypeT > & | b | ) | const |
Returns the norm of the residual vector, \( (b-Ax)'(b-Ax) \), associated with the right-hand side vector b and the corresponding least squares solution vector x
.
RWMathVec<TypeT> RWLeastSqSV< TypeT, SVDCalc >::solve | ( | const RWMathVec< TypeT > & | b | ) | const |
Returns the solution to the least squares problem for the given right-hand-side vector b. If the system matrix is overdetermined, this is the vector that minimizes the norm of the residual vector. If the system matrix is not overdetermined, this is the minimum norm vector that satisfies the system equations.
Copyright © 2020 Rogue Wave Software, Inc. All Rights Reserved. |