LSST Applications g180d380827+107df2c2fa,g2079a07aa2+86d27d4dc4,g2305ad1205+27ad5d03fa,g2bbee38e9b+c6a8a0fb72,g337abbeb29+c6a8a0fb72,g33d1c0ed96+c6a8a0fb72,g3a166c0a6a+c6a8a0fb72,g3d1719c13e+cc4c7597ef,g487adcacf7+4b0be3ae0a,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+14d443d837,g62aa8f1a4b+588cc723a1,g674612935b+7a21c67e12,g858d7b2824+cc4c7597ef,g991b906543+cc4c7597ef,g99cad8db69+b90e8bab37,g9c22b2923f+e2510deafe,g9ddcbc5298+9a081db1e4,g9fbc5161f1+1dc7c5428e,ga1e77700b3+03d07e1c1f,gb0e22166c9+60f28cb32d,gb23b769143+cc4c7597ef,gba4ed39666+c2a2e4ac27,gbb8dafda3b+52e28152d7,gbd998247f1+585e252eca,gbeadb96d05+a322446fe6,gc120e1dc64+6a70fcc921,gc28159a63d+c6a8a0fb72,gc3e9b769f7+48c1343504,gcf0d15dbbd+7a21c67e12,gdaeeff99f8+f9a426f77a,ge6526c86ff+9349653ccd,ge79ae78c31+c6a8a0fb72,gee10cc3b42+585e252eca,w.2024.18
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)