LSST Applications  21.0.0+04719a4bac,21.0.0-1-ga51b5d4+f5e6047307,21.0.0-11-g2b59f77+a9c1acf22d,21.0.0-11-ga42c5b2+86977b0b17,21.0.0-12-gf4ce030+76814010d2,21.0.0-13-g1721dae+760e7a6536,21.0.0-13-g3a573fe+768d78a30a,21.0.0-15-g5a7caf0+f21cbc5713,21.0.0-16-g0fb55c1+b60e2d390c,21.0.0-19-g4cded4ca+71a93a33c0,21.0.0-2-g103fe59+bb20972958,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+3ad5d60fb1,21.0.0-2-g7f82c8f+8babb168e8,21.0.0-2-g8f08a60+06509c8b61,21.0.0-2-g8faa9b5+616205b9df,21.0.0-2-ga326454+8babb168e8,21.0.0-2-gde069b7+5e4aea9c2f,21.0.0-2-gecfae73+1d3a86e577,21.0.0-2-gfc62afb+3ad5d60fb1,21.0.0-25-g1d57be3cd+e73869a214,21.0.0-3-g357aad2+ed88757d29,21.0.0-3-g4a4ce7f+3ad5d60fb1,21.0.0-3-g4be5c26+3ad5d60fb1,21.0.0-3-g65f322c+e0b24896a3,21.0.0-3-g7d9da8d+616205b9df,21.0.0-3-ge02ed75+a9c1acf22d,21.0.0-4-g591bb35+a9c1acf22d,21.0.0-4-g65b4814+b60e2d390c,21.0.0-4-gccdca77+0de219a2bc,21.0.0-4-ge8a399c+6c55c39e83,21.0.0-5-gd00fb1e+05fce91b99,21.0.0-6-gc675373+3ad5d60fb1,21.0.0-64-g1122c245+4fb2b8f86e,21.0.0-7-g04766d7+cd19d05db2,21.0.0-7-gdf92d54+04719a4bac,21.0.0-8-g5674e7b+d1bd76f71f,master-gac4afde19b+a9c1acf22d,w.2021.13
LSST Data Management Base Package
Public Types | Public Member Functions | Static Public Member Functions | List of all members
lsst::afw::table::BoxKey< Box > Class Template Referenceabstract

A FunctorKey used to get or set a lsst::geom::Box2I or Box2D from a (min, max) pair of PointKeys. More...

#include <aggregates.h>

Inheritance diagram for lsst::afw::table::BoxKey< Box >:
lsst::afw::table::FunctorKey< Box > lsst::afw::table::OutputFunctorKey< T > lsst::afw::table::InputFunctorKey< T >

Public Types

using Element = typename Box::Element
 Type of coordinate elements (i.e. int or double). More...
 
using Value = Box
 The data type for get and set. More...
 

Public Member Functions

 BoxKey () noexcept=default
 Default constructor; instance will not be usable unless subsequently assigned to. More...
 
 BoxKey (PointKey< Element > const &min, PointKey< Element > const &max) noexcept
 Construct from a pair of PointKeys. More...
 
 BoxKey (SubSchema const &s)
 Construct from a subschema, assuming _min_x, _max_x, _min_y, _max_y subfields. More...
 
 BoxKey (BoxKey const &) noexcept=default
 
 BoxKey (BoxKey &&) noexcept=default
 
BoxKeyoperator= (BoxKey const &) noexcept=default
 
BoxKeyoperator= (BoxKey &&) noexcept=default
 
 ~BoxKey () noexcept override=default
 
std::size_t hash_value () const noexcept
 Return a hash of this object. More...
 
Box get (BaseRecord const &record) const override
 Get a Box from the given record. More...
 
void set (BaseRecord &record, Box const &value) const override
 Set a Box in the given record. More...
 
bool operator== (BoxKey const &other) const noexcept
 Compare the FunctorKey for equality with another, using the underlying x and y Keys. More...
 
