LSST Applications g180d380827+78227d2bc4,g2079a07aa2+86d27d4dc4,g2305ad1205+bdd7851fe3,g2bbee38e9b+c6a8a0fb72,g337abbeb29+c6a8a0fb72,g33d1c0ed96+c6a8a0fb72,g3a166c0a6a+c6a8a0fb72,g3d1719c13e+260d7c3927,g3ddfee87b4+723a6db5f3,g487adcacf7+29e55ea757,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+9443c4b912,g62aa8f1a4b+7e2ea9cd42,g858d7b2824+260d7c3927,g864b0138d7+8498d97249,g95921f966b+dffe86973d,g991b906543+260d7c3927,g99cad8db69+4809d78dd9,g9c22b2923f+e2510deafe,g9ddcbc5298+9a081db1e4,ga1e77700b3+03d07e1c1f,gb0e22166c9+60f28cb32d,gb23b769143+260d7c3927,gba4ed39666+c2a2e4ac27,gbb8dafda3b+e22341fd87,gbd998247f1+585e252eca,gc120e1dc64+713f94b854,gc28159a63d+c6a8a0fb72,gc3e9b769f7+385ea95214,gcf0d15dbbd+723a6db5f3,gdaeeff99f8+f9a426f77a,ge6526c86ff+fde82a80b9,ge79ae78c31+c6a8a0fb72,gee10cc3b42+585e252eca,w.2024.18
LSST Data Management Base Package
Loading...
Searching...
No Matches
DoubleShapeletPsfApprox.h
Go to the documentation of this file.
1// -*- lsst-c++ -*-
2/*
3 * LSST Data Management System
4 * Copyright 2008-2016 LSST/AURA.
5 *
6 * This product includes software developed by the
7 * LSST Project (http://www.lsst.org/).
8 *
9 * This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the LSST License Statement and
20 * the GNU General Public License along with this program. If not,
21 * see <http://www.lsstcorp.org/LegalNotices/>.
22 */
23
24#ifndef LSST_MEAS_MODELFIT_DoubleShapeletPsfApprox_h_INCLUDED
25#define LSST_MEAS_MODELFIT_DoubleShapeletPsfApprox_h_INCLUDED
26
27#include "lsst/afw/geom.h"
32
33namespace lsst { namespace meas { namespace modelfit {
34
39public:
40
46
47 LSST_CONTROL_FIELD(innerOrder, int, "Shapelet order of inner expansion (0 == Gaussian)");
48
49 LSST_CONTROL_FIELD(outerOrder, int, "Shapelet order of outer expansion (0 == Gaussian)");
50
51 LSST_CONTROL_FIELD(radiusRatio, double, "Initial outer radius divided by inner radius");
52
54 peakRatio, double,
55 "Initial outer Gaussian peak height divided by inner Gaussian peak height"
56 );
57
59 minRadius, double,
60 "Don't allow the semi-minor radius of any component to drop below this value (pixels)"
61 );
62
64 minRadiusDiff, double,
65 "Don't allow the determinant radii of the two components to differ by less than this (pixels)"
66 );
67
70 "Don't allow the semi-major radius of any component to go above this fraction of the PSF image width"
71 );
72
75 "Configuration of the optimizer used by DoubleShapeletPsfsApproxAlgorithm::fitProfile()."
76 );
77
78};
79
80
97public:
98
99 // Structures and routines to manage flaghandler
105
107
109
125 Control const & ctrl,
126 std::string const & name,
127 afw::table::Schema & schema
128 );
129
138
162 static void fitMoments(
164 Control const & ctrl,
165 afw::image::Image<Scalar> const & psfImage
166 );
167
197 Control const & ctrl,
198 afw::image::Image<Scalar> const & psfImage
199 );
200
201
218 static void fitProfile(
220 Control const & ctrl,
221 afw::image::Image<Scalar> const & psfImage
222 );
223
238 static void fitShapelets(
240 Control const & ctrl,
241 afw::image::Image<Scalar> const & psfImage
242 );
243
250 afw::table::SourceRecord & measRecord,
251 afw::image::Exposure<float> const & exposure
252 ) const;
253
257 void fail(
258 afw::table::SourceRecord & measRecord,
260 ) const;
261
262private:
263 Control _ctrl;
264 meas::base::SafeCentroidExtractor _centroidExtractor;
267};
268
269}}} // namespace lsst::meas::modelfit
270
271#endif // !LSST_MEAS_MODELFIT_DoubleShapeletPsfApprox_h_INCLUDED
py::object result
Definition _schema.cc:429
An ellipse defined by an arbitrary BaseCore and a center point.
Definition Ellipse.h:51
A class to contain the data, WCS, and other information needed to describe an image of the sky.
Definition Exposure.h:72
A class to represent a 2-dimensional array of pixels.
Definition Image.h:51
Defines the fields and offsets for a table.
Definition Schema.h:51
Record class that contains measurements made on a single exposure.
Definition Source.h:78
vector-type utility class to build a collection of FlagDefinitions
Definition FlagHandler.h:60
Utility class for handling flag fields that indicate the failure modes of an algorithm.
Exception to be thrown when a measurement algorithm experiences a known failure mode.
Definition exceptions.h:48
Utility class for measurement algorithms that extracts a position from the Centroid slot and handles ...
An abstract base classes for which the same implementation can be used for both SingleFrameAlgorithm ...
Definition Algorithm.h:170
An algorithm that fits a 2-component shapelet approximation to the PSF model.
static base::FlagDefinitionList const & getFlagDefinitions()
static std::shared_ptr< OptimizerObjective > makeObjective(afw::geom::ellipses::Ellipse const &moments, Control const &ctrl, afw::image::Image< Scalar > const &psfImage)
Return an Objective object that can be used to fit the profile of the model.
DoubleShapeletPsfApproxAlgorithm(Control const &ctrl, std::string const &name, afw::table::Schema &schema)
Failure modes passed by MeasurementErrors thrown by this class.
static shapelet::MultiShapeletFunction initializeResult(Control const &ctrl)
Create a MultiShapeletFunction with orders and radii and amplitude ratios from the control object.
static void fitShapelets(shapelet::MultiShapeletFunction &result, Control const &ctrl, afw::image::Image< Scalar > const &psfImage)
Update a MultiShapeletFunction's higher-order shapelet terms, holding everything else fixed.
static void fitMoments(shapelet::MultiShapeletFunction &result, Control const &ctrl, afw::image::Image< Scalar > const &psfImage)
Update a MultiShapeletFunction's ellipses to match the first and second moments of a PSF image.
void fail(afw::table::SourceRecord &measRecord, lsst::meas::base::MeasurementError *error=nullptr) const
Handle failures caught by the measurement plugin system, setting failure flags as appropriate.
static void fitProfile(shapelet::MultiShapeletFunction &result, Control const &ctrl, afw::image::Image< Scalar > const &psfImage)
Update a MultiShapeletFunction's zeroth-order profile by fitting radii and amplitudes.
void measure(afw::table::SourceRecord &measRecord, afw::image::Exposure< float > const &exposure) const
Run all fitting stages on the Psf attached to the given Exposure, saving the results in measRecord.
Control object used to configure a 2-shapelet fit to a PSF model; see DoubleShapeletPsfApproxAlgorith...
OptimizerControl optimizer
"Configuration of the optimizer used by DoubleShapeletPsfsApproxAlgorithm::fitProfile()....
int innerOrder
"Shapelet order of inner expansion (0 == Gaussian)" ;
double maxRadiusBoxFraction
"Don't allow the semi-major radius of any component to go above this fraction of the PSF image width"...
double minRadius
"Don't allow the semi-minor radius of any component to drop below this value (pixels)" ;
double radiusRatio
"Initial outer radius divided by inner radius" ;
double minRadiusDiff
"Don't allow the determinant radii of the two components to differ by less than this (pixels)" ;
int outerOrder
"Shapelet order of outer expansion (0 == Gaussian)" ;
double peakRatio
"Initial outer Gaussian peak height divided by inner Gaussian peak height" ;
Configuration object for Optimizer.
Definition optimizer.h:187
A multi-scale shapelet function.
Class that maps MultiShapeletFunction objects to fields in afw::table objects.
#define LSST_NESTED_CONTROL_FIELD(NAME, MODULE, TYPE, DOC)
A preprocessor macro used to define fields in C++ "control object" structs, for nested control object...
Definition config.h:69
#define LSST_CONTROL_FIELD(NAME, TYPE, DOC)
A preprocessor macro used to define fields in C++ "control object" structs.
Definition config.h:43
VectorQ moments
Simple class used to define and document flags The name and doc constitute the identity of the FlagDe...
Definition FlagHandler.h:40