49 #include "FastSimulation/Tracking/test/FastTrackAnalyzer.h"
98 doGenPlots_ (iConfig.getParameter<bool>(
"MakeGenPlots")),
99 doHLTPlots_ (iConfig.getParameter<bool>(
"MakeHLTPlots")),
100 doSimTrackPlots_ (iConfig.getParameter<bool>(
"MakeSimTrackPlots")),
101 doSimDigiPlots_ (iConfig.getParameter<bool>(
"MakeSimDigiPlots")),
102 doRecoPlots_ (iConfig.getParameter<bool>(
"MakeRecoPlots")),
103 token_(consumes<edm::
HepMCProduct> (iConfig.getParameter<edm::InputTag>(
"generatorLabel"))),
105 trEvToken_(consumes<trigger::TriggerEvent>(edm::InputTag(
"hltTriggerSummaryAOD"))),
107 dEdxTrackToken_(consumes<edm::ValueMap<
reco::DeDxData> >(edm::InputTag(
"dedxHarmonic2"))),
109 particleIds_ (iConfig.getParameter< std::vector<int> >(
"particleIds")),
110 particleStatus_ (iConfig.getUntrackedParameter<int>(
"particleStatus",1)),
111 ebSimHitToken_ (consumes<edm::
PCaloHitContainer>(iConfig.getParameter<edm::InputTag>(
"EBSimHitCollection"))),
112 eeSimHitToken_ (consumes<edm::
PCaloHitContainer>(iConfig.getParameter<edm::InputTag>(
"EESimHitCollection"))),
113 simTrackToken_ (consumes<edm::
SimTrackContainer>(iConfig.getParameter<edm::InputTag>(
"SimTrackCollection"))),
114 EBDigiCollectionToken_ (consumes<
EBDigiCollection>(iConfig.getParameter<edm::InputTag>(
"EBDigiCollection"))),
115 EEDigiCollectionToken_ (consumes<
EEDigiCollection>(iConfig.getParameter<edm::InputTag>(
"EEDigiCollection")))
121 particlePHist_ = fileService->
make<TH1F>(
"particleP",
"Momentum of gen particle",500,0,2000);
122 particlePtHist_ = fileService->
make<TH1F>(
"particlePt",
"P_{T} of gen particle",500,0,2000);
128 h_genhscp_met = fileService->
make<TH1F>(
"hscp_met" ,
"missing E_{T} hscp" , 100, 0., 1500. );
145 dedxVsp = fileService->
make<TH2F>(
"dedxvsp",
"dedxvsp",100,0,1000,100,0,10);
147 hltmet = fileService->
make<TH1F>(
"HLT_MET",
"MET",3,-1,2);
148 hltjet = fileService->
make<TH1F>(
"HLT_JET",
"JET",3,-1,2);
149 hltmu = fileService->
make<TH1F>(
"HLT_Mu",
"Mu",3,-1,2);
155 simHitsEcalTimeHistEB_ = fileService->
make<TH1F>(
"ecalTimingOfSimHitsEB",
"HSCP SimTrack-matching SimHit time EB [ns]",115,-15,100);
156 simHitsEcalTimeHistEE_ = fileService->
make<TH1F>(
"ecalTimingOfSimHitsEE",
"HSCP SimTrack-matching SimHit time EE [ns]",115,-15,100);
157 simHitsEcalNumHistEB_ = fileService->
make<TH1F>(
"ecalNumberOfSimHitsEB",
"Number of HSCP SimTrack-matching EB sim hits in event",100,0,200);
158 simHitsEcalNumHistEE_ = fileService->
make<TH1F>(
"ecalNumberOfSimHitsEE",
"Number of HSCP SimTrack-matching EE sim hits in event",100,0,200);
159 simHitsEcalEnergyVsTimeHistEB_ = fileService->
make<TH2F>(
"ecalEnergyVsTimeOfSimHitsEB",
"Energy vs. time of HSCP SimTrack-matching EB sim hits in event",115,-15,100,125,-1,4);
160 simHitsEcalEnergyVsTimeHistEE_ = fileService->
make<TH2F>(
"ecalEnergyVsTimeOfSimHitsEE",
"Energy vs. time of HSCP SimTrack-matching EE sim hits in event",115,-15,100,125,-1,4);
169 digisEcalNumHistEB_ = fileService->
make<TH1F>(
"ecalDigisNumberEB",
"Number of EB digis matching simhits in event",200,0,1000);
170 digisEcalNumHistEE_ = fileService->
make<TH1F>(
"ecalDigisNumberEE",
"Number of EE digis matching simhits in event",200,0,1000);
171 digiOccupancyMapEB_ = fileService->
make<TH2F>(
"ecalDigiOccupancyMapEB",
"Occupancy of simhit-matching digis EB;i#phi;i#eta",360,1,361,171,-85,86);
172 digiOccupancyMapEEP_ = fileService->
make<TH2F>(
"ecalDigiOccupancyMapEEM",
"Occupancy of simhit-matching digis EEM;ix;iy",100,1,100,100,1,100);
173 digiOccupancyMapEEM_ = fileService->
make<TH2F>(
"ecalDigiOccupancyMapEEP",
"Occupancy of simhit-matching digis EEP;ix;iy",100,1,100,100,1,100);
181 rpcTimeOfFlightBarrel_[2] = fileService->
make<TH1F>(
"RPCToFLayer3",
"RPC HSCP Time Of Flight Layer 3",50,5,100);
182 rpcTimeOfFlightBarrel_[3] = fileService->
make<TH1F>(
"RPCToFLayer4",
"RPC HSCP Time Of Flight Layer 4",50,5,100);
183 rpcTimeOfFlightBarrel_[4] = fileService->
make<TH1F>(
"RPCToFLayer5",
"RPC HSCP Time Of Flight Layer 5",50,5,100);
184 rpcTimeOfFlightBarrel_[5] = fileService->
make<TH1F>(
"RPCToFLayer6",
"RPC HSCP Time Of Flight Layer 6",50,5,100);
185 rpcBXBarrel_[0] = fileService->
make<TH1F>(
"RPCBXLayer1",
"RPC HSCP BX Layer 1",5,-0.5,4.5);
186 rpcBXBarrel_[1] = fileService->
make<TH1F>(
"RPCBXLayer2",
"RPC HSCP BX Layer 2",5,-0.5,4.5);
187 rpcBXBarrel_[2] = fileService->
make<TH1F>(
"RPCBXLayer3",
"RPC HSCP BX Layer 3",5,-0.5,4.5);
188 rpcBXBarrel_[3] = fileService->
make<TH1F>(
"RPCBXLayer4",
"RPC HSCP BX Layer 4",5,-0.5,4.5);
189 rpcBXBarrel_[4] = fileService->
make<TH1F>(
"RPCBXLayer5",
"RPC HSCP BX Layer 5",5,-0.5,4.5);
190 rpcBXBarrel_[5] = fileService->
make<TH1F>(
"RPCBXLayer6",
"RPC HSCP BX Layer 6",5,-0.5,4.5);
193 rpcTimeOfFlightEndCap_[2]= fileService->
make<TH1F>(
"RPCToFDisk3",
"RPC HSCP Time Of Flight Disk 3",50,5,100);
194 rpcBXEndCap_[0] = fileService->
make<TH1F>(
"RPCBXDisk1",
"RPC HSCP BX Disk 1",5,-0.5,4.5);
195 rpcBXEndCap_[1] = fileService->
make<TH1F>(
"RPCBXDisk2",
"RPC HSCP BX Disk 2",5,-0.5,4.5);
196 rpcBXEndCap_[2] = fileService->
make<TH1F>(
"RPCBXDisk3",
"RPC HSCP BX Disk 3",5,-0.5,4.5);
260 frequencies+=
"PDG ID: ";
262 frequencies+=
" Frequency: ";
266 std::cout <<
"Found PDGIds: " <<
"\n\n" << frequencies << std::endl;
277 double missingpx_nohscp=0;
278 double missingpy_nohscp=0;
280 double scalorEt_nohscp=0;
286 HepMC::GenEvent * myGenEvent =
new HepMC::GenEvent(*(evt->GetEvent()));
287 for(HepMC::GenEvent::particle_iterator
p = myGenEvent->particles_begin();
288 p != myGenEvent->particles_end(); ++
p )
294 if(
abs((*p)->pdg_id())!=12 &&
abs((*p)->pdg_id())!=14 &&
abs((*p)->pdg_id())!=16){
295 missingpx-=(*p)->momentum().px();
296 missingpy-=(*p)->momentum().py();
297 scalorEt+=(*p)->momentum().perp();
305 if(
abs((*p)->pdg_id())!=12 &&
abs((*p)->pdg_id())!=14 &&
abs((*p)->pdg_id())!=16){
306 missingpx_nohscp-=(*p)->momentum().px();
307 missingpy_nohscp-=(*p)->momentum().py();
308 scalorEt_nohscp+=(*p)->momentum().perp();
315 std::pair<std::map<int,int>::iterator,
bool> pair =
particleIdsFoundMap_.insert(std::make_pair<int,int>((*p)->pdg_id(),1));
318 ++(pair.first->second);
321 double mag =
sqrt(
pow((*p)->momentum().px(),2) +
pow((*p)->momentum().py(),2) +
pow((*p)->momentum().pz(),2) );
327 float particleP =
mag;
328 float particleM = (*p)->generated_mass();
349 {
using namespace edm;
355 SimTrackContainer::const_iterator simTrack;
357 for (simTrack = simTracks.begin(); simTrack != simTracks.end(); ++simTrack){
384 std::cout<<
"Tirgger Results not available"<<std::endl;
392 unsigned int TrIndex_Unknown = tr.size();
396 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_Mu40_v1")){
397 if(tr.accept(tr.triggerIndex(
"HLT_Mu40_v1")))
hltmu->Fill(1);
398 else {
hltmu->Fill(0);}
401 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_Mu30_v1")){
405 printf(
"BUG with HLT_Mu\n");
407 for(
unsigned int i=0;
i<tr.size();
i++){
416 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_PFMHT150_v3")){
417 if(tr.accept(tr.triggerIndex(
"HLT_PFMHT150_v3")))
hltmet->Fill(1);
420 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_PFMHT150_v2")){
421 if(tr.accept(tr.triggerIndex(
"HLT_PFMHT150_v2")))
hltmet->Fill(1);
425 printf(
"BUG with HLT_MET\n");
432 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_Jet370_v1")){
433 if(tr.accept(tr.triggerIndex(
"HLT_Jet370_v1")))
hltjet->Fill(1);
436 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_Jet100U")){
440 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_Jet70U")){
444 if(TrIndex_Unknown != tr.triggerIndex(
"HLT_Jet50U")){
448 printf(
"BUG with HLT_Jet\n");
468 if(!ebSimHits.isValid())
470 std::cout <<
"Cannot get EBSimHits from event!" << std::endl;
476 if(!eeSimHits.isValid())
478 std::cout <<
"Cannot get EESimHits from event!" << std::endl;
484 if(!simTracks.isValid())
486 std::cout <<
"Cannot get SimTracks from event!" << std::endl;
492 if(!ebDigis.isValid())
494 std::cout <<
"Cannot get EBDigis from event!" << std::endl;
500 if(!eeDigis.isValid())
502 std::cout <<
"Cannot get EEDigis from event!" << std::endl;
510 int numMatchedSimHitsEventEB = 0;
511 int numMatchedDigisEventEB = 0;
513 phitsEB = ebSimHits.product();
514 for(SimTrackContainer::const_iterator simTrack = simTracks->begin(); simTrack != simTracks->end(); ++simTrack)
522 std::vector<EBDataFrame> myDigisEB;
525 int trackId = simTrack->trackId();
526 PCaloHitContainer::const_iterator simHitItr = phitsEB->begin();
527 while(simHitItr != phitsEB->end())
529 if(simHitItr->geantTrackId()==trackId)
530 mySimHitsEB.push_back(*simHitItr);
533 if(mySimHitsEB.size()==0)
535 std::cout <<
"Could not find matching EB PCaloHits for SimTrack id: " << trackId <<
". Skipping this SimTrack" << std::endl;
540 for(simHitItr = mySimHitsEB.begin(); simHitItr != mySimHitsEB.end(); ++simHitItr)
546 std::cout <<
"SimHit DetId found: " << simHitId <<
" for PDGid: " << simTrack->type() << std::endl;
548 std::cout <<
"SimHit energy: " << simHitItr->energy() <<
" time: " << simHitItr->time() << std::endl;
549 ++numMatchedSimHitsEventEB;
552 while(digiItr != ebDigis->end() && (digiItr->id() != simHitId))
554 if(digiItr==ebDigis->end())
557 std::cout <<
"Could not find simHit detId: " << simHitId <<
"in EBDigiCollection!" << std::endl;
560 std::vector<EBDataFrame>::const_iterator myDigiItr = myDigisEB.begin();
561 while(myDigiItr != myDigisEB.end() && (digiItr->id() != myDigiItr->id()))
563 if(myDigiItr!=myDigisEB.end())
566 ++numMatchedDigisEventEB;
568 myDigisEB.push_back(df);
570 for(
int i=0;
i<10;++
i)
573 for(
int i=0;
i < df.
size(); ++
i)
591 int numMatchedSimHitsEventEE = 0;
592 int numMatchedDigisEventEE = 0;
594 phitsEE = eeSimHits.product();
595 for(SimTrackContainer::const_iterator simTrack = simTracks->begin(); simTrack != simTracks->end(); ++simTrack)
603 std::vector<EEDataFrame> myDigisEE;
606 int trackId = simTrack->trackId();
607 PCaloHitContainer::const_iterator simHitItr = phitsEE->begin();
608 while(simHitItr != phitsEE->end())
610 if(simHitItr->geantTrackId()==trackId)
611 mySimHitsEE.push_back(*simHitItr);
614 if(mySimHitsEE.size()==0)
616 std::cout <<
"Could not find matching EE PCaloHits for SimTrack id: " << trackId <<
". Skipping this SimTrack" << std::endl;
621 for(simHitItr = mySimHitsEE.begin(); simHitItr != mySimHitsEE.end(); ++simHitItr)
627 std::cout <<
"SimHit DetId found: " << simHitId <<
" for PDGid: " << simTrack->type() << std::endl;
629 std::cout <<
"SimHit energy: " << simHitItr->energy() <<
" time: " << simHitItr->time() << std::endl;
630 ++numMatchedSimHitsEventEE;
633 while(digiItr != eeDigis->end() && (digiItr->id() != simHitId))
635 if(digiItr==eeDigis->end())
638 std::cout <<
"Could not find simHit detId: " << simHitId <<
"in EEDigiCollection!" << std::endl;
641 std::vector<EEDataFrame>::const_iterator myDigiItr = myDigisEE.begin();
642 while(myDigiItr != myDigisEE.end() && (digiItr->id() != myDigiItr->id()))
644 if(myDigiItr!=myDigisEE.end())
647 ++numMatchedDigisEventEE;
649 myDigisEE.push_back(df);
651 for(
int i=0;
i<10;++
i)
654 for(
int i=0;
i < df.
size(); ++
i)
677 using namespace reco;
690 for(
size_t i=0;
i<tkTracks->size();
i++){
694 if(trkRef->pt()<5 || trkRef->normalizedChi2()>10)
continue;
697 double hscpgenPt =-1;
699 HepMC::GenEvent * myGenEvent =
new HepMC::GenEvent(*(evt->GetEvent()));
700 for(HepMC::GenEvent::particle_iterator
p = myGenEvent->particles_begin();
701 p != myGenEvent->particles_end(); ++
p )
711 double distance =
pow((*p)->momentum().eta()-trkRef->eta(),2)+
pow((*p)->momentum().phi()-trkRef->phi(),2);
712 distance =
sqrt(distance);
715 hscpgenPt= (*p)->momentum().perp();
722 double dedx = dEdxTrack[trkRef].dEdx();
723 dedxVsp->Fill( trkRef->p(),dedx);
735 std::vector<Handle<edm::PSimHitContainer> > theSimHitContainers;
743 std::vector<PSimHit> theSimHits;
745 for (
int i = 0;
i < int(theSimHitContainers.size());
i++){
746 theSimHits.insert(theSimHits.end(),theSimHitContainers.at(
i)->begin(),theSimHitContainers.at(
i)->end());
750 for (std::vector<PSimHit>::const_iterator iHit = theSimHits.begin(); iHit != theSimHits.end(); iHit++){
756 DetId theDetUnitId((*iHit).detUnitId());
771 GlobalPoint SimHitInGlobal = RPCSurface.toGlobal((*iHit).localPosition());
773 std::cout<<
"\t\t We have an RPC Sim Hit! in t="<<(*iHit).timeOfFlight()<<
"ns "<<rpcsrv.
name()<<
" Global postition="<<SimHitInGlobal<<std::endl;
778 else if(rollId.
station()==1&&rollId.
layer()==2) layer = 2;
779 else if(rollId.
station()==2&&rollId.
layer()==1) layer = 3;
780 else if(rollId.
station()==2&&rollId.
layer()==2) layer = 4;
781 else if(rollId.
station()==3) layer = 5;
782 else if(rollId.
station()==4) layer = 6;
790 std::cout<<
"\t\t r="<<SimHitInGlobal.
mag()<<
" phi="<<SimHitInGlobal.
phi()<<
" eta="<<SimHitInGlobal.
eta()<<std::endl;
794 float minres = 3000.;
796 std::cout<<
"\t \t \t \t Getting RecHits in Roll Asociated"<<std::endl;
798 typedef std::pair<RPCRecHitCollection::const_iterator, RPCRecHitCollection::const_iterator> rangeRecHits;
799 rangeRecHits recHitCollection =
rpcRecHits->get(rollId);
804 for(recHit = recHitCollection.first; recHit != recHitCollection.second ; recHit++){
806 float res=(*iHit).localPosition().x()- recHitPos.
x();
807 if(fabs(res)<fabs(minres)){
809 cluSize = recHit->clusterSize();
811 std::cout<<
"\t New Min Res "<<res<<
"cm."<<std::endl;
830 ostringstream myStream;
831 myStream << num << flush;
832 return(myStream.str());
842 unsigned int filterIndex = trEv.
filterIndex(InputPath);
848 const int nI(VIDS.size());
849 const int nK(KEYS.size());
855 if(!averageThreshold){
856 int NObjectAboveThresholdObserved = 0;
857 for (
int i=0;
i!=
n; ++
i) {
858 if(TOC[KEYS[
i]].
pt()> NewThreshold && fabs(TOC[KEYS[
i]].
eta())<etaCut) NObjectAboveThresholdObserved++;
861 if(NObjectAboveThresholdObserved>=NObjectAboveThreshold)
return true;
864 std::vector<double> ObjPt;
866 for (
int i=0;
i!=
n; ++
i) {
867 ObjPt.push_back(TOC[KEYS[
i]].
pt());
870 if((
int)(ObjPt.size())<NObjectAboveThreshold)
return false;
874 for(
int i=0;
i<NObjectAboveThreshold;
i++){
875 Average+= ObjPt[ObjPt.size()-1-
i];
876 }Average/=NObjectAboveThreshold;
879 if(Average>NewThreshold)
return true;
void getManyByType(std::vector< Handle< PROD > > &results) const
TH2F * simHitsEcalDigiMatchEnergyVsTimeHistEE_
virtual TriggerResultsByName triggerResultsByName(std::string const &process) const
TH1F * rpcTimeOfFlightBarrel_[6]
edm::EDGetTokenT< EEDigiCollection > EEDigiCollectionToken_
TH1F * rpcTimeOfFlightEndCap_[3]
std::vector< PCaloHit > PCaloHitContainer
TH1F * simHitsEcalTimeHistEE_
edm::EDGetTokenT< EBDigiCollection > EBDigiCollectionToken_
boost::transform_iterator< IterHelp, boost::counting_iterator< int > > const_iterator
edm::EDGetTokenT< edm::PCaloHitContainer > eeSimHitToken_
The single EDProduct to be saved for each event (AOD case)
trigger::size_type sizeFilters() const
virtual void analyze(const edm::Event &, const edm::EventSetup &)
bool getByToken(EDGetToken token, Handle< PROD > &result) const
TH2F * simHitsEcalEnergyVsTimeHistEB_
T mag() const
The vector magnitude. Equivalent to sqrt(vec.mag2())
#define DEFINE_FWK_MODULE(type)
TH1F * simHitsEcalEnergyHistEE_
TH1F * h_genhscp_met_nohscp
edm::EDGetTokenT< edm::PCaloHitContainer > ebSimHitToken_
TH1F * digisEcalNumHistEE_
const Keys & filterKeys(trigger::size_type index) const
Geom::Phi< T > phi() const
trigger::size_type filterIndex(const edm::InputTag &filterTag) const
find index of filter in data-member vector from filter tag
std::vector< Track > TrackCollection
collection of Tracks
TH2F * digiOccupancyMapEEM_
EcalMGPASample sample(int i) const
T * make(const Args &...args) const
make new ROOT object
bool IncreasedTreshold(const trigger::TriggerEvent &trEv, const edm::InputTag &InputPath, double NewThreshold, double etaCut, int NObjectAboveThreshold, bool averageThreshold)
TH1F * cluSizeDistribution_
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
TH1F * simHitsEcalDigiMatchTimeHistEB_
const Plane & surface() const
The nominal surface of the GeomDet.
void makeSimTrackPlots(const edm::Event &iEvent)
HSCPValidator(const edm::ParameterSet &)
void makeRecoPlots(const edm::Event &iEvent)
std::vector< int > particleIds_
std::map< int, int > particleIdsFoundMap_
TH1F * simTrackParticlePtHist_
edm::EDGetTokenT< edm::SimTrackContainer > simTracksToken_
TH1F * simHitsEcalNumHistEE_
const Vids & filterIds(trigger::size_type index) const
TH2F * digiOccupancyMapEEP_
virtual std::string name()
TH1F * h_genhscp_scaloret
const TriggerObjectCollection & getObjects() const
void Fill(HcalDetId &id, double val, std::vector< TH2F > &depth)
TH2F * digiOccupancyMapEB_
TH1F * efficiencyRPCRecHitSimDigis_
TH2F * simHitsEcalDigiMatchEnergyVsTimeHistEB_
TH1F * simHitsEcalDigiMatchEnergyHistEE_
TH1F * h_genhscp_scaloret_nohscp
edm::EDGetTokenT< edm::HepMCProduct > token_
Abs< T >::type abs(const T &t)
TH1F * simHitsEcalDigiMatchTimeHistEE_
std::string intToString(int num)
void makeSimDigiPlotsECAL(const edm::Event &iEvent)
edm::EDGetTokenT< edm::SimTrackContainer > simTrackToken_
edm::EDGetTokenT< RPCRecHitCollection > rpcRecHitsToken_
TH2F * simHitsEcalEnergyVsTimeHistEE_
std::vector< TriggerObject > TriggerObjectCollection
collection of trigger physics objects (e.g., all isolated muons)
TH1F * residualsRPCRecHitSimDigis_
TH1F * simHitsEcalDigiMatchIEtaHist_
TH1F * simHitsEcalNumHistEB_
void makeGenPlots(const edm::Event &iEvent)
edm::Service< TFileService > fileService
edm::EDGetTokenT< trigger::TriggerEvent > trEvToken_
TH1F * digisEcalNumHistEB_
TH1F * simTrackParticleEtaHist_
TH1F * simHitsEcalDigiMatchIPhiHist_
std::vector< size_type > Keys
TH1F * simHitsEcalDigiMatchEnergyHistEB_
edm::Ref< TrackCollection > TrackRef
persistent reference to a Track
TH1F * particleStatusHist_
edm::ESHandle< RPCGeometry > rpcGeo
TH1F * simTrackParticlePhiHist_
void makeSimDigiPlotsRPC(const edm::Event &iEvent)
edm::EDGetTokenT< reco::TrackCollection > tkTracksToken_
void makeHLTPlots(const edm::Event &iEvent)
TH1F * simTrackParticleBetaHist_
edm::EDGetTokenT< edm::ValueMap< reco::DeDxData > > dEdxTrackToken_
std::vector< SimTrack > SimTrackContainer
TH1F * simHitsEcalEnergyHistEB_
Power< A, B >::type pow(const A &a, const B &b)
TH1F * simTrackParticlePHist_
TH1F * particleBetaInverseHist_
int adc() const
get the ADC sample (12 bits)
TH1F * simHitsEcalTimeHistEB_
int region() const
Region id: 0 for Barrel, +/-1 For +/- Endcap.