LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
Public Types | Public Member Functions | Public Attributes | List of all members
lsst::afw::math::LeastSquares::Impl Class Referenceabstract

Public Types

enum  StateFlags {
  LOWER_FISHER_MATRIX = 0x001 , FULL_FISHER_MATRIX = 0x002 , RHS_VECTOR = 0x004 , SOLUTION_ARRAY = 0x008 ,
  COVARIANCE_ARRAY = 0x010 , DIAGNOSTIC_ARRAY = 0x020 , DESIGN_AND_DATA = 0x040
}
 

Public Member Functions

template<typename D >
void setRank (Eigen::MatrixBase< D > const &values)
 
void ensure (int desired)
 
virtual void factor ()=0
 
virtual void updateRank ()=0
 
virtual void updateSolution ()=0
 
virtual void updateCovariance ()=0
 
virtual void updateDiagnostic ()=0
 
 Impl (int dimension_, double threshold_=std::numeric_limits< double >::epsilon())
 
virtual ~Impl ()=default
 

Public Attributes

int state
 
int dimension
 
int rank
 
Factorization factorization
 
Factorization whichDiagnostic
 
double threshold
 
Eigen::MatrixXd design
 
Eigen::VectorXd data
 
Eigen::MatrixXd fisher
 
Eigen::VectorXd rhs
 
ndarray::Array< double, 1, 1 > solution
 
ndarray::Array< double, 2, 2 > covariance
 
ndarray::Array< double, 1, 1 > diagnostic
 

Detailed Description

Definition at line 43 of file LeastSquares.cc.

Member Enumeration Documentation

◆ StateFlags

Enumerator
LOWER_FISHER_MATRIX 
FULL_FISHER_MATRIX 
RHS_VECTOR 
SOLUTION_ARRAY 
COVARIANCE_ARRAY 
DIAGNOSTIC_ARRAY 
DESIGN_AND_DATA 

Definition at line 45 of file LeastSquares.cc.

Constructor & Destructor Documentation

◆ Impl()

lsst::afw::math::LeastSquares::Impl::Impl ( int  dimension_,
double  threshold_ = std::numeric_limits<double>::epsilon() 
)
inline

◆ ~Impl()

virtual lsst::afw::math::LeastSquares::Impl::~Impl ( )
virtualdefault

Member Function Documentation

◆ ensure()

void lsst::afw::math::LeastSquares::Impl::ensure ( int  desired)
inline

Definition at line 82 of file LeastSquares.cc.

82  {
84  if (desired & FULL_FISHER_MATRIX) desired |= LOWER_FISHER_MATRIX;
85  int toAdd = ~state & desired;
86  if (toAdd & LOWER_FISHER_MATRIX) {
87  assert(state & DESIGN_AND_DATA);
88  fisher = Eigen::MatrixXd::Zero(design.cols(), design.cols());
89  fisher.selfadjointView<Eigen::Lower>().rankUpdate(design.adjoint());
90  }
91  if (toAdd & FULL_FISHER_MATRIX) {
92  fisher.triangularView<Eigen::StrictlyUpper>() = fisher.adjoint();
93  }
94  if (toAdd & RHS_VECTOR) {
95  assert(state & DESIGN_AND_DATA);
96  rhs = design.adjoint() * data;
97  }
98  if (toAdd & SOLUTION_ARRAY) {
99  if (solution.isEmpty()) solution = ndarray::allocate(dimension);
100  updateSolution();
101  }
102  if (toAdd & COVARIANCE_ARRAY) {
103  if (covariance.isEmpty()) covariance = ndarray::allocate(dimension, dimension);
105  }
106  if (toAdd & DIAGNOSTIC_ARRAY) {
107  if (diagnostic.isEmpty()) diagnostic = ndarray::allocate(dimension);
109  }
110  state |= toAdd;
111  }
ndarray::Array< double, 1, 1 > solution
Definition: LeastSquares.cc:67
ndarray::Array< double, 2, 2 > covariance
Definition: LeastSquares.cc:68
ndarray::Array< double, 1, 1 > diagnostic
Definition: LeastSquares.cc:69

◆ factor()

virtual void lsst::afw::math::LeastSquares::Impl::factor ( )
pure virtual

◆ setRank()

template<typename D >
void lsst::afw::math::LeastSquares::Impl::setRank ( Eigen::MatrixBase< D > const &  values)
inline

Definition at line 72 of file LeastSquares.cc.

72  {
73  double cond = threshold * values[0];
74  if (cond <= 0.0) {
75  rank = 0;
76  } else {
77  for (rank = dimension; (rank > 1) && (values[rank - 1] < cond); --rank)
78  ;
79  }
80  }

◆ updateCovariance()

virtual void lsst::afw::math::LeastSquares::Impl::updateCovariance ( )
pure virtual

◆ updateDiagnostic()

virtual void lsst::afw::math::LeastSquares::Impl::updateDiagnostic ( )
pure virtual

◆ updateRank()

virtual void lsst::afw::math::LeastSquares::Impl::updateRank ( )
pure virtual

◆ updateSolution()

virtual void lsst::afw::math::LeastSquares::Impl::updateSolution ( )
pure virtual

Member Data Documentation

◆ covariance

ndarray::Array<double, 2, 2> lsst::afw::math::LeastSquares::Impl::covariance

Definition at line 68 of file LeastSquares.cc.

◆ data

Eigen::VectorXd lsst::afw::math::LeastSquares::Impl::data

Definition at line 63 of file LeastSquares.cc.

◆ design

Eigen::MatrixXd lsst::afw::math::LeastSquares::Impl::design

Definition at line 62 of file LeastSquares.cc.

◆ diagnostic

ndarray::Array<double, 1, 1> lsst::afw::math::LeastSquares::Impl::diagnostic

Definition at line 69 of file LeastSquares.cc.

◆ dimension

int lsst::afw::math::LeastSquares::Impl::dimension

Definition at line 56 of file LeastSquares.cc.

◆ factorization

Factorization lsst::afw::math::LeastSquares::Impl::factorization

Definition at line 58 of file LeastSquares.cc.

◆ fisher

Eigen::MatrixXd lsst::afw::math::LeastSquares::Impl::fisher

Definition at line 64 of file LeastSquares.cc.

◆ rank

int lsst::afw::math::LeastSquares::Impl::rank

Definition at line 57 of file LeastSquares.cc.

◆ rhs

Eigen::VectorXd lsst::afw::math::LeastSquares::Impl::rhs

Definition at line 65 of file LeastSquares.cc.

◆ solution

ndarray::Array<double, 1, 1> lsst::afw::math::LeastSquares::Impl::solution

Definition at line 67 of file LeastSquares.cc.

◆ state

int lsst::afw::math::LeastSquares::Impl::state

Definition at line 55 of file LeastSquares.cc.

◆ threshold

double lsst::afw::math::LeastSquares::Impl::threshold

Definition at line 60 of file LeastSquares.cc.

◆ whichDiagnostic

Factorization lsst::afw::math::LeastSquares::Impl::whichDiagnostic

Definition at line 59 of file LeastSquares.cc.


The documentation for this class was generated from the following file: