LSST Applications g00d0e8bbd7+8c5ae1fdc5,g013ef56533+603670b062,g083dd6704c+2e189452a7,g199a45376c+0ba108daf9,g1c5cce2383+bc9f6103a4,g1fd858c14a+cd69ed4fc1,g210f2d0738+c4742f2e9e,g262e1987ae+612fa42d85,g29ae962dfc+83d129e820,g2cef7863aa+aef1011c0b,g35bb328faa+8c5ae1fdc5,g3fd5ace14f+5eaa884f2a,g47891489e3+e32160a944,g53246c7159+8c5ae1fdc5,g5b326b94bb+dcc56af22d,g64539dfbff+c4742f2e9e,g67b6fd64d1+e32160a944,g74acd417e5+c122e1277d,g786e29fd12+668abc6043,g87389fa792+8856018cbb,g88cb488625+47d24e4084,g89139ef638+e32160a944,g8d7436a09f+d14b4ff40a,g8ea07a8fe4+b212507b11,g90f42f885a+e1755607f3,g97be763408+34be90ab8c,g98df359435+ec1fa61bf1,ga2180abaac+8c5ae1fdc5,ga9e74d7ce9+43ac651df0,gbf99507273+8c5ae1fdc5,gc2a301910b+c4742f2e9e,gca7fc764a6+e32160a944,gd7ef33dd92+e32160a944,gdab6d2f7ff+c122e1277d,gdb1e2cdc75+1b18322db8,ge410e46f29+e32160a944,ge41e95a9f2+c4742f2e9e,geaed405ab2+0d91c11c6d,w.2025.44
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
196 afw::geom::ellipses::Ellipse const & moments,
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
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
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
Simple class used to define and document flags The name and doc constitute the identity of the FlagDe...
Definition FlagHandler.h:40