CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Private Attributes
PixelDigiCollection Class Reference

#include <PixelDigiCollection.h>

Public Types

typedef std::vector< PixelDigi >::const_iterator ContainerIterator
 
typedef std::pair< unsigned int, unsigned int > IndexRange
 
typedef std::pair< ContainerIterator, ContainerIteratorRange
 
typedef std::map< unsigned int, IndexRangeRegistry
 
typedef std::map< unsigned int, IndexRange >::const_iterator RegistryIterator
 

Public Member Functions

const std::vector< unsigned int > detIDs () const
 
const Range get (unsigned int detID) const
 
 PixelDigiCollection ()
 
void put (Range input, unsigned int detID)
 

Private Attributes

std::vector< PixelDigicontainer_
 
Registry map_
 

Detailed Description

Definition at line 9 of file PixelDigiCollection.h.

Member Typedef Documentation

typedef std::vector<PixelDigi>::const_iterator PixelDigiCollection::ContainerIterator

Definition at line 13 of file PixelDigiCollection.h.

typedef std::pair<unsigned int, unsigned int> PixelDigiCollection::IndexRange

Definition at line 15 of file PixelDigiCollection.h.

Definition at line 14 of file PixelDigiCollection.h.

typedef std::map<unsigned int, IndexRange> PixelDigiCollection::Registry

Definition at line 16 of file PixelDigiCollection.h.

typedef std::map<unsigned int, IndexRange>::const_iterator PixelDigiCollection::RegistryIterator

Definition at line 17 of file PixelDigiCollection.h.

Constructor & Destructor Documentation

PixelDigiCollection::PixelDigiCollection ( )
inline

Definition at line 19 of file PixelDigiCollection.h.

References detIDs(), input, and put().

19 {}

Member Function Documentation

const std::vector< unsigned int > PixelDigiCollection::detIDs ( ) const

Definition at line 56 of file PixelDigiCollection.cc.

References begin, end, map_, and convertSQLitetoXML_cfg::output.

Referenced by PixelDigiCollection().

56  {
57  // returns vector of detIDs in map
58 
61 
62  std::vector<unsigned int> output;
63 
64  for (; begin != end; ++begin) {
65  output.push_back(begin->first);
66  }
67 
68  return output;
69 
70 }
std::map< unsigned int, IndexRange >::const_iterator RegistryIterator
#define end
Definition: vmac.h:39
#define begin
Definition: vmac.h:32
const PixelDigiCollection::Range PixelDigiCollection::get ( unsigned int  detID) const

Definition at line 40 of file PixelDigiCollection.cc.

References container_, runEdmFileComparison::found, and map_.

Referenced by Options.Options::__getitem__(), betterConfigParser.BetterConfigParser::__updateDict(), util.rrapi.RRApi::columns(), rrapi.RRApi::columns(), util.rrapi.RRApi::count(), rrapi.RRApi::count(), rrapi.RRApi::data(), util.rrapi.RRApi::data(), betterConfigParser.BetterConfigParser::getCompares(), betterConfigParser.BetterConfigParser::getGeneral(), betterConfigParser.BetterConfigParser::getResultingSection(), rrapi.RRApi::report(), util.rrapi.RRApi::report(), rrapi.RRApi::reports(), util.rrapi.RRApi::reports(), util.rrapi.RRApi::tables(), rrapi.RRApi::tables(), rrapi.RRApi::tags(), util.rrapi.RRApi::tags(), rrapi.RRApi::templates(), util.rrapi.RRApi::templates(), util.rrapi.RRApi::workspaces(), and rrapi.RRApi::workspaces().

40  {
41  // get Digis of detID
42 
43  auto found = map_.find(detID);
44  PixelDigiCollection::IndexRange returnIndexRange{};
45  if(found != map_.end()) {
46  returnIndexRange = found->second;
47  }
48 
49  PixelDigiCollection::Range returnRange;
50  returnRange.first = container_.begin()+returnIndexRange.first;
51  returnRange.second = container_.begin()+returnIndexRange.second+1;
52 
53  return returnRange;
54 }
std::vector< PixelDigi > container_
std::pair< ContainerIterator, ContainerIterator > Range
std::pair< unsigned int, unsigned int > IndexRange
void PixelDigiCollection::put ( Range  input,
unsigned int  detID 
)

Definition at line 5 of file PixelDigiCollection.cc.

References begin, container_, end, plotBeamSpotDB::first, estimatePileup::inputRange, and map_.

Referenced by PixelDigiCollection().

5  {
6  // put in Digis of detID
7 
8  // store size of vector before put
10 
11  // put in PixelDigis from input
12  bool first = true;
13 
14  // fill input in temporary vector for sorting
15  std::vector<PixelDigi> temporary;
18  for ( ;sort_begin != sort_end; ++sort_begin ) {
19  temporary.push_back(*sort_begin);
20  }
21  std::sort(temporary.begin(),temporary.end());
22 
23  // iterators over input
26  for ( ;begin != end; ++begin ) {
27  container_.push_back(*begin);
28  if ( first ) {
29  inputRange.first = container_.size()-1;
30  first = false;
31  }
32  }
33  inputRange.second = container_.size()-1;
34 
35  // fill map
36  map_[detID] = inputRange;
37 
38 }
static std::string const input
Definition: EdmProvDump.cc:48
std::vector< PixelDigi > container_
#define end
Definition: vmac.h:39
std::vector< PixelDigi >::const_iterator ContainerIterator
#define begin
Definition: vmac.h:32
inputRange
Get input source.
std::pair< unsigned int, unsigned int > IndexRange

Member Data Documentation

std::vector<PixelDigi> PixelDigiCollection::container_
private

Definition at line 26 of file PixelDigiCollection.h.

Referenced by get(), and put().

Registry PixelDigiCollection::map_
private

Definition at line 27 of file PixelDigiCollection.h.

Referenced by detIDs(), get(), and put().