bool operator!= (BoxKey const &other) const noexcept
 
bool isValid () const noexcept
 Return True if both the min and max PointKeys are valid. More...
 
PointKey< ElementgetMin () const noexcept
 Return the underlying min PointKey. More...
 
PointKey< ElementgetMax () const noexcept
 Return the underlying max PointKey. More...
 
virtual void set (BaseRecord &record, T const &value) const =0
 

Static Public Member Functions

static BoxKey addFields (Schema &schema, std::string const &name, std::string const &doc, std::string const &unit)
 Add _min_x, _min_y, _max_x, _max_y fields to a Schema, and return a BoxKey that points to them. More...
 

Detailed Description

template<typename Box>
class lsst::afw::table::BoxKey< Box >

A FunctorKey used to get or set a lsst::geom::Box2I or Box2D from a (min, max) pair of PointKeys.

The Box2IKey and Box2DKey typedefs should be preferred to using the template name directly.

Definition at line 126 of file aggregates.h.

Member Typedef Documentation

◆ Element

template<typename Box >
using lsst::afw::table::BoxKey< Box >::Element = typename Box::Element

Type of coordinate elements (i.e. int or double).

Definition at line 129 of file aggregates.h.

◆ Value

using lsst::afw::table::FunctorKey< Box >::Value = Box
inherited

The data type for get and set.

Definition at line 77 of file FunctorKey.h.

Constructor & Destructor Documentation

◆ BoxKey() [1/5]

template<typename Box >
lsst::afw::table::BoxKey< Box >::BoxKey ( )
defaultnoexcept

Default constructor; instance will not be usable unless subsequently assigned to.

◆ BoxKey() [2/5]

template<typename Box >
lsst::afw::table::BoxKey< Box >::BoxKey ( PointKey< Element > const &  min,
PointKey< Element > const &  max 
)
inlinenoexcept

Construct from a pair of PointKeys.

Definition at line 151 of file aggregates.h.

151 : _min(min), _max(max) {}
int min
int max

◆ BoxKey() [3/5]

template<typename Box >
lsst::afw::table::BoxKey< Box >::BoxKey ( SubSchema const &  s)
inline

Construct from a subschema, assuming _min_x, _max_x, _min_y, _max_y subfields.

If a schema has "a_min_x" and "a_min_x" (etc) fields, this constructor allows you to construct a BoxKey via:

BoxKey<Box> k(schema["a"]);

Definition at line 161 of file aggregates.h.

161 : _min(s["min"]), _max(s["max"]) {}

◆ BoxKey() [4/5]

template<typename Box >
lsst::afw::table::BoxKey< Box >::BoxKey ( BoxKey< Box > const &  )
defaultnoexcept

◆ BoxKey() [5/5]

template<typename Box >
lsst::afw::table::BoxKey< Box >::BoxKey ( BoxKey< Box > &&  )
defaultnoexcept

◆ ~BoxKey()

template<typename Box >
lsst::afw::table::BoxKey< Box >::~BoxKey ( )
overridedefaultnoexcept

Member Function Documentation

◆ addFields()

template<typename Box >
BoxKey< Box > lsst::afw::table::BoxKey< Box >::addFields ( Schema schema,
std::string const &  name,
std::string const &  doc,
std::string const &  unit 
)
static

Add _min_x, _min_y, _max_x, _max_y fields to a Schema, and return a BoxKey that points to them.

Parameters
[in,out]schemaSchema to add fields to.
[in]nameName prefix for all fields; suffixes above will be appended to this to form the full field names. For example, if name == "b", the fields added will be "b_min_x", "b_min_y", "b_max_x", and "b_max_y".
[in]docString used as the documentation for the fields.
[in]unitString used as the unit for all fields.

Definition at line 60 of file aggregates.cc.

61  {
62  auto minKey = PointKey<Element>::addFields(schema, schema.join(name, "min"), doc + " (minimum)", unit);
63  auto maxKey = PointKey<Element>::addFields(schema, schema.join(name, "max"), doc + " (maximum)", unit);
64  return BoxKey<Box>(minKey, maxKey);
65 }
table::Key< std::string > name
Definition: Amplifier.cc:116
table::Schema schema
Definition: python.h:134
static PointKey addFields(Schema &schema, std::string const &name, std::string const &doc, std::string const &unit)
Add a pair of _x, _y fields to a Schema, and return a PointKey that points to them.
Definition: aggregates.cc:36

◆ get()

template<typename Box >
Box lsst::afw::table::BoxKey< Box >::get ( BaseRecord const &  record) const
overridevirtual

Get a Box from the given record.

Implements lsst::afw::table::OutputFunctorKey< T >.

Definition at line 68 of file aggregates.cc.

68  {
69  return Box(record.get(_min), record.get(_max), /*invert=*/false);
70 }

◆ getMax()

template<typename Box >
PointKey<Element> lsst::afw::table::BoxKey< Box >::getMax ( ) const
inlinenoexcept

Return the underlying max PointKey.

Definition at line 194 of file aggregates.h.

194 { return _max; }

◆ getMin()

template<typename Box >
PointKey<Element> lsst::afw::table::BoxKey< Box >::getMin ( ) const
inlinenoexcept

Return the underlying min PointKey.

Definition at line 191 of file aggregates.h.

191 { return _min; }

◆ hash_value()

template<typename Box >
std::size_t lsst::afw::table::BoxKey< Box >::hash_value ( ) const
inlinenoexcept

Return a hash of this object.

Definition at line 170 of file aggregates.h.

170  {
171  // Completely arbitrary seed
172  return utils::hashCombine(17, _min, _max);
173  }
std::size_t hashCombine(std::size_t seed) noexcept
Combine hashes.
Definition: hashCombine.h:35

◆ isValid()

template<typename Box >
bool lsst::afw::table::BoxKey< Box >::isValid ( ) const
inlinenoexcept

Return True if both the min and max PointKeys are valid.

Definition at line 188 of file aggregates.h.

188 { return _min.isValid() && _max.isValid(); }
bool isValid() const noexcept
Return True if both the x and y Keys are valid.
Definition: aggregates.h:104

◆ operator!=()

template<typename Box >
bool lsst::afw::table::BoxKey< Box >::operator!= ( BoxKey< Box > const &  other) const
inlinenoexcept

Definition at line 184 of file aggregates.h.

184 { return !(*this == other); }
ItemVariant const * other
Definition: Schema.cc:56

◆ operator=() [1/2]

template<typename Box >
BoxKey& lsst::afw::table::BoxKey< Box >::operator= ( BoxKey< Box > &&  )
defaultnoexcept

◆ operator=() [2/2]

template<typename Box >
BoxKey& lsst::afw::table::BoxKey< Box >::operator= ( BoxKey< Box > const &  )
defaultnoexcept

◆ operator==()

template<typename Box >
bool lsst::afw::table::BoxKey< Box >::operator== ( BoxKey< Box > const &  other) const
inlinenoexcept

Compare the FunctorKey for equality with another, using the underlying x and y Keys.

Definition at line 183 of file aggregates.h.

183 { return _min == other._min && _max == other._max; }

◆ set() [1/2]

template<typename Box >
void lsst::afw::table::BoxKey< Box >::set ( BaseRecord record,
Box const &  value 
) const
override

Set a Box in the given record.

Definition at line 73 of file aggregates.cc.

73  {
74  _min.set(record, value.getMin());
75  _max.set(record, value.getMax());
76 }
void set(BaseRecord &record, lsst::geom::Point< T, 2 > const &value) const override
Set a Point in the given record.
Definition: aggregates.cc:49

◆ set() [2/2]

template<typename T >
virtual void lsst::afw::table::InputFunctorKey< T >::set ( BaseRecord record,
T const &  value 
) const
pure virtualinherited

The documentation for this class was generated from the following files: