CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Attributes
edm::ContainerMask< T > Class Template Reference

#include <ContainerMask.h>

Public Member Functions

void applyOrTo (std::vector< bool > &) const
 
 ContainerMask ()
 
 ContainerMask (const edm::RefProd< T > &iProd, const std::vector< bool > &iMask)
 
void copyMaskTo (std::vector< bool > &) const
 
bool mask (unsigned int iIndex) const
 
bool mask (const typename ContainerMaskTraits< T >::value_type *)
 
const edm::RefProd< T > & refProd () const
 
size_t size () const
 
void swap (ContainerMask< T > &iOther)
 

Static Public Member Functions

static short Class_Version ()
 

Private Attributes

std::vector< bool > m_mask
 
edm::RefProd< Tm_prod
 

Detailed Description

template<typename T>
class edm::ContainerMask< T >

Definition at line 36 of file ContainerMask.h.

Constructor & Destructor Documentation

template<typename T>
edm::ContainerMask< T >::ContainerMask ( )
inline
template<typename T>
ContainerMask::ContainerMask ( const edm::RefProd< T > &  iProd,
const std::vector< bool > &  iMask 
)

Definition at line 77 of file ContainerMask.h.

References edm::ContainerMaskTraits< T >::size().

77  :
78  m_prod(iProd), m_mask(iMask) {
79  assert(iMask.size() <= ContainerMaskTraits<T>::size(m_prod.product()));
80  }
std::vector< bool > m_mask
Definition: ContainerMask.h:73
edm::RefProd< T > m_prod
Definition: ContainerMask.h:72
product_type const * product() const
Definition: RefProd.h:119
static size_t size(const T *iContainer)

Member Function Documentation

template<typename T >
void ContainerMask::applyOrTo ( std::vector< bool > &  iTo) const

Definition at line 96 of file ContainerMask.h.

References edm::ContainerMask< T >::m_mask, and create_public_lumi_plots::transform.

Referenced by edm::ContainerMask< DetSetVector< Phase2ITPixelCluster > >::mask().

96  {
97  assert(iTo.size()==m_mask.size());
98  std::transform(m_mask.begin(),m_mask.end(),iTo.begin(), iTo.begin(),std::logical_or<bool>());
99  }
std::vector< bool > m_mask
Definition: ContainerMask.h:73
template<typename T>
static short edm::ContainerMask< T >::Class_Version ( )
inlinestatic

Definition at line 64 of file ContainerMask.h.

66 :
67  //ContainerMask(const ContainerMask&); // stop default
template<typename T >
void ContainerMask::copyMaskTo ( std::vector< bool > &  iTo) const
template<typename T>
bool edm::ContainerMask< T >::mask ( unsigned int  iIndex) const
inline

Definition at line 44 of file ContainerMask.h.

Referenced by ctfseeding::HitExtractorPIX::hits(), edm::ContainerMask< DetSetVector< Phase2ITPixelCluster > >::mask(), and edm::ContainerMask< T >::mask().

44  {
45  if(iIndex<m_mask.size()) {
46  return m_mask[iIndex];
47  }
48  return false;
49  }
std::vector< bool > m_mask
Definition: ContainerMask.h:73
template<typename T>
bool ContainerMask::mask ( const typename ContainerMaskTraits< T >::value_type *  iElement)

Definition at line 84 of file ContainerMask.h.

References diffTreeTool::index, edm::ContainerMaskTraits< T >::indexFor(), edm::ContainerMask< T >::m_prod, edm::ContainerMask< T >::mask(), and edm::RefProd< C >::product().

85  {
86  unsigned int index = ContainerMaskTraits<T>::indexFor(iElement,m_prod.product());
87  return this->mask(index);
88  }
edm::RefProd< T > m_prod
Definition: ContainerMask.h:72
bool mask(unsigned int iIndex) const
Definition: ContainerMask.h:44
product_type const * product() const
Definition: RefProd.h:119
static unsigned int indexFor(const value_type *iElement, const T *iContainer)
template<typename T>
const edm::RefProd<T>& edm::ContainerMask< T >::refProd ( ) const
inline

Definition at line 57 of file ContainerMask.h.

Referenced by ctfseeding::HitExtractorPIX::hits().

57 {return m_prod;}
edm::RefProd< T > m_prod
Definition: ContainerMask.h:72
template<typename T>
size_t edm::ContainerMask< T >::size ( void  ) const
inline
template<typename T>
void ContainerMask::swap ( ContainerMask< T > &  iOther)

Definition at line 102 of file ContainerMask.h.

References edm::ContainerMask< T >::m_mask, edm::ContainerMask< T >::m_prod, edm::RefProd< C >::swap(), and std::swap().

Referenced by edm::ContainerMask< DetSetVector< Phase2ITPixelCluster > >::refProd().

102  {
103  m_prod.swap(iOther.m_prod);
104  std::swap(m_mask,iOther.m_mask);
105  }
std::vector< bool > m_mask
Definition: ContainerMask.h:73
edm::RefProd< T > m_prod
Definition: ContainerMask.h:72
void swap(edm::DataFrameContainer &lhs, edm::DataFrameContainer &rhs)
void swap(RefProd< C > &)
Definition: RefProd.h:190

Member Data Documentation

template<typename T>
std::vector<bool> edm::ContainerMask< T >::m_mask
private
template<typename T>
edm::RefProd<T> edm::ContainerMask< T >::m_prod
private