LSST Applications g180d380827+0f66a164bb,g2079a07aa2+86d27d4dc4,g2305ad1205+7d304bc7a0,g29320951ab+500695df56,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g33d1c0ed96+0e5473021a,g3a166c0a6a+0e5473021a,g3ddfee87b4+e42ea45bea,g48712c4677+36a86eeaa5,g487adcacf7+2dd8f347ac,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+c70619cc9d,g5a732f18d5+53520f316c,g5ea96fc03c+341ea1ce94,g64a986408d+f7cd9c7162,g858d7b2824+f7cd9c7162,g8a8a8dda67+585e252eca,g99cad8db69+469ab8c039,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,gb0e22166c9+60f28cb32d,gba4ed39666+c2a2e4ac27,gbb8dafda3b+c92fc63c7e,gbd866b1f37+f7cd9c7162,gc120e1dc64+02c66aa596,gc28159a63d+0e5473021a,gc3e9b769f7+b0068a2d9f,gcf0d15dbbd+e42ea45bea,gdaeeff99f8+f9a426f77a,ge6526c86ff+84383d05b3,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gff1a9f87cc+f7cd9c7162,w.2024.17
LSST Data Management Base Package
Loading...
Searching...
No Matches
KernelCandidate.h
Go to the documentation of this file.
1// -*- lsst-c++ -*-
12#ifndef LSST_IP_DIFFIM_KERNELCANDIDATE_H
13#define LSST_IP_DIFFIM_KERNELCANDIDATE_H
14
15#include <memory>
16#include "Eigen/Core"
17
18#include "lsst/afw/math.h"
19#include "lsst/afw/image.h"
22#include "lsst/daf/base.h"
23
24namespace lsst {
25namespace ip {
26namespace diffim {
27
28
38 template <typename _PixelT>
40 public:
42 typedef _PixelT PixelT; // _after_ afw::math::Kernel::Pixel
43 public:
48
50 ORIG = 0,
51 PCA = 1,
52 RECENT = 2
53 };
54
64 KernelCandidate(float const xCenter,
65 float const yCenter,
66 MaskedImagePtr const& templateMaskedImage,
67 MaskedImagePtr const& scienceMaskedImage,
68 daf::base::PropertySet const& ps);
69
79 KernelCandidate(SourcePtr const& source,
80 MaskedImagePtr const& templateMaskedImage,
81 MaskedImagePtr const& scienceMaskedImage,
82 daf::base::PropertySet const& ps);
84 virtual ~KernelCandidate() {};
85
91 double getCandidateRating() const { return _coreFlux; }
95 SourcePtr getSource() const { return _source; }
99 MaskedImagePtr getTemplateMaskedImage() {return _templateMaskedImage;}
100 MaskedImagePtr getScienceMaskedImage() {return _scienceMaskedImage;}
101
107 double getBackground(CandidateSwitch cand) const;
108 double getKsum(CandidateSwitch cand) const;
110 std::shared_ptr<ImageT const> getImage() const; // For SpatialCellImageCandidate
112
117
125 double background
126 );
127
128 bool isInitialized() const {return _isInitialized;}
129
130
165 /*
166 * @note This method uses an estimate of the variance which is the
167 * straight difference of the 2 images. If requested in the PropertySet
168 * ("iterateSingleKernel"), the kernel will be rebuilt using the
169 * variance of the difference image resulting from this first
170 * approximate step. This is particularly useful when convolving a
171 * single-depth science image; the variance (and thus resulting kernel)
172 * generally converges after 1 iteration. If
173 * "constantVarianceWeighting" is requested in the PropertySet, no iterations
174 * will be performed even if requested.
175 */
176
177 void build(
178 afw::math::KernelList const& basisList
179 );
180 void build(
181 afw::math::KernelList const& basisList,
182 Eigen::MatrixXd const& hMat
183 );
184
185 private:
186 MaskedImagePtr _templateMaskedImage;
187 MaskedImagePtr _scienceMaskedImage;
188 VariancePtr _varianceEstimate;
190 SourcePtr _source;
191 double _coreFlux;
192 bool _isInitialized;
193 bool _useRegularization;
194 bool _fitForBackground;
195
196 /* best single raw kernel */
198
199 /* with Pca basis */
201
202 void _buildKernelSolution(afw::math::KernelList const& basisList,
203 Eigen::MatrixXd const& hMat);
204 };
205
206
218 template <typename PixelT>
220 makeKernelCandidate(float const xCenter,
221 float const yCenter,
222 std::shared_ptr<afw::image::MaskedImage<PixelT> > const& templateMaskedImage,
223 std::shared_ptr<afw::image::MaskedImage<PixelT> > const& scienceMaskedImage,
224 daf::base::PropertySet const& ps){
225
227 templateMaskedImage,
228 scienceMaskedImage,
229 ps));
230 }
231
243 template <typename PixelT>
246 std::shared_ptr<afw::image::MaskedImage<PixelT> > const& templateMaskedImage,
247 std::shared_ptr<afw::image::MaskedImage<PixelT> > const& scienceMaskedImage,
248 daf::base::PropertySet const& ps){
249
251 templateMaskedImage,
252 scienceMaskedImage,
253 ps));
254 }
255
256
257}}} // end of namespace lsst::ip::diffim
258
259#endif
Declaration of classes to store the solution for convolution kernels.
A class to represent a 2-dimensional array of pixels.
Definition Image.h:51
A class to manipulate images, masks, and variance as a single object.
Definition MaskedImage.h:74
Base class for candidate objects in a SpatialCell that are able to return an Image of some sort (e....
Class for storing generic metadata.
Definition PropertySet.h:66
Class stored in SpatialCells for spatial Kernel fitting.
std::shared_ptr< ImageT const > getImage() const
std::shared_ptr< afw::image::MaskedImage< PixelT > > MaskedImagePtr
std::shared_ptr< afw::image::Image< afw::image::VariancePixel > > VariancePtr
virtual ~KernelCandidate()
Destructor.
afw::image::Image< afw::math::Kernel::Pixel > ImageT
afw::image::MaskedImage< PixelT > getDifferenceImage(CandidateSwitch cand)
Calculate associated difference image using internal solutions.
double getCandidateRating() const
Return Candidate rating.
std::shared_ptr< KernelCandidate > Ptr
MaskedImagePtr getTemplateMaskedImage()
Return pointers to the image pixels used in kernel determination.
double getBackground(CandidateSwitch cand) const
double getKsum(CandidateSwitch cand) const
std::shared_ptr< afw::table::SourceRecord > SourcePtr
std::shared_ptr< StaticKernelSolution< PixelT > > getKernelSolution(CandidateSwitch cand) const
std::shared_ptr< afw::math::Kernel > getKernel(CandidateSwitch cand) const
Return results of kernel solution.
KernelCandidate(float const xCenter, float const yCenter, MaskedImagePtr const &templateMaskedImage, MaskedImagePtr const &scienceMaskedImage, daf::base::PropertySet const &ps)
Constructor.
SourcePtr getSource() const
Return the original source.
std::shared_ptr< ImageT > getKernelImage(CandidateSwitch cand) const
void build(afw::math::KernelList const &basisList)
Core functionality of KernelCandidate, to build and fill a KernelSolution.
std::shared_ptr< KernelCandidate< PixelT > > makeKernelCandidate(float const xCenter, float const yCenter, std::shared_ptr< afw::image::MaskedImage< PixelT > > const &templateMaskedImage, std::shared_ptr< afw::image::MaskedImage< PixelT > > const &scienceMaskedImage, daf::base::PropertySet const &ps)
Return a KernelCandidate pointer of the right sort.