LSST Applications  21.0.0+04719a4bac,21.0.0-1-ga51b5d4+f5e6047307,21.0.0-11-g2b59f77+a9c1acf22d,21.0.0-11-ga42c5b2+86977b0b17,21.0.0-12-gf4ce030+76814010d2,21.0.0-13-g1721dae+760e7a6536,21.0.0-13-g3a573fe+768d78a30a,21.0.0-15-g5a7caf0+f21cbc5713,21.0.0-16-g0fb55c1+b60e2d390c,21.0.0-19-g4cded4ca+71a93a33c0,21.0.0-2-g103fe59+bb20972958,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+3ad5d60fb1,21.0.0-2-g7f82c8f+8babb168e8,21.0.0-2-g8f08a60+06509c8b61,21.0.0-2-g8faa9b5+616205b9df,21.0.0-2-ga326454+8babb168e8,21.0.0-2-gde069b7+5e4aea9c2f,21.0.0-2-gecfae73+1d3a86e577,21.0.0-2-gfc62afb+3ad5d60fb1,21.0.0-25-g1d57be3cd+e73869a214,21.0.0-3-g357aad2+ed88757d29,21.0.0-3-g4a4ce7f+3ad5d60fb1,21.0.0-3-g4be5c26+3ad5d60fb1,21.0.0-3-g65f322c+e0b24896a3,21.0.0-3-g7d9da8d+616205b9df,21.0.0-3-ge02ed75+a9c1acf22d,21.0.0-4-g591bb35+a9c1acf22d,21.0.0-4-g65b4814+b60e2d390c,21.0.0-4-gccdca77+0de219a2bc,21.0.0-4-ge8a399c+6c55c39e83,21.0.0-5-gd00fb1e+05fce91b99,21.0.0-6-gc675373+3ad5d60fb1,21.0.0-64-g1122c245+4fb2b8f86e,21.0.0-7-g04766d7+cd19d05db2,21.0.0-7-gdf92d54+04719a4bac,21.0.0-8-g5674e7b+d1bd76f71f,master-gac4afde19b+a9c1acf22d,w.2021.13
LSST Data Management Base Package
PixelFitRegion.h
Go to the documentation of this file.
1 // -*- lsst-c++ -*-
2 /*
3  * LSST Data Management System
4  * Copyright 2015-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_PixelFitRegion_h_INCLUDED
25 #define LSST_MEAS_MODELFIT_PixelFitRegion_h_INCLUDED
26 
27 #include "lsst/pex/config.h"
29 #include "lsst/geom/Point.h"
30 #include "lsst/afw/image/Mask.h"
32 #include "lsst/afw/geom/ellipses.h"
33 
34 namespace lsst { namespace meas { namespace modelfit {
35 
36 
38 
40  nKronRadii(1.5),
41  nPsfSigmaMin(4.0),
42  nPsfSigmaGrow(2.0),
43  nFitRadiiMin(1.0),
44  nFitRadiiMax(3.0),
45  maxArea(100000),
47  {
48  badMaskPlanes.push_back("EDGE");
49  badMaskPlanes.push_back("SAT");
50  badMaskPlanes.push_back("BAD");
51  badMaskPlanes.push_back("NO_DATA");
52  }
53 
55  nKronRadii, double,
56  "Use this multiple of the Kron ellipse to set the fit region (for the final fit region, "
57  "subject to the nFitRadiiMin and nFitRadiiMax constraints)."
58  );
59 
61  nPsfSigmaMin, double,
62  "If the Kron radius is less than this multiple of the PSF width, ignore it and fall back "
63  "to a PSF-oriented ellipse scaled to match the area of the footprint or this radius "
64  "(whichever is larger)."
65  );
66 
68  nPsfSigmaGrow, double,
69  "Grow the initial fit ellipses by this factor before comparing with the Kron/Footprint region"
70  );
71 
73  nFitRadiiMin, double,
74  "Use this multiple of the initial fit ellipse then grow by the PSF width "
75  "to determine the minimum final fit region size."
76  );
77 
79  nFitRadiiMax, double,
80  "Use this multiple of the initial fit ellipse then grow by the PSF width "
81  "to determine the maximum final fit region size."
82  );
83 
85  maxArea, int,
86  "Abort if the fit region grows beyond this many pixels."
87  );
88 
91  "Mask planes that indicate pixels that should be ignored in the fit."
92  );
93 
95  maxBadPixelFraction, double,
96  "Maximum fraction of pixels that may be ignored due to masks; "
97  "more than this and we don't even try."
98  );
99 
100 };
101 
102 
104 public:
105 
107  PixelFitRegionControl const & ctrl,
109  afw::geom::ellipses::Quadrupole const & psfMoments,
110  Scalar kronRadius,
111  int footprintArea
112  );
113 
115  PixelFitRegionControl const & ctrl,
117  );
118 
120  afw::geom::ellipses::Quadrupole const & deconvolved,
121  afw::geom::ellipses::Quadrupole const & psfMoments
122  );
123 
124  void applyMask(afw::image::Mask<> const & mask, geom::Point2D const & center);
125 
130  bool maxArea;
134 
135 private:
136  PixelFitRegionControl _ctrl;
137  afw::image::MaskPixel _badPixelMask;
138 };
139 
140 
141 }}} // lsst::meas::modelfit
142 
143 #endif // !LSST_MEAS_MODELFIT_PixelFitRegion_h_INCLUDED
afw::table::Key< afw::table::Array< MaskPixelT > > mask
#define PTR(...)
Definition: base.h:41
Class to describe the properties of a detected object from an image.
Definition: Footprint.h:63
An ellipse core with quadrupole moments as parameters.
Definition: Quadrupole.h:47
Represent a 2-dimensional array of bitmask pixels.
Definition: Mask.h:77
afw::geom::ellipses::Quadrupole ellipse
PixelFitRegion(PixelFitRegionControl const &ctrl, afw::geom::ellipses::Quadrupole const &moments, afw::geom::ellipses::Quadrupole const &psfMoments, Scalar kronRadius, int footprintArea)
void applyMask(afw::image::Mask<> const &mask, geom::Point2D const &center)
boost::shared_ptr< afw::detection::Footprint > footprint
bool applyEllipse(afw::geom::ellipses::Quadrupole const &deconvolved, afw::geom::ellipses::Quadrupole const &psfMoments)
PixelFitRegion(PixelFitRegionControl const &ctrl, afw::geom::ellipses::Quadrupole const &ellipse)
#define LSST_CONTROL_FIELD(NAME, TYPE, DOC)
A preprocessor macro used to define fields in C++ "control object" structs.
Definition: config.h:43
double Scalar
Typedefs to be used for probability and parameter values.
Definition: common.h:44
A base class for image defects.
T push_back(T... args)
VectorQ moments
Definition: simpleShape.cc:151
double nFitRadiiMax
"Use this multiple of the initial fit ellipse then grow by the PSF width " "to determine the maximum ...
double maxBadPixelFraction
"Maximum fraction of pixels that may be ignored due to masks; " "more than this and we don't even try...
double nKronRadii
"Use this multiple of the Kron ellipse to set the fit region (for the final fit region,...
double nPsfSigmaGrow
"Grow the initial fit ellipses by this factor before comparing with the Kron/Footprint region" ;
std::vector< std::string > badMaskPlanes
"Mask planes that indicate pixels that should be ignored in the fit." ;
double nFitRadiiMin
"Use this multiple of the initial fit ellipse then grow by the PSF width " "to determine the minimum ...
int maxArea
"Abort if the fit region grows beyond this many pixels." ;
double nPsfSigmaMin
"If the Kron radius is less than this multiple of the PSF width, ignore it and fall back " "to a PSF-...