LSST Applications 27.0.0,g0265f82a02+469cd937ee,g02d81e74bb+21ad69e7e1,g1470d8bcf6+cbe83ee85a,g2079a07aa2+e67c6346a6,g212a7c68fe+04a9158687,g2305ad1205+94392ce272,g295015adf3+81dd352a9d,g2bbee38e9b+469cd937ee,g337abbeb29+469cd937ee,g3939d97d7f+72a9f7b576,g487adcacf7+71499e7cba,g50ff169b8f+5929b3527e,g52b1c1532d+a6fc98d2e7,g591dd9f2cf+df404f777f,g5a732f18d5+be83d3ecdb,g64a986408d+21ad69e7e1,g858d7b2824+21ad69e7e1,g8a8a8dda67+a6fc98d2e7,g99cad8db69+f62e5b0af5,g9ddcbc5298+d4bad12328,ga1e77700b3+9c366c4306,ga8c6da7877+71e4819109,gb0e22166c9+25ba2f69a1,gb6a65358fc+469cd937ee,gbb8dafda3b+69d3c0e320,gc07e1c2157+a98bf949bb,gc120e1dc64+615ec43309,gc28159a63d+469cd937ee,gcf0d15dbbd+72a9f7b576,gdaeeff99f8+a38ce5ea23,ge6526c86ff+3a7c1ac5f1,ge79ae78c31+469cd937ee,gee10cc3b42+a6fc98d2e7,gf1cff7945b+21ad69e7e1,gfbcc870c63+9a11dc8c8f
LSST Data Management Base Package
Loading...
Searching...
No Matches
MaskDict.h
Go to the documentation of this file.
1/*
2 * Developed for the LSST Data Management System.
3 * This product includes software developed by the LSST Project
4 * (https://www.lsst.org).
5 * See the COPYRIGHT file at the top-level directory of this distribution
6 * for details of code ownership.
7 *
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation, either version 3 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program. If not, see <https://www.gnu.org/licenses/>.
20 */
21
22#ifndef LSST_AFW_IMAGE_DETAIL_MASKDICT_H
23#define LSST_AFW_IMAGE_DETAIL_MASKDICT_H
24
25#include <memory>
26#include <map>
27#include "lsst/afw/image/Mask.h"
28
29namespace lsst { namespace afw { namespace image { namespace detail {
30
31/*
32 * MaskDict is the internal object that relates Mask's string plane names
33 * to bit IDs.
34 *
35 * The Mask public API only uses MaskPlaneDict, which is just a typedef
36 * to std::map. A MaskDict holds this MaskPlaneDict, limiting non-const
37 * access to just the add() and erase() methods in order to maintain
38 * a hash of the full dictionary for fast comparison between MaskDicts.
39 *
40 * In order to maximize consistency of mask plane definitions across different
41 * Mask instances, MaskDict also maintains a global list of all active
42 * MaskDict instances. When a plane is added to Mask, it is typically
43 * automatically added to *all* active Mask instances that do not already use
44 * that bit (via MaskDict::addMaskPlane) as well as a default MaskDict that is
45 * used when constructing future Mask instances. In contrast, when a plane is
46 * removed, it typically only affects that Mask, and if that Mask is currently
47 * using the default MaskDict, the default is redefined to a copy prior to
48 * the plane's removal (via detachDefault).
49 *
50 * To maintain that global state, all MaskDicts must be held by shared_ptr,
51 * and hence MaskDict's constructors are private, and static or instance
52 * methods that return shared_ptr are provided to replace them.
53 *
54 * MaskDict is an implementation detail (albeit and important one) and hence
55 * its "documentation" is intentionally in the form of regular comments
56 * rather than Doxygen-parsed blocks. It is also not available from Python.
57 *
58 * With the exception of addMaskPlane, all MaskDict methods provide strong
59 * exception safety.
60 */
61class MaskDict final {
62public:
63
64 using value_type = MaskPlaneDict::value_type;
65 using const_iterator = MaskPlaneDict::const_iterator;
66
67 // Return a new MaskDict with the same plane definitions as the given
68 // MaskPlaneDict, or return the default mask dict if it is empty.
70
71 // Return the default MaskDict to be used for new Mask instances.
73
74 // Set the default MaskDict.
75 static void setDefault(std::shared_ptr<MaskDict> dict);
76
77 /*
78 * Set the default MaskDict to a copy of the current one, returning the
79 * new default.
80 */
82
83 /*
84 * Add the given mask plane to all active MaskDicts for which there is
85 * no conflict, including the default MaskDict.
86 *
87 * MaskDicts that already have a plane with the same name or bit ID
88 * are not affected.
89 *
90 * Provides basic exception safety: mask planes may be added to some
91 * MaskDict instances even if an exception is raised while adding
92 * the mask plane to later ones (though the only exception that could
93 * be thrown in practice is std::bad_alloc).
94 */
95 static void addAllMasksPlane(std::string const & name, int bitId);
96
97 // Assignment is disabled; we don't need it.
98 MaskDict & operator=(MaskDict const &) = delete;
99 MaskDict & operator=(MaskDict &&) = delete;
100
101 ~MaskDict() noexcept;
102
103 // Return a deep copy of the MaskDict.
104 std::shared_ptr<MaskDict> clone() const;
105
106 /*
107 * Return an integer bit ID that is not currently used in this MaskDict.
108 *
109 * Always succeeds in returning a new plane (except in the extraordinarily
110 * unlikely case that int overflows), but is is the responsibility of the
111 * caller to check that the Mask pixel size has enough bits for it.
112 */
113 int getUnusedPlane() const;
114
115 /*
116 * Return the bit ID associated with the given mask plane name.
117 *
118 * Returns -1 if no such plane is found.
119 */
120 int getMaskPlane(std::string const & name) const;
121
122 // Write a description of the MaskDict to stdout.
123 void print() const;
124
125 // Fast comparison of MaskDicts, using the hash (and assuming there are
126 // no unlucky collisions).
127 bool operator==(MaskDict const& rhs) const;
128 bool operator!=(MaskDict const& rhs) const { return !(*this == rhs); }
129
130 // Iterators over MaskDict items (yields std::pair<std::string, int>).
131 const_iterator begin() const noexcept { return _dict.begin(); }
132 const_iterator end() const noexcept { return _dict.end(); }
133
134 // Return an iterator to the item with the given name, or end().
135 const_iterator find(std::string const & name) const { return _dict.find(name); }
136
137 // Return the number of planes in this MaskDict.
138 std::size_t size() const noexcept { return _dict.size(); }
139
140 // Return true if the MaskDict contains no mask planes.
141 bool empty() const noexcept { return _dict.empty(); }
142
143 // Return the internal MaskPlaneDict.
144 MaskPlaneDict const & getMaskPlaneDict() const noexcept { return _dict; }
145
146 // Add a mask plane to just this MaskDict.
147 // If a plane with the given name already exists, it is overridden.
148 // Caller is responsible for ensuring that the bit is not in use; if it is,
149 // the MaskDict will be in a corrupted state.
150 void add(std::string const & name, int bitId);
151
152 // Remove the plane with the given name from just this MaskDict.
153 // Does nothing if no such plane exists.
154 void erase(std::string const & name);
155
156 // Remove all planes from this MaskDict.
157 void clear();
158
159private:
160
161 class GlobalState;
162
163 // Add mask planes that should be present on all Masks that don't
164 // explicitly remove them. Called exactly once, when initalizing
165 // GlobalState.
166 void _addInitialMaskPlanes();
167
168 // ALL MaskDict constructors should only be from GlobalState,
169 // in order to ensure the global set of active dictionaries
170 // is kept up-to-date.
171
172 MaskDict();
173
174 explicit MaskDict(MaskPlaneDict const & dict);
175
176 MaskDict(MaskDict const &) = default;
177 MaskDict(MaskDict &&) = default;
178
179 MaskPlaneDict _dict;
180 std::size_t _hash;
181};
182
183}}}} // namespace lsst::afw::image::detail
184
185#endif // !LSST_AFW_IMAGE_DETAIL_MASKDICT_H
T begin(T... args)
int getMaskPlane(std::string const &name) const
Definition MaskDict.cc:176
const_iterator begin() const noexcept
Definition MaskDict.h:131
MaskPlaneDict::const_iterator const_iterator
Definition MaskDict.h:65
static void addAllMasksPlane(std::string const &name, int bitId)
Definition MaskDict.cc:127
static std::shared_ptr< MaskDict > detachDefault()
Definition MaskDict.cc:123
const_iterator end() const noexcept
Definition MaskDict.h:132
std::size_t size() const noexcept
Definition MaskDict.h:138
MaskDict & operator=(MaskDict &&)=delete
static std::shared_ptr< MaskDict > getDefault()
Definition MaskDict.cc:115
std::shared_ptr< MaskDict > clone() const
Definition MaskDict.cc:146
static void setDefault(std::shared_ptr< MaskDict > dict)
Definition MaskDict.cc:119
const_iterator find(std::string const &name) const
Definition MaskDict.h:135
MaskPlaneDict const & getMaskPlaneDict() const noexcept
Definition MaskDict.h:144
void add(std::string const &name, int bitId)
Definition MaskDict.cc:191
MaskDict & operator=(MaskDict const &)=delete
static std::shared_ptr< MaskDict > copyOrGetDefault(MaskPlaneDict const &dict)
Definition MaskDict.cc:111
bool empty() const noexcept
Definition MaskDict.h:141
void erase(std::string const &name)
Definition MaskDict.cc:196
MaskPlaneDict::value_type value_type
Definition MaskDict.h:64
T empty(T... args)
T end(T... args)
T find(T... args)
STL namespace.
T size(T... args)