LSST Applications g063fba187b+cac8b7c890,g0f08755f38+6aee506743,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g1a2382251a+b4475c5878,g1dcb35cd9c+8f9bc1652e,g20f6ffc8e0+6aee506743,g217e2c1bcf+73dee94bd0,g28da252d5a+1f19c529b9,g2bbee38e9b+3f2625acfc,g2bc492864f+3f2625acfc,g3156d2b45e+6e55a43351,g32e5bea42b+1bb94961c2,g347aa1857d+3f2625acfc,g35bb328faa+a8ce1bb630,g3a166c0a6a+3f2625acfc,g3e281a1b8c+c5dd892a6c,g3e8969e208+a8ce1bb630,g414038480c+5927e1bc1e,g41af890bb2+8a9e676b2a,g7af13505b9+809c143d88,g80478fca09+6ef8b1810f,g82479be7b0+f568feb641,g858d7b2824+6aee506743,g89c8672015+f4add4ffd5,g9125e01d80+a8ce1bb630,ga5288a1d22+2903d499ea,gb58c049af0+d64f4d3760,gc28159a63d+3f2625acfc,gcab2d0539d+b12535109e,gcf0d15dbbd+46a3f46ba9,gda6a2b7d83+46a3f46ba9,gdaeeff99f8+1711a396fd,ge79ae78c31+3f2625acfc,gef2f8181fd+0a71e47438,gf0baf85859+c1f95f4921,gfa517265be+6aee506743,gfa999e8aa5+17cd334064,w.2024.51
LSST Data Management Base Package
Loading...
Searching...
No Matches
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"
33
34namespace 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 {
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
104public:
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
134
135private:
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
An ellipse core with quadrupole moments as parameters.
Definition Quadrupole.h:47
Represent a 2-dimensional array of bitmask pixels.
Definition Mask.h:82
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)
bool applyEllipse(afw::geom::ellipses::Quadrupole const &deconvolved, afw::geom::ellipses::Quadrupole const &psfMoments)
PixelFitRegion(PixelFitRegionControl const &ctrl, afw::geom::ellipses::Quadrupole const &ellipse)
std::shared_ptr< afw::detection::Footprint > footprint
#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
T push_back(T... args)
VectorQ moments
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-...