Template Class ArrayKey¶
Defined in File arrays.h
Inheritance Relationships¶
Base Types¶
public lsst::afw::table::FunctorKey< ndarray::Array< T const, 1, 1 > >
(Template Class FunctorKey)public lsst::afw::table::ReferenceFunctorKey< ndarray::ArrayRef< T, 1, 1 > >
(Template Class ReferenceFunctorKey)public lsst::afw::table::ConstReferenceFunctorKey< ndarray::ArrayRef< T const, 1, 1 > >
(Template Class ConstReferenceFunctorKey)
Class Documentation¶
-
template<typename
T
>
classArrayKey
: public lsst::afw::table::FunctorKey<ndarray::Array<T const, 1, 1>>, public lsst::afw::table::ReferenceFunctorKey<ndarray::ArrayRef<T, 1, 1>>, public lsst::afw::table::ConstReferenceFunctorKey<ndarray::ArrayRef<T const, 1, 1>>¶ A FunctorKey used to get or set a ndarray::Array from a sequence of scalar Keys.
ArrayKey operates on the convention that arrays are defined by a set of contiguous scalar fields (i.e. added to the Schema in order, with no interruption) of the same type, with a common field name prefix and “_0”, “_1” etc. suffixes.
Unnamed Group
-
bool
operator==
(ArrayKey<T> const &other) const¶ Compare the FunctorKey for equality with another, using the underlying scalar Keys.
-
bool
operator!=
(ArrayKey<T> const &other) const¶
Public Functions
-
ArrayKey
()¶ Default constructor; instance will not be usable unless subsequently assigned to.
-
ArrayKey
(std::vector<Key<T>> const &keys)¶ Construct from a vector of scalar Keys.
-
ArrayKey
(Key<Array<T>> const &other)¶ Construct from a compound Key< Array<T> >
Key< Array<T> > is now deprecated in favor of ArrayKey; this factory function is intended to aid in the transition.
-
ArrayKey
(SubSchema const &s)¶ Construct from a subschema, assuming *_0, *_1, *_2, etc. subfields
If a schema has “a_0”, “a_1”, and “a_2” fields, this constructor allows you to construct a 3-element ArrayKey via:
ArrayKey<T> k(schema["a"]);
-
ArrayKey &
operator=
(ArrayKey const&)¶
-
ArrayKey &
operator=
(ArrayKey&&)¶
-
~ArrayKey
()¶
-
int
getSize
() const¶ Return the number of elements in the array.
-
ndarray::Array<T const, 1, 1>
get
(BaseRecord const &record) const¶ Get an array from the given record.
-
void
set
(BaseRecord &record, ndarray::Array<T const, 1, 1> const &value) const¶ Set an array in the given record.
-
ndarray::ArrayRef<T, 1, 1>
getReference
(BaseRecord &record) const¶ Get non-const reference array from the given record.
-
ndarray::ArrayRef<T const, 1, 1>
getConstReference
(BaseRecord const &record) const¶ Get const reference array from the given record.
-
std::size_t
hash_value
() const¶ Return a hash of this object.
-
bool
isValid
() const¶ Return True if the FunctorKey contains valid scalar keys.
-
ArrayKey
slice
(int begin, int end) const¶ Return a FunctorKey corresponding to a range of elements.
Public Static Functions
-
static ArrayKey
addFields
(Schema &schema, std::string const &name, std::string const &doc, std::string const &unit, std::vector<T> const &docData)¶ Add an array of fields to a Schema, and return an ArrayKey that points to them.
- Parameters
[inout] schema
: Schema to add fields to.[in] name
: Name prefix for all fields; “_0”, “_1”, etc. will be appended to this to form the full field names.[in] doc
: String used as the documentation for the fields. Should include a single boost::format template string, which will be substituted with the appropriate element from the docData array to form the full documentation string.[in] unit
: String used as the unit for all fields.[in] docData
: Vector of values substituted into the doc fields. The length of the vector determines the number of fields added.
-
static ArrayKey
addFields
(Schema &schema, std::string const &name, std::string const &doc, std::string const &unit, int size)¶ Add an array of fields to a Schema, and return an ArrayKey that points to them.
- Parameters
[inout] schema
: Schema to add fields to.[in] name
: Name prefix for all fields; “_0”, “_1”, etc. will be appended to this to form the full field names.[in] doc
: String used as the documentation for the fields.[in] unit
: String used as the unit for all fields.[in] size
: Number of fields to add.
-
bool