16 while(cellmap.begin() != cellmap.end())
18 delete cellmap.begin()->second;
19 cellmap.erase(cellmap.begin());
27 map<unsigned int,PHG4CylinderCell *>::const_iterator iter;
28 os <<
"Number of cells: " << size() << endl;
29 for (iter = cellmap.begin(); iter != cellmap.end(); ++iter)
31 os <<
"cell key 0x" << hex << iter->first << dec << endl;
32 (iter->second)->identify();
34 set<int>::const_iterator siter;
35 os <<
"Number of layers: " << num_layers() << endl;
36 for (siter = layers.begin(); siter != layers.end(); ++siter)
38 os <<
"layer : " << *siter << endl;
49 cout <<
" detector id too large: " << detid << endl;
53 unsigned int cellid = cellmap.size();
56 if (cellmap.find(newkey) != cellmap.end())
58 cout <<
" duplicate key: " << newkey <<
" exiting now" << endl;
70 cellmap[key] = newcell;
71 return cellmap.find(key);
77 if(cellmap.find(key)!=cellmap.end())
79 cout <<
"PHG4CylinderCellContainer::AddCylinderCellSpecifyKey: duplicate key: " << key <<
" exiting now" << endl;
84 cellmap[key] = newcell;
85 return cellmap.find(key);
93 cout <<
" detector id too large: " << detid << endl;
102 retpair.first = cellmap.lower_bound(keylow);
103 retpair.second = cellmap.upper_bound(keyup);
109 {
return std::make_pair( cellmap.begin(), cellmap.end() ); }
116 if(it == cellmap.end())
119 it = cellmap.find(key);
132 if(it != cellmap.end())
144 double totalenergy = 0;
145 for (iter = cellmap.begin(); iter != cellmap.end(); ++iter)
147 totalenergy += iter->second->get_edep();
Map::const_iterator ConstIterator
std::pair< ConstIterator, ConstIterator > ConstRange
ConstIterator AddCylinderCell(const unsigned int detid, PHG4CylinderCell *newcylinderCell)
Iterator findOrAddCylinderCell(PHG4CylinderCellDefs::keytype key)
PHG4CylinderCellContainer()
ConstIterator AddCylinderCellSpecifyKey(const PHG4CylinderCellDefs::keytype key, PHG4CylinderCell *newcylinderCell)
PHG4CylinderCell * findCylinderCell(PHG4CylinderCellDefs::keytype key)
void identify(std::ostream &os=std::cout) const
ConstRange getCylinderCells(void) const
return all hist
double getTotalEdep() const
PHG4CylinderCellDefs::keytype genkey(const unsigned int detid)
virtual void set_cell_id(const PHG4CylinderCellDefs::keytype id)
virtual unsigned int get_layer() const
keytype genkey(const unsigned short layer, const unsigned short zbin, const unsigned short iphibin)