LSST Applications g0b6bd0c080+a72a5dd7e6,g1182afd7b4+2a019aa3bb,g17e5ecfddb+2b8207f7de,g1d67935e3f+06cf436103,g38293774b4+ac198e9f13,g396055baef+6a2097e274,g3b44f30a73+6611e0205b,g480783c3b1+98f8679e14,g48ccf36440+89c08d0516,g4b93dc025c+98f8679e14,g5c4744a4d9+a302e8c7f0,g613e996a0d+e1c447f2e0,g6c8d09e9e7+25247a063c,g7271f0639c+98f8679e14,g7a9cd813b8+124095ede6,g9d27549199+a302e8c7f0,ga1cf026fa3+ac198e9f13,ga32aa97882+7403ac30ac,ga786bb30fb+7a139211af,gaa63f70f4e+9994eb9896,gabf319e997+ade567573c,gba47b54d5d+94dc90c3ea,gbec6a3398f+06cf436103,gc6308e37c7+07dd123edb,gc655b1545f+ade567573c,gcc9029db3c+ab229f5caf,gd01420fc67+06cf436103,gd877ba84e5+06cf436103,gdb4cecd868+6f279b5b48,ge2d134c3d5+cc4dbb2e3f,ge448b5faa6+86d1ceac1d,gecc7e12556+98f8679e14,gf3ee170dca+25247a063c,gf4ac96e456+ade567573c,gf9f5ea5b4d+ac198e9f13,gff490e6085+8c2580be5c,w.2022.27
LSST Data Management Base Package
|
Conversions between shapelet basis types. More...
#include <ConversionMatrix.h>
Public Member Functions | |
Eigen::MatrixXd | getBlock (int n) const |
Return a block of the block-diagonal conversion matrix. More... | |
Eigen::MatrixXd | buildDenseMatrix () const |
Construct the full conversion matrix (should just be used for testing). More... | |
void | multiplyOnLeft (ndarray::Array< double, 1 > const &array) const |
Multiply the given array by the conversion matrix on the left in-place. More... | |
void | multiplyOnRight (ndarray::Array< double, 1 > const &array) const |
Multiply the given array by the conversion matrix on the right in-place. More... | |
ConversionMatrix (BasisTypeEnum input, BasisTypeEnum output, int order) | |
Construct a conversion matrix that maps the input basis to the output basis. More... | |
Static Public Member Functions | |
static void | convertCoefficientVector (ndarray::Array< double, 1 > const &array, BasisTypeEnum input, BasisTypeEnum output, int order) |
Convert a coefficient vector between basis types in-place. More... | |
static void | convertOperationVector (ndarray::Array< double, 1 > const &array, BasisTypeEnum input, BasisTypeEnum output, int order) |
Convert an operation (evaluation, integration) vector between basis types in-place. More... | |
Conversions between shapelet basis types.
The basis conversion matrix is block-diagonal and only needs to be computed once, so we cache the blocks in a hidden singleton and provide operations that act on shapelet matrices while taking advantage of the sparseness of the conversion.
Definition at line 42 of file ConversionMatrix.h.
|
explicit |
Construct a conversion matrix that maps the input basis to the output basis.
Eigen::MatrixXd lsst::shapelet::ConversionMatrix::buildDenseMatrix | ( | ) | const |
Construct the full conversion matrix (should just be used for testing).
|
static |
Convert a coefficient vector between basis types in-place.
|
static |
Convert an operation (evaluation, integration) vector between basis types in-place.
Eigen::MatrixXd lsst::shapelet::ConversionMatrix::getBlock | ( | int | n | ) | const |
Return a block of the block-diagonal conversion matrix.
void lsst::shapelet::ConversionMatrix::multiplyOnLeft | ( | ndarray::Array< double, 1 > const & | array | ) | const |
Multiply the given array by the conversion matrix on the left in-place.
void lsst::shapelet::ConversionMatrix::multiplyOnRight | ( | ndarray::Array< double, 1 > const & | array | ) | const |
Multiply the given array by the conversion matrix on the right in-place.