LSST Applications g013ef56533+d2224463a4,g199a45376c+0ba108daf9,g19c4beb06c+9f335b2115,g1fd858c14a+2459ca3e43,g210f2d0738+2d3d333a78,g262e1987ae+abbb004f04,g2825c19fe3+eedc38578d,g29ae962dfc+0cb55f06ef,g2cef7863aa+aef1011c0b,g35bb328faa+8c5ae1fdc5,g3fd5ace14f+19c3a54948,g47891489e3+501a489530,g4cdb532a89+a047e97985,g511e8cfd20+ce1f47b6d6,g53246c7159+8c5ae1fdc5,g54cd7ddccb+890c8e1e5d,g5fd55ab2c7+951cc3f256,g64539dfbff+2d3d333a78,g67b6fd64d1+501a489530,g67fd3c3899+2d3d333a78,g74acd417e5+0ea5dee12c,g786e29fd12+668abc6043,g87389fa792+8856018cbb,g89139ef638+501a489530,g8d7436a09f+5ea4c44d25,g8ea07a8fe4+81eaaadc04,g90f42f885a+34c0557caf,g9486f8a5af+165c016931,g97be763408+d5e351dcc8,gbf99507273+8c5ae1fdc5,gc2a301910b+2d3d333a78,gca7fc764a6+501a489530,gce8aa8abaa+8c5ae1fdc5,gd7ef33dd92+501a489530,gdab6d2f7ff+0ea5dee12c,ge410e46f29+501a489530,geaed405ab2+e3b4b2a692,gf9a733ac38+8c5ae1fdc5,w.2025.41
LSST Data Management Base Package
Loading...
Searching...
No Matches
FieldBase.h
Go to the documentation of this file.
1// -*- lsst-c++ -*-
2#ifndef AFW_TABLE_FieldBase_h_INCLUDED
3#define AFW_TABLE_FieldBase_h_INCLUDED
4
5#include <cstring>
6#include <iostream>
7
8#include "Eigen/Core"
9
10#include "lsst/base.h"
11#include "lsst/pex/exceptions.h"
12#include "ndarray.h"
13#include "lsst/afw/table/misc.h"
16
17namespace lsst {
18namespace afw {
19namespace table {
20
21namespace detail {
22
23class TableImpl;
24
30inline std::size_t indexCovariance(std::size_t i, std::size_t j) { return (i < j) ? (i + j * (j + 1) / 2) : (j + i * (i + 1) / 2); }
31
33inline std::size_t computeCovariancePackedSize(std::size_t size) { return size * (size + 1) / 2; }
34
35} // namespace detail
36
40template <typename T>
41struct FieldBase {
42 using Value = T;
43 using Reference = T &;
44 using ConstReference = const T &;
45 using Element = T;
46
48 std::size_t getElementCount() const noexcept { return 1; }
49
52
53 // Only the first of these constructors is valid for this specializations, but
54 // it's convenient to be able to instantiate both, since the other is used
55 // by other specializations.
56 FieldBase() = default;
59 "Constructor disabled (this Field type is not sized).");
60 }
61 FieldBase(FieldBase const &) noexcept = default;
62 FieldBase(FieldBase &&) noexcept = default;
63 FieldBase &operator=(FieldBase const &) noexcept = default;
64 FieldBase &operator=(FieldBase &&) noexcept = default;
65 ~FieldBase() noexcept = default;
66
67protected:
69 static FieldBase makeDefault() noexcept { return FieldBase(); }
70
72 void stream(std::ostream &os) const {}
73
75 Reference getReference(Element *p, ndarray::Manager::Ptr const &) const { return *p; }
76
78 ConstReference getConstReference(Element const *p, ndarray::Manager::Ptr const &) const { return *p; }
79
81 Value getValue(Element const *p, ndarray::Manager::Ptr const &) const { return *p; }
82
84 void setValue(Element *p, ndarray::Manager::Ptr const &, Value v) const { *p = v; }
85};
86
95template <typename U>
96struct FieldBase<Array<U> > {
97 using Value = ndarray::Array<const U, 1, 1>;
98
100 using Reference = ndarray::ArrayRef<U, 1, 1>;
101
103 using ConstReference = ndarray::ArrayRef<const U, 1, 1>;
104
105 using Element = U;
106
120 FieldBase(size_t size = 0) : _size(size) {
121 }
122
123 FieldBase(FieldBase const &) noexcept = default;
124 FieldBase(FieldBase &&) noexcept = default;
125 FieldBase &operator=(FieldBase const &) noexcept = default;
126 FieldBase &operator=(FieldBase &&) noexcept = default;
127 ~FieldBase() noexcept = default;
128
130 static std::string getTypeString();
131
134 std::size_t getElementCount() const noexcept { return _size; }
135
138 std::size_t getSize() const noexcept { return _size; }
139
141 bool isVariableLength() const noexcept { return _size == 0; }
142
143protected:
145 static FieldBase makeDefault() noexcept { return FieldBase(0); }
146
148 void stream(std::ostream &os) const { os << ", size=" << _size; }
149
151 Reference getReference(Element *p, ndarray::Manager::Ptr const &m) const {
152 if (isVariableLength()) {
153 return reinterpret_cast<ndarray::Array<Element, 1, 1> *>(p)->deep();
154 }
155 return ndarray::external(p, ndarray::makeVector(_size), ndarray::ROW_MAJOR, m);
156 }
157
159 ConstReference getConstReference(Element const *p, ndarray::Manager::Ptr const &m) const {
160 if (isVariableLength()) {
161 return reinterpret_cast<ndarray::Array<Element, 1, 1> const *>(p)->deep();
162 }
163 return ndarray::external(p, ndarray::makeVector(_size), ndarray::ROW_MAJOR, m);
164 }
165
167 Value getValue(Element const *p, ndarray::Manager::Ptr const &m) const {
168 if (isVariableLength()) {
169 return *reinterpret_cast<ndarray::Array<Element, 1, 1> const *>(p);
170 }
171 return ndarray::external(p, ndarray::makeVector(_size), ndarray::ROW_MAJOR, m);
172 }
173
180 void setValue(Element *p, ndarray::Manager::Ptr const &,
181 ndarray::Array<Element, 1, 1> const &value) const {
182 if (isVariableLength()) {
183 *reinterpret_cast<ndarray::Array<Element, 1, 1> *>(p) = value;
184 } else {
185 setValueDeep(p, value);
186 }
187 }
188
190 template <typename Derived>
191 void setValue(Element *p, ndarray::Manager::Ptr const &,
192 ndarray::ExpressionBase<Derived> const &value) const {
193 if (isVariableLength()) {
194 throw LSST_EXCEPT(
196 "Assignment to a variable-length array must use a non-const array of the correct type.");
197 }
198 setValueDeep(p, value);
199 }
200
201private:
202 template <typename Derived>
203 void setValueDeep(Element *p, ndarray::ExpressionBase<Derived> const &value) const {
204 if (value.template getSize<0>() != static_cast<std::size_t>(_size)) {
206 "Incorrect size in array field assignment.");
207 }
208 for (std::size_t i = 0; i < _size; ++i) p[i] = value[i];
209 }
210
211 std::size_t _size;
212};
213
217template <>
218struct FieldBase<std::string> {
220
222 using Reference = char *;
223
225 using ConstReference = const char *;
226
227 using Element = char;
228
243
244 FieldBase(FieldBase const &) noexcept = default;
245 FieldBase(FieldBase &&) noexcept = default;
246 FieldBase &operator=(FieldBase const &) noexcept = default;
247 FieldBase &operator=(FieldBase &&) noexcept = default;
248 ~FieldBase() noexcept = default;
249
251 static std::string getTypeString();
252
255 std::size_t getElementCount() const noexcept { return _size; }
256
259 std::size_t getSize() const noexcept { return _size; }
260
262 bool isVariableLength() const noexcept { return _size == 0; }
263
264protected:
266 static FieldBase makeDefault() noexcept { return FieldBase(0); }
267
269 void stream(std::ostream &os) const { os << ", size=" << _size; }
270
272 Reference getReference(Element *p, ndarray::Manager::Ptr const &m) const {
273 if (isVariableLength()) {
274 // Can't be done until C++17, which allows read/write access to std::string's internal buffer
276 "non-const operator[] not supported for variable-length strings");
277 } else {
278 return p;
279 }
280 }
281
283 ConstReference getConstReference(Element const *p, ndarray::Manager::Ptr const &m) const {
284 if (isVariableLength()) {
285 return reinterpret_cast<std::string const *>(p)->data();
286 } else {
287 return p;
288 }
289 }
290
292 Value getValue(Element const *p, ndarray::Manager::Ptr const &m) const;
293
299 void setValue(Element *p, ndarray::Manager::Ptr const &, std::string const &value) const;
300
301private:
302 std::size_t _size;
303};
304} // namespace table
305} // namespace afw
306} // namespace lsst
307
308#endif // !AFW_TABLE_FieldBase_h_INCLUDED
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition Exception.h:48
Basic LSST definitions.
Tag types used to declare specialized field types.
Definition misc.h:31
Reports attempts to exceed implementation-defined length limits for some classes.
Definition Runtime.h:76
Reports errors in the logical structure of the program.
Definition Runtime.h:46
T max(T... args)
std::size_t computeCovariancePackedSize(std::size_t size)
Defines the packed size of a covariance matrices.
Definition FieldBase.h:33
std::size_t indexCovariance(std::size_t i, std::size_t j)
Defines the ordering of packed covariance matrices.
Definition FieldBase.h:30
STL namespace.
void setValue(Element *p, ndarray::Manager::Ptr const &, ndarray::Array< Element, 1, 1 > const &value) const
Used to implement BaseRecord::set; accepts only non-const arrays of the right type.
Definition FieldBase.h:180
ndarray::ArrayRef< U, 1, 1 > Reference
the type returned by BaseRecord::operator[]
Definition FieldBase.h:100
std::size_t getSize() const noexcept
Return the size of the array (equal to the number of subfield elements), or 0 for a variable-length a...
Definition FieldBase.h:138
Value getValue(Element const *p, ndarray::Manager::Ptr const &m) const
Used to implement BaseRecord::get.
Definition FieldBase.h:167
void stream(std::ostream &os) const
Defines how Fields are printed.
Definition FieldBase.h:148
std::size_t getElementCount() const noexcept
Return the number of subfield elements (equal to the size of the array), or 0 for a variable-length a...
Definition FieldBase.h:134
FieldBase(FieldBase const &) noexcept=default
void setValue(Element *p, ndarray::Manager::Ptr const &, ndarray::ExpressionBase< Derived > const &value) const
Used to implement BaseRecord::set; accepts any ndarray expression.
Definition FieldBase.h:191
static std::string getTypeString()
Return a string description of the field type.
Definition FieldBase.cc:63
U Element
the type of subfields and array elements
Definition FieldBase.h:105
ndarray::ArrayRef< const U, 1, 1 > ConstReference
the type returned by BaseRecord::operator[] (const)
Definition FieldBase.h:103
bool isVariableLength() const noexcept
Return true if the field is variable-length (each record can have a different size array).
Definition FieldBase.h:141
FieldBase(FieldBase &&) noexcept=default
Reference getReference(Element *p, ndarray::Manager::Ptr const &m) const
Used to implement BaseRecord::operator[] (non-const).
Definition FieldBase.h:151
FieldBase(size_t size=0)
Construct a FieldBase with the given size.
Definition FieldBase.h:120
ndarray::Array< const U, 1, 1 > Value
the type returned by BaseRecord::get
Definition FieldBase.h:97
static FieldBase makeDefault() noexcept
Needed to allow Keys to be default-constructed.
Definition FieldBase.h:145
ConstReference getConstReference(Element const *p, ndarray::Manager::Ptr const &m) const
Used to implement BaseRecord::operator[] (const).
Definition FieldBase.h:159
FieldBase(std::size_t size=std::numeric_limits< size_t >::max())
Construct a FieldBase with the given size.
Definition FieldBase.cc:69
char Element
the type of subfields and array elements
Definition FieldBase.h:227
char * Reference
the type returned by BaseRecord::operator[]
Definition FieldBase.h:222
const char * ConstReference
the type returned by BaseRecord::operator[] (const)
Definition FieldBase.h:225
std::string Value
the type returned by BaseRecord::get
Definition FieldBase.h:219
static FieldBase makeDefault() noexcept
Needed to allow Keys to be default-constructed.
Definition FieldBase.h:266
bool isVariableLength() const noexcept
Return true if the field is variable-length (each record can have a different size array).
Definition FieldBase.h:262
static std::string getTypeString()
Return a string description of the field type.
Definition FieldBase.cc:72
FieldBase(FieldBase &&) noexcept=default
std::size_t getSize() const noexcept
Return the maximum length of the string, including a null terminator (equal to the number of subfield...
Definition FieldBase.h:259
FieldBase(FieldBase const &) noexcept=default
ConstReference getConstReference(Element const *p, ndarray::Manager::Ptr const &m) const
Used to implement BaseRecord::operator[] (const).
Definition FieldBase.h:283
void stream(std::ostream &os) const
Defines how Fields are printed.
Definition FieldBase.h:269
std::size_t getElementCount() const noexcept
Return the number of subfield elements (equal to the size of the string, including a null terminator)...
Definition FieldBase.h:255
Reference getReference(Element *p, ndarray::Manager::Ptr const &m) const
Used to implement BaseRecord::operator[] (non-const).
Definition FieldBase.h:272
const T & ConstReference
the type returned by BaseRecord::operator[] (const)
Definition FieldBase.h:44
ConstReference getConstReference(Element const *p, ndarray::Manager::Ptr const &) const
Used to implement BaseRecord::operator[] (const).
Definition FieldBase.h:78
FieldBase(FieldBase const &) noexcept=default
static std::string getTypeString()
Return a string description of the field type.
Definition FieldBase.cc:56
Value getValue(Element const *p, ndarray::Manager::Ptr const &) const
Used to implement BaseRecord::get.
Definition FieldBase.h:81
std::size_t getElementCount() const noexcept
Return the number of subfield elements (always one for scalars).
Definition FieldBase.h:48
T & Reference
the type returned by BaseRecord::operator[] (non-const)
Definition FieldBase.h:43
void setValue(Element *p, ndarray::Manager::Ptr const &, Value v) const
Used to implement BaseRecord::set.
Definition FieldBase.h:84
Reference getReference(Element *p, ndarray::Manager::Ptr const &) const
Used to implement BaseRecord::operator[] (non-const).
Definition FieldBase.h:75
static FieldBase makeDefault() noexcept
Needed to allow Keys to be default-constructed.
Definition FieldBase.h:69
T Value
the type returned by BaseRecord::get
Definition FieldBase.h:42
void stream(std::ostream &os) const
Defines how Fields are printed.
Definition FieldBase.h:72
T Element
the type of subfields (the same as the type itself for scalars)
Definition FieldBase.h:45
FieldBase(FieldBase &&) noexcept=default