LSSTApplications  10.0-2-g4f67435,11.0.rc2+1,11.0.rc2+12,11.0.rc2+3,11.0.rc2+4,11.0.rc2+5,11.0.rc2+6,11.0.rc2+7,11.0.rc2+8
LSSTDataManagementBasePackage
Defect.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 #if !defined(LSST_AFW_IMAGE_DEFECT_H)
26 #define LSST_AFW_IMAGE_DEFECT_H
27 
30 #include <limits>
31 #include <vector>
32 #include "lsst/afw/geom.h"
33 #include "lsst/afw/image/Utils.h"
34 
35 namespace lsst {
36 namespace afw {
37 namespace image {
38 
42 class DefectBase {
43 public:
44  typedef boost::shared_ptr<DefectBase> Ptr;
45 
46  explicit DefectBase(
47  const geom::Box2I & bbox
48  ) : _bbox(bbox) { }
49  virtual ~DefectBase() {}
50 
51  geom::Box2I const & getBBox() const { return _bbox; }
52  int getX0() const { return _bbox.getMinX(); }
53  int getX1() const { return _bbox.getMaxX(); }
54  int getY0() const { return _bbox.getMinY(); }
55  int getY1() const { return _bbox.getMaxY(); }
56 
57 
58  void clip(geom::Box2I const & bbox) {_bbox.clip(bbox);}
59 
63  void shift(int dx,
64  int dy
65  ) {
66  _bbox.shift(geom::Extent2I(dx, dy));
67  }
68  void shift(geom::Extent2I const & d) {_bbox.shift(d);}
69 private:
71 };
72 
73 }}}
74 
75 #endif
geom::Box2I _bbox
Bounding box for bad pixels.
Definition: Defect.h:70
int getY1() const
Return the Defect&#39;s top row.
Definition: Defect.h:55
An include file to include the header files for lsst::afw::geom.
void clip(Box2I const &other)
Shrink this to ensure that other.contains(*this).
int getY0() const
Return the Defect&#39;s bottom row.
Definition: Defect.h:54
void shift(geom::Extent2I const &d)
Definition: Defect.h:68
Encapsulate information about a bad portion of a detector.
Definition: Defect.h:42
int getMinY() const
Definition: Box.h:125
int getMaxX() const
Definition: Box.h:128
An integer coordinate rectangle.
Definition: Box.h:53
table::Key< table::Array< Kernel::Pixel > > image
Definition: FixedKernel.cc:117
void clip(geom::Box2I const &bbox)
Definition: Defect.h:58
DefectBase(const geom::Box2I &bbox)
Definition: Defect.h:46
void shift(Extent2I const &offset)
Shift the position of the box by the given offset.
int getX0() const
Return the Defect&#39;s left column.
Definition: Defect.h:52
A set of classes of general utility in connection with images.
int getMaxY() const
Definition: Box.h:129
geom::Box2I const & getBBox() const
Return the Defect&#39;s bounding box.
Definition: Defect.h:51
int getMinX() const
Definition: Box.h:124
int getX1() const
Return the Defect&#39;s right column.
Definition: Defect.h:53
void shift(int dx, int dy)
Definition: Defect.h:63
boost::shared_ptr< DefectBase > Ptr
shared pointer to DefectBase
Definition: Defect.h:44