All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Types | Public Member Functions | Private Types | List of all members
geo::PlaneIDmapper< Index > Class Template Reference

Mapping for sensitive plane identifiers. More...

#include <GeometryIDmapper.h>

Inheritance diagram for geo::PlaneIDmapper< Index >:
geo::GeoIDmapper< geo::PlaneID, Index >

Public Types

using ID_t = typename BaseMapper_t::ID_t
 
using index_type = typename BaseMapper_t::index_type
 
- Public Types inherited from geo::GeoIDmapper< geo::PlaneID, Index >
using ID_t = geo::PlaneID
 Type used as ID for this mapping. More...
 
using index_type = Index
 Type of flat index. More...
 

Public Member Functions

 PlaneIDmapper (unsigned int nCryo, unsigned int nTPCs, unsigned int nPlanes)
 Prepares the mapping with the specified sizes. More...
 
void resize (unsigned int nCryo, unsigned int nTPCs, unsigned int nPlanes)
 Prepares the mapping for the specified sizes. More...
 
Mapping status query
bool hasCryostat (geo::CryostatID const &cryoid) const
 Returns whether this mapping covers the specified cryostat. More...
 
bool hasTPC (geo::TPCID const &tpcid) const
 Returns whether this mapping covers the specified TPC. More...
 
bool hasPlane (geo::PlaneID const &planeid) const
 Returns whether this mapping covers the specified plane. More...
 
- Public Member Functions inherited from geo::GeoIDmapper< geo::PlaneID, Index >
 GeoIDmapper ()
 Default constructor: all dimensions empty. More...
 
 GeoIDmapper (std::initializer_list< unsigned int > dims)
 Prepares the indexer. More...
 
index_type index (ID_t const &id) const
 Returns the linear index corresponding to the specified ID. More...
 
ID_t ID (index_type const index) const
 Returns the ID corresponding to the specified linear index. More...
 
index_type operator() (ID_t const &id) const
 Returns the linear index corresponding to the specified ID. More...
 
ID_t operator() (index_type const index) const
 Returns the ID corresponding to the specified linear index. More...
 
void resize (std::initializer_list< unsigned int > dims)
 Resizes the mapping to accommodate the specified dimension sizes. More...
 
void resizeAs (geo::GeoIDmapper< OIDType, OIndex > const &other)
 Resizes the mapping to reflect the one from another mapping. More...
 
void clear ()
 Sets all dimension sizes to 0. More...
 
index_type size () const
 Returns the number of elements in the mapping. More...
 
bool empty () const
 Returns whether the mapping has no elements (false by assumptions). More...
 
unsigned int dimSize () const
 Dimensions of the Level dimension of this mapping. More...
 
bool hasElement (GeoID const &id) const
 Returns whether this mapping hosts data for the specified ID. More...
 
GeoID firstID () const
 Returns the ID of the first element with GeoID type. More...
 
GeoID lastID () const
 Returns the ID of the last covered element with GeoID type. More...
 

Private Types

using BaseMapper_t = geo::GeoIDmapper< geo::PlaneID, Index >
 Base class. More...
 

Detailed Description

template<typename Index = std::size_t>
class geo::PlaneIDmapper< Index >

Mapping for sensitive plane identifiers.


Template Parameters
Index(default: std::size_t) type of flat index
See Also
geo::GeoIDmapper

A customized version of geo::GeoIDmapper offering sensitive plane ID-specific interface.

Definition at line 35 of file GeometryIDmapper.h.

Member Typedef Documentation

template<typename Index = std::size_t>
using geo::PlaneIDmapper< Index >::BaseMapper_t = geo::GeoIDmapper<geo::PlaneID, Index>
private

Base class.

Definition at line 340 of file GeometryIDmapper.h.

template<typename Index = std::size_t>
using geo::PlaneIDmapper< Index >::ID_t = typename BaseMapper_t::ID_t

Definition at line 345 of file GeometryIDmapper.h.

template<typename Index = std::size_t>
using geo::PlaneIDmapper< Index >::index_type = typename BaseMapper_t::index_type

Definition at line 346 of file GeometryIDmapper.h.

Constructor & Destructor Documentation

template<typename Index = std::size_t>
geo::PlaneIDmapper< Index >::PlaneIDmapper ( unsigned int  nCryo,
unsigned int  nTPCs,
unsigned int  nPlanes 
)
inline

Prepares the mapping with the specified sizes.

Parameters
nCryonumber of cryostats
nTPCsnumber of TPCs per cryostat
nPlanesnumber of planes per TPC

The mapping is sized to map nCryo cryostats, each with nTPCs TPCs, each one with nPlanes wire planes.

Definition at line 361 of file GeometryIDmapper.h.

362  : BaseMapper_t({ nCryo, nTPCs, nPlanes })
geo::GeoIDmapper< geo::PlaneID, Index > BaseMapper_t
Base class.

Member Function Documentation

template<typename Index = std::size_t>
bool geo::PlaneIDmapper< Index >::hasCryostat ( geo::CryostatID const &  cryoid) const
inline

Returns whether this mapping covers the specified cryostat.

Definition at line 394 of file GeometryIDmapper.h.

395  { return BaseMapper_t::hasElement(cryoid); }
bool hasElement(GeoID const &id) const
Returns whether this mapping hosts data for the specified ID.
template<typename Index = std::size_t>
bool geo::PlaneIDmapper< Index >::hasPlane ( geo::PlaneID const &  planeid) const
inline

Returns whether this mapping covers the specified plane.

Definition at line 402 of file GeometryIDmapper.h.

403  { return BaseMapper_t::hasElement(planeid); }
bool hasElement(GeoID const &id) const
Returns whether this mapping hosts data for the specified ID.
template<typename Index = std::size_t>
bool geo::PlaneIDmapper< Index >::hasTPC ( geo::TPCID const &  tpcid) const
inline

Returns whether this mapping covers the specified TPC.

Definition at line 398 of file GeometryIDmapper.h.

399  { return BaseMapper_t::hasElement(tpcid); }
bool hasElement(GeoID const &id) const
Returns whether this mapping hosts data for the specified ID.
template<typename Index = std::size_t>
void geo::PlaneIDmapper< Index >::resize ( unsigned int  nCryo,
unsigned int  nTPCs,
unsigned int  nPlanes 
)
inline

Prepares the mapping for the specified sizes.

Parameters
nCryonumber of cryostats
nTPCsnumber of TPCs
nPlanesnumber of planes per TPC
See Also
resizeAs()

The mapping is sized to map nCryo cryostats, each with nTPCs TPCs, each one with nPlanes wire planes.

Definition at line 382 of file GeometryIDmapper.h.

383  { BaseMapper_t::resize({ nCryo, nTPCs, nPlanes }); }
void resize(std::initializer_list< unsigned int > dims)
Resizes the mapping to accommodate the specified dimension sizes.

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