LSST Applications g0b6bd0c080+a72a5dd7e6,g1182afd7b4+2a019aa3bb,g17e5ecfddb+2b8207f7de,g1d67935e3f+06cf436103,g38293774b4+ac198e9f13,g396055baef+6a2097e274,g3b44f30a73+6611e0205b,g480783c3b1+98f8679e14,g48ccf36440+89c08d0516,g4b93dc025c+98f8679e14,g5c4744a4d9+a302e8c7f0,g613e996a0d+e1c447f2e0,g6c8d09e9e7+25247a063c,g7271f0639c+98f8679e14,g7a9cd813b8+124095ede6,g9d27549199+a302e8c7f0,ga1cf026fa3+ac198e9f13,ga32aa97882+7403ac30ac,ga786bb30fb+7a139211af,gaa63f70f4e+9994eb9896,gabf319e997+ade567573c,gba47b54d5d+94dc90c3ea,gbec6a3398f+06cf436103,gc6308e37c7+07dd123edb,gc655b1545f+ade567573c,gcc9029db3c+ab229f5caf,gd01420fc67+06cf436103,gd877ba84e5+06cf436103,gdb4cecd868+6f279b5b48,ge2d134c3d5+cc4dbb2e3f,ge448b5faa6+86d1ceac1d,gecc7e12556+98f8679e14,gf3ee170dca+25247a063c,gf4ac96e456+ade567573c,gf9f5ea5b4d+ac198e9f13,gff490e6085+8c2580be5c,w.2022.27
LSST Data Management Base Package
ConvolveImage.h
Go to the documentation of this file.
1// -*- LSST-C++ -*-
2
3/*
4 * LSST Data Management System
5 * Copyright 2008, 2009, 2010 LSST Corporation.
6 *
7 * This product includes software developed by the
8 * LSST Project (http://www.lsst.org/).
9 *
10 * This program is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the LSST License Statement and
21 * the GNU General Public License along with this program. If not,
22 * see <http://www.lsstcorp.org/LegalNotices/>.
23 */
24
25#ifndef LSST_AFW_MATH_CONVOLVEIMAGE_H
26#define LSST_AFW_MATH_CONVOLVEIMAGE_H
27/*
28 * Convolve and convolveAtAPoint functions for Image and Kernel
29 *
30 * @todo Consider adding a flag to convolve indicating which specialized version of basicConvolve was used.
31 * This would only be used for unit testing and trace messages suffice (barely), so not a high priority.
32 */
33#include <limits>
34#include <sstream>
35
36#include "lsst/pex/exceptions.h"
40
41namespace lsst {
42namespace afw {
43namespace math {
44
51public:
52 ConvolutionControl(bool doNormalize = true,
53 bool doCopyEdge = false,
55 int maxInterpolationDistance = 10
57 )
58 : _doNormalize(doNormalize),
59 _doCopyEdge(doCopyEdge),
60 _maxInterpolationDistance(maxInterpolationDistance) {}
61
62 bool getDoNormalize() const { return _doNormalize; }
63 bool getDoCopyEdge() const { return _doCopyEdge; }
64 int getMaxInterpolationDistance() const { return _maxInterpolationDistance; };
65
66 void setDoNormalize(bool doNormalize) { _doNormalize = doNormalize; }
67 void setDoCopyEdge(bool doCopyEdge) { _doCopyEdge = doCopyEdge; }
68 void setMaxInterpolationDistance(int maxInterpolationDistance) {
69 _maxInterpolationDistance = maxInterpolationDistance;
70 }
71
72private:
73 bool _doNormalize;
74 bool _doCopyEdge;
76 int _maxInterpolationDistance;
78};
79
102template <typename OutImageT, typename InImageT>
103void scaledPlus(OutImageT& outImage, double c1, InImageT const& inImage1, double c2,
104 InImageT const& inImage2);
105
106template <typename OutImageT, typename InImageT>
107inline typename OutImageT::SinglePixel convolveAtAPoint(
108 typename InImageT::const_xy_locator inImageLocator,
110 int kWidth, int kHeight);
111
112template <typename OutImageT, typename InImageT>
113inline typename OutImageT::SinglePixel convolveAtAPoint(
114 typename InImageT::const_xy_locator inImageLocator,
117
190template <typename OutImageT, typename InImageT, typename KernelT>
191void convolve(OutImageT& convolvedImage, InImageT const& inImage, KernelT const& kernel,
192 ConvolutionControl const& convolutionControl = ConvolutionControl());
193
199template <typename ImageT>
202) {
203 using SinglePixelT = typename ImageT::SinglePixel;
206 : 0);
207}
208
220template <typename MaskedImageT>
221typename MaskedImageT::SinglePixel edgePixel(
224) {
225 using ImagePixelT = typename MaskedImageT::Image::Pixel;
226 using VariancePixelT = typename MaskedImageT::Variance::Pixel;
227
230 : 0;
231 auto maskPixel = MaskedImageT::Mask::getPlaneBitMask("NO_DATA");
234 : 0;
235 return typename MaskedImageT::SinglePixel(imagePixel, maskPixel, variancePixel);
236}
237
238/*
239 * Define inline functions
240 */
241
258template <typename OutImageT, typename InImageT>
259inline typename OutImageT::SinglePixel convolveAtAPoint(
260 typename InImageT::const_xy_locator inImageLocator,
261 image::Image<Kernel::Pixel>::const_xy_locator kernelLocator, int kWidth, int kHeight) {
262 typename OutImageT::SinglePixel outValue = 0;
263 for (int kRow = 0; kRow != kHeight; ++kRow) {
265 kEnd = kernelLocator + image::detail::difference_type(kWidth, 0);
266 kernelLocator != kEnd; ++inImageLocator.x(), ++kernelLocator.x()) {
267 typename Kernel::Pixel const kVal = kernelLocator[0];
268 if (kVal != 0) {
269 outValue += *inImageLocator * kVal;
270 }
271 }
272
273 inImageLocator += image::detail::difference_type(-kWidth, 1);
274 kernelLocator += image::detail::difference_type(-kWidth, 1);
275 }
276
277 return outValue;
278}
279
294template <typename OutImageT, typename InImageT>
295inline typename OutImageT::SinglePixel convolveAtAPoint(typename InImageT::const_xy_locator inImageLocator,
296 std::vector<Kernel::Pixel> const& kernelXList,
297 std::vector<Kernel::Pixel> const& kernelYList) {
298 using k_iter = typename std::vector<Kernel::Pixel>::const_iterator;
299
300 using OutT = typename OutImageT::SinglePixel;
301 OutT outValue = 0;
302 for (double kValY : kernelYList) {
303 OutT outValueY = 0;
304 for (k_iter kernelXIter = kernelXList.begin(), xEnd = kernelXList.end(); kernelXIter != xEnd;
305 ++kernelXIter, ++inImageLocator.x()) {
306 typename Kernel::Pixel const kValX = *kernelXIter;
307 if (kValX != 0) {
308 outValueY += *inImageLocator * kValX;
309 }
310 }
311
312 if (kValY != 0) {
313 outValue += outValueY * kValY;
314 }
315
316 inImageLocator += image::detail::difference_type(-kernelXList.size(), 1);
317 }
318
319 return outValue;
320}
321} // namespace math
322} // namespace afw
323} // namespace lsst
324
325#endif // !defined(LSST_AFW_MATH_CONVOLVEIMAGE_H)
T begin(T... args)
typename _view_t::xy_locator::const_t const_xy_locator
A const_xy_locator.
Definition: ImageBase.h:123
Parameters to control convolution.
Definition: ConvolveImage.h:50
void setDoCopyEdge(bool doCopyEdge)
Definition: ConvolveImage.h:67
void setDoNormalize(bool doNormalize)
Definition: ConvolveImage.h:66
ConvolutionControl(bool doNormalize=true, bool doCopyEdge=false, int maxInterpolationDistance=10)
Definition: ConvolveImage.h:52
void setMaxInterpolationDistance(int maxInterpolationDistance)
Definition: ConvolveImage.h:68
T end(T... args)
T infinity(T... args)
OutImageT::SinglePixel convolveAtAPoint(typename InImageT::const_xy_locator inImageLocator, typename lsst::afw::image::Image< lsst::afw::math::Kernel::Pixel >::const_xy_locator kernelLocator, int kWidth, int kHeight)
Apply convolution kernel to an image at one point.
void scaledPlus(OutImageT &outImage, double c1, InImageT const &inImage1, double c2, InImageT const &inImage2)
Compute the scaled sum of two images.
void convolve(OutImageT &convolvedImage, InImageT const &inImage, KernelT const &kernel, ConvolutionControl const &convolutionControl=ConvolutionControl())
Convolve an Image or MaskedImage with a Kernel, setting pixels of an existing output image.
ImageT::SinglePixel edgePixel(lsst::afw::image::detail::Image_tag)
Return an off-the-edge pixel appropriate for a given Image type.
float Pixel
Typedefs to be used for pixel values.
Definition: common.h:37
A base class for image defects.
T quiet_NaN(T... args)
T size(T... args)
A traits class for MaskedImage.
Definition: MaskedImage.h:50