CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Types | Public Member Functions | Private Member Functions | Static Private Member Functions | Private Attributes
EcalContainer< DetId, T > Class Template Reference

#include <EcalContainer.h>

Public Types

typedef std::vector< Item >
::const_iterator 
const_iterator
 
typedef T Item
 
typedef std::vector< ItemItems
 
typedef std::vector< Item >
::iterator 
iterator
 
typedef EcalContainer< DetId, Tself
 
typedef Item value_type
 

Public Member Functions

const_iterator begin () const
 
void checkAndResize ()
 
void checkAndResize (size_t priv_size)
 
 EcalContainer ()
 
const_iterator end () const
 
const_iterator find (uint32_t rawId) const
 
void insert (std::pair< uint32_t, Item > const &a)
 
const Itemitem (size_t hashid) const
 
const Itemsitems () const
 
Itemoperator[] (uint32_t rawId)
 
Item const & operator[] (uint32_t rawId) const
 
void setItems (const std::vector< Item > &items)
 
size_t size () const
 

Private Member Functions

bool isValidId (const DetId id) const
 

Static Private Member Functions

static const Itemdummy_item ()
 

Private Attributes

std::vector< Itemm_items
 

Detailed Description

template<typename DetId, typename T>
class EcalContainer< DetId, T >

Definition at line 18 of file EcalContainer.h.

Member Typedef Documentation

template<typename DetId, typename T>
typedef std::vector<Item>::const_iterator EcalContainer< DetId, T >::const_iterator

Definition at line 26 of file EcalContainer.h.

template<typename DetId, typename T>
typedef T EcalContainer< DetId, T >::Item

Definition at line 23 of file EcalContainer.h.

template<typename DetId, typename T>
typedef std::vector<Item> EcalContainer< DetId, T >::Items

Definition at line 25 of file EcalContainer.h.

template<typename DetId, typename T>
typedef std::vector<Item>::iterator EcalContainer< DetId, T >::iterator

Definition at line 27 of file EcalContainer.h.

template<typename DetId, typename T>
typedef EcalContainer<DetId, T> EcalContainer< DetId, T >::self

Definition at line 22 of file EcalContainer.h.

template<typename DetId, typename T>
typedef Item EcalContainer< DetId, T >::value_type

Definition at line 24 of file EcalContainer.h.

Constructor & Destructor Documentation

template<typename DetId, typename T>
EcalContainer< DetId, T >::EcalContainer ( )
inline

Definition at line 30 of file EcalContainer.h.

30 {checkAndResize();}
void checkAndResize()
Definition: EcalContainer.h:53

Member Function Documentation

template<typename DetId, typename T>
const_iterator EcalContainer< DetId, T >::begin ( void  ) const
inline
template<typename DetId, typename T>
void EcalContainer< DetId, T >::checkAndResize ( )
inline

Definition at line 53 of file EcalContainer.h.

Referenced by EcalCondTowerObjectContainer< EcalDAQStatusCode >::EcalCondTowerObjectContainer(), EcalContainer< EcalTrigTowerDetId, Item >::EcalContainer(), and EcalContainer< EcalTrigTowerDetId, Item >::operator[]().

53  {
54  if (m_items.size()==0) {
55  // std::cout << "resizing to " << DetId::kSizeForDenseIndexing << std::endl;
56  m_items.resize(DetId::kSizeForDenseIndexing);
57  }
58  }
std::vector< Item > m_items
template<typename DetId, typename T>
void EcalContainer< DetId, T >::checkAndResize ( size_t  priv_size)
inline

Definition at line 61 of file EcalContainer.h.

61  {
62  // this method allows to resize the vector to a specific size forcing a specific value
63  if (m_items.size()==0) {
64  // std::cout << "resizing to " << priv_size << std::endl;
65  m_items.resize(priv_size);
66  }
67  }
std::vector< Item > m_items
template<typename DetId, typename T>
static const Item& EcalContainer< DetId, T >::dummy_item ( )
inlinestaticprivate

Definition at line 105 of file EcalContainer.h.

Referenced by EcalContainer< EcalTrigTowerDetId, Item >::operator[]().

105  {
106  static const Item s_dummy{};
107  return s_dummy;
108  }
template<typename DetId, typename T>
const_iterator EcalContainer< DetId, T >::end ( void  ) const
inline
template<typename DetId, typename T>
const_iterator EcalContainer< DetId, T >::find ( uint32_t  rawId) const
inline

Definition at line 79 of file EcalContainer.h.

Referenced by BeautifulSoup.Tag::__getattr__(), ESCondObjectContainer< ESStripGroupId >::find(), EcalCondTowerObjectContainer< EcalDAQStatusCode >::find(), EcalCondObjectContainer< EcalTimeDependentCorrections::Values >::find(), and BeautifulSoup.Tag::firstText().

79  {
80  DetId ib(rawId);
81  if ( !isValidId(ib) ) return m_items.end();
82  return m_items.begin() + ib.hashedIndex();
83  }
int ib
Definition: cuy.py:660
std::vector< Item > m_items
Definition: DetId.h:18
bool isValidId(const DetId id) const
template<typename DetId, typename T>
void EcalContainer< DetId, T >::insert ( std::pair< uint32_t, Item > const &  a)
inline
template<typename DetId, typename T>
bool EcalContainer< DetId, T >::isValidId ( const DetId  id) const
inlineprivate

Definition at line 113 of file EcalContainer.h.

Referenced by EcalContainer< EcalTrigTowerDetId, Item >::find(), and EcalContainer< EcalTrigTowerDetId, Item >::operator[]().

113  {
114  return id.det() == ::DetId::Ecal;
115  };
template<typename DetId, typename T>
const Item& EcalContainer< DetId, T >::item ( size_t  hashid) const
inline
template<typename DetId, typename T>
const Items& EcalContainer< DetId, T >::items ( ) const
inline
template<typename DetId, typename T>
Item& EcalContainer< DetId, T >::operator[] ( uint32_t  rawId)
inline

Definition at line 44 of file EcalContainer.h.

44  {
46  static Item dummy;
47  DetId id(rawId);
48  if ( !isValidId(id) ) return dummy;
49  return m_items[id.hashedIndex()];
50  }
std::vector< Item > m_items
Definition: DetId.h:18
void checkAndResize()
Definition: EcalContainer.h:53
bool isValidId(const DetId id) const
template<typename DetId, typename T>
Item const& EcalContainer< DetId, T >::operator[] ( uint32_t  rawId) const
inline

Definition at line 69 of file EcalContainer.h.

69  {
70  // if (m_items.size()==0) {
71  // std::cout << "resizing to " << DetId::kSizeForDenseIndexing << std::endl;
72  // m_items.resize((size_t) DetId::kSizeForDenseIndexing);
73  // }
74  DetId id(rawId);
75  if ( !isValidId(id) ) return dummy_item();
76  return m_items[id.hashedIndex()];
77  }
std::vector< Item > m_items
Definition: DetId.h:18
static const Item & dummy_item()
bool isValidId(const DetId id) const
template<typename DetId, typename T>
void EcalContainer< DetId, T >::setItems ( const std::vector< Item > &  items)
inline

Definition at line 97 of file EcalContainer.h.

Referenced by boost::serialization::load().

97  {
98  m_items = items;
99  }
const Items & items() const
Definition: EcalContainer.h:40
std::vector< Item > m_items
template<typename DetId, typename T>
size_t EcalContainer< DetId, T >::size ( void  ) const
inline

Member Data Documentation

template<typename DetId, typename T>
std::vector<Item> EcalContainer< DetId, T >::m_items
private