LSSTApplications  17.0+11,17.0+34,17.0+56,17.0+57,17.0+59,17.0+7,17.0-1-g377950a+33,17.0.1-1-g114240f+2,17.0.1-1-g4d4fbc4+28,17.0.1-1-g55520dc+49,17.0.1-1-g5f4ed7e+52,17.0.1-1-g6dd7d69+17,17.0.1-1-g8de6c91+11,17.0.1-1-gb9095d2+7,17.0.1-1-ge9fec5e+5,17.0.1-1-gf4e0155+55,17.0.1-1-gfc65f5f+50,17.0.1-1-gfc6fb1f+20,17.0.1-10-g87f9f3f+1,17.0.1-11-ge9de802+16,17.0.1-16-ga14f7d5c+4,17.0.1-17-gc79d625+1,17.0.1-17-gdae4c4a+8,17.0.1-2-g26618f5+29,17.0.1-2-g54f2ebc+9,17.0.1-2-gf403422+1,17.0.1-20-g2ca2f74+6,17.0.1-23-gf3eadeb7+1,17.0.1-3-g7e86b59+39,17.0.1-3-gb5ca14a,17.0.1-3-gd08d533+40,17.0.1-30-g596af8797,17.0.1-4-g59d126d+4,17.0.1-4-gc69c472+5,17.0.1-6-g5afd9b9+4,17.0.1-7-g35889ee+1,17.0.1-7-gc7c8782+18,17.0.1-9-gc4bbfb2+3,w.2019.22
LSSTDataManagementBasePackage
Public Member Functions | Static Public Member Functions | List of all members
lsst::shapelet::ConversionMatrix Class Reference

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...
 

Detailed Description

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.

Constructor & Destructor Documentation

◆ ConversionMatrix()

lsst::shapelet::ConversionMatrix::ConversionMatrix ( BasisTypeEnum  input,
BasisTypeEnum  output,
int  order 
)
explicit

Construct a conversion matrix that maps the input basis to the output basis.

Member Function Documentation

◆ buildDenseMatrix()

Eigen::MatrixXd lsst::shapelet::ConversionMatrix::buildDenseMatrix ( ) const

Construct the full conversion matrix (should just be used for testing).

◆ convertCoefficientVector()

static void lsst::shapelet::ConversionMatrix::convertCoefficientVector ( ndarray::Array< double, 1 > const &  array,
BasisTypeEnum  input,
BasisTypeEnum  output,
int  order 
)
static

Convert a coefficient vector between basis types in-place.

◆ convertOperationVector()

static void lsst::shapelet::ConversionMatrix::convertOperationVector ( ndarray::Array< double, 1 > const &  array,
BasisTypeEnum  input,
BasisTypeEnum  output,
int  order 
)
static

Convert an operation (evaluation, integration) vector between basis types in-place.

◆ getBlock()

Eigen::MatrixXd lsst::shapelet::ConversionMatrix::getBlock ( int  n) const

Return a block of the block-diagonal conversion matrix.

◆ multiplyOnLeft()

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.

◆ multiplyOnRight()

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.


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