CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
HcalTB04Analysis Class Reference
Inheritance diagram for HcalTB04Analysis:
SimProducer Observer< const BeginOfRun * > Observer< const BeginOfEvent * > Observer< const EndOfEvent * > Observer< const G4Step * > SimWatcher

Public Member Functions

 HcalTB04Analysis (const edm::ParameterSet &p)
 
void produce (edm::Event &, const edm::EventSetup &) override
 
 ~HcalTB04Analysis () override
 
- Public Member Functions inherited from SimProducer
void registerProducts (edm::ProducesCollector producesCollector)
 
 SimProducer ()
 
- Public Member Functions inherited from SimWatcher
 SimWatcher ()
 
virtual ~SimWatcher ()
 
- Public Member Functions inherited from Observer< const BeginOfRun * >
 Observer ()
 
void slotForUpdate (const BeginOfRun * iT)
 
virtual ~Observer ()
 
- Public Member Functions inherited from Observer< const BeginOfEvent * >
 Observer ()
 
void slotForUpdate (const BeginOfEvent * iT)
 
virtual ~Observer ()
 
- Public Member Functions inherited from Observer< const EndOfEvent * >
 Observer ()
 
void slotForUpdate (const EndOfEvent * iT)
 
virtual ~Observer ()
 
- Public Member Functions inherited from Observer< const G4Step * >
 Observer ()
 
void slotForUpdate (const G4Step * iT)
 
virtual ~Observer ()
 

Private Member Functions

void clear ()
 
void fillBuffer (const EndOfEvent *evt)
 
void fillEvent (PHcalTB04Info &)
 
void finalAnalysis ()
 
 HcalTB04Analysis (const HcalTB04Analysis &)=delete
 
void init ()
 
const HcalTB04Analysisoperator= (const HcalTB04Analysis &)=delete
 
void qieAnalysis (CLHEP::HepRandomEngine *)
 
double scale (int det, int layer)
 
double timeOfFlight (int det, int layer, double eta)
 
int unitID (uint32_t id)
 
void update (const BeginOfEvent *evt) override
 This routine will be called when the appropriate signal arrives. More...
 
void update (const BeginOfRun *run) override
 This routine will be called when the appropriate signal arrives. More...
 
void update (const EndOfEvent *evt) override
 This routine will be called when the appropriate signal arrives. More...
 
void update (const G4Step *step) override
 This routine will be called when the appropriate signal arrives. More...
 
void xtalAnalysis (CLHEP::HepRandomEngine *)
 

Private Attributes

G4RotationMatrix * beamline_RM
 
double beamOffset
 
int count
 
std::vector< CaloHitecalHitCache
 
double ecalNoise
 
double eecalq
 
double eecals
 
double ehcalq
 
double ehcals
 
std::vector< double > enois
 
std::vector< double > eqeta
 
std::vector< double > eqie
 
std::vector< double > eqlay
 
std::vector< double > eqphi
 
std::vector< double > eseta
 
std::vector< double > esime
 
std::vector< double > esimh
 
std::vector< double > eslay
 
std::vector< double > esphi
 
double etaInit
 
double etotq
 
double etots
 
int evNum
 
std::vector< CaloHithcalHitCache
 
std::vector< CaloHithcalHitLayer
 
bool hcalOnly
 
HcalTB04Histohisto
 
int iceta
 
int icphi
 
std::vector< uint32_t > idEcal
 
std::vector< int > idHcal
 
std::vector< uint32_t > idTower
 
std::vector< int > idXtal
 
int mode
 
HcalQiemyQie
 
std::vector< std::string > names
 
int nCrystal
 
int nPrimary
 
int nTower
 
int particleType
 
double phiInit
 
double pInit
 
bool pvFound
 
G4ThreeVector pvMomentum
 
G4ThreeVector pvPosition
 
int pvType
 
G4ThreeVector pvUVW
 
double scaleHB0
 
double scaleHB16
 
double scaleHE0
 
double scaleHO
 
std::vector< double > secEkin
 
std::vector< G4ThreeVector > secMomentum
 
std::vector< int > secPartID
 
std::vector< int > secTrackID
 
std::vector< int > shortLivedSecondaries
 
int type
 

Additional Inherited Members

- Protected Member Functions inherited from SimProducer
template<class T >
void produces ()
 
template<class T >
void produces (const std::string &instanceName)
 

Detailed Description

Definition at line 72 of file HcalTB04Analysis.cc.

Constructor & Destructor Documentation

◆ HcalTB04Analysis() [1/2]

HcalTB04Analysis::HcalTB04Analysis ( const edm::ParameterSet p)

Definition at line 148 of file HcalTB04Analysis.cc.

148  : myQie(nullptr), histo(nullptr) {
149  edm::ParameterSet m_Anal = p.getParameter<edm::ParameterSet>("HcalTB04Analysis");
150  hcalOnly = m_Anal.getParameter<bool>("HcalOnly");
151  mode = m_Anal.getParameter<int>("Mode");
152  type = m_Anal.getParameter<int>("Type");
153  ecalNoise = m_Anal.getParameter<double>("EcalNoise");
154  scaleHB0 = m_Anal.getParameter<double>("ScaleHB0");
155  scaleHB16 = m_Anal.getParameter<double>("ScaleHB16");
156  scaleHO = m_Anal.getParameter<double>("ScaleHO");
157  scaleHE0 = m_Anal.getParameter<double>("ScaleHE0");
158  names = m_Anal.getParameter<std::vector<std::string> >("Names");
159  beamOffset = -m_Anal.getParameter<double>("BeamPosition") * cm;
160  double fMinEta = m_Anal.getParameter<double>("MinEta");
161  double fMaxEta = m_Anal.getParameter<double>("MaxEta");
162  double fMinPhi = m_Anal.getParameter<double>("MinPhi");
163  double fMaxPhi = m_Anal.getParameter<double>("MaxPhi");
164  double beamEta = (fMaxEta + fMinEta) / 2.;
165  double beamPhi = (fMaxPhi + fMinPhi) / 2.;
166  double beamThet = 2 * atan(exp(-beamEta));
167  if (beamPhi < 0)
168  beamPhi += twopi;
169  iceta = (int)(beamEta / 0.087) + 1;
170  icphi = (int)(fabs(beamPhi) / 0.087) + 5;
171  if (icphi > 72)
172  icphi -= 73;
173 
174  produces<PHcalTB04Info>();
175 
176  beamline_RM = new G4RotationMatrix;
177  beamline_RM->rotateZ(-beamPhi);
178  beamline_RM->rotateY(-beamThet);
179 
180  edm::LogVerbatim("HcalTBSim")
181  << "HcalTB04:: Initialised as observer of BeginOf Job/BeginOfRun/BeginOfEvent/G4Step/EndOfEvent with Parameter "
182  "values:\n \thcalOnly = "
183  << hcalOnly << "\tecalNoise = " << ecalNoise << "\n\tMode = " << mode << " (0: HB2 Standard; 1:HB2 Segmented)"
184  << "\tType = " << type << " (0: HB; 1 HE; 2 HB+HE)\n\tbeamOffset = " << beamOffset << "\ticeta = " << iceta
185  << "\ticphi = " << icphi << "\n\tbeamline_RM = " << *beamline_RM;
186 
187  init();
188 
189  myQie = new HcalQie(p);
190  histo = new HcalTB04Histo(m_Anal);
191 }

References beamline_RM, beamOffset, ecalNoise, JetChargeProducer_cfi::exp, edm::ParameterSet::getParameter(), hcalOnly, histo, iceta, icphi, init(), createfilelist::int, mode, myQie, names, AlCaHLTBitMon_ParallelJobs::p, scaleHB0, scaleHB16, scaleHE0, and scaleHO.

◆ ~HcalTB04Analysis()

HcalTB04Analysis::~HcalTB04Analysis ( )
override

Definition at line 193 of file HcalTB04Analysis.cc.

193  {
194  edm::LogVerbatim("HcalTBSim") << "\n --------> Total number of selected entries : " << count << "\nPointers:: QIE "
195  << myQie << " Histo " << histo;
196  if (myQie) {
197  delete myQie;
198  myQie = nullptr;
199  }
200  if (histo) {
201  delete histo;
202  histo = nullptr;
203  }
204 }

References count, histo, and myQie.

◆ HcalTB04Analysis() [2/2]

HcalTB04Analysis::HcalTB04Analysis ( const HcalTB04Analysis )
privatedelete

Member Function Documentation

◆ clear()

void HcalTB04Analysis::clear ( void  )
private

Definition at line 1013 of file HcalTB04Analysis.cc.

1013  {
1014  pvFound = false;
1015  pvType = -2;
1016  pvPosition = G4ThreeVector();
1017  pvMomentum = G4ThreeVector();
1018  pvUVW = G4ThreeVector();
1019  secTrackID.clear();
1020  secPartID.clear();
1021  secMomentum.clear();
1022  secEkin.clear();
1023  shortLivedSecondaries.clear();
1024 
1025  ecalHitCache.erase(ecalHitCache.begin(), ecalHitCache.end());
1026  hcalHitCache.erase(hcalHitCache.begin(), hcalHitCache.end());
1027  hcalHitLayer.erase(hcalHitLayer.begin(), hcalHitLayer.end());
1028  nPrimary = particleType = 0;
1029  pInit = etaInit = phiInit = 0;
1030 
1031  esimh.clear();
1032  eqie.clear();
1033  esimh.reserve(nTower);
1034  eqie.reserve(nTower);
1035  for (int i = 0; i < nTower; i++) {
1036  esimh.push_back(0.);
1037  eqie.push_back(0.);
1038  }
1039  esime.clear();
1040  enois.clear();
1041  esime.reserve(nCrystal);
1042  enois.reserve(nCrystal);
1043  for (int i = 0; i < nCrystal; i++) {
1044  esime.push_back(0.);
1045  enois.push_back(0.);
1046  }
1047 }

References ecalHitCache, enois, eqie, esime, esimh, etaInit, hcalHitCache, hcalHitLayer, mps_fire::i, nCrystal, nPrimary, nTower, particleType, phiInit, pInit, pvFound, pvMomentum, pvPosition, pvType, pvUVW, secEkin, secMomentum, secPartID, secTrackID, and shortLivedSecondaries.

Referenced by init(), and update().

◆ fillBuffer()

void HcalTB04Analysis::fillBuffer ( const EndOfEvent evt)
private

Definition at line 471 of file HcalTB04Analysis.cc.

471  {
472  std::vector<CaloHit> hhits, hhitl;
473  int idHC, j;
474  CaloG4HitCollection* theHC;
475  std::map<int, float, std::less<int> > primaries;
476  double etot1 = 0, etot2 = 0;
477 
478  // Look for the Hit Collection of HCal
479  G4HCofThisEvent* allHC = (*evt)()->GetHCofThisEvent();
480  std::string sdName = names[0];
481  idHC = G4SDManager::GetSDMpointer()->GetCollectionID(sdName);
482  theHC = (CaloG4HitCollection*)allHC->GetHC(idHC);
483 #ifdef EDM_ML_DEBUG
484  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Hit Collection for " << sdName << " of ID " << idHC
485  << " is obtained at " << theHC << " with " << theHC->entries() << " entries";
486 #endif
487  int thehc_entries = theHC->entries();
488  if (idHC >= 0 && theHC != nullptr) {
489  hhits.reserve(theHC->entries());
490  hhitl.reserve(theHC->entries());
491  for (j = 0; j < thehc_entries; j++) {
492  CaloG4Hit* aHit = (*theHC)[j];
493  double e = aHit->getEnergyDeposit() / CLHEP::GeV;
494  double time = aHit->getTimeSlice();
495  math::XYZPoint pos = aHit->getEntry();
496  unsigned int id = aHit->getUnitID();
497  double theta = pos.theta();
498  double eta = -log(tan(theta * 0.5));
499  double phi = pos.phi();
500  int det, z, group, ieta, iphi, layer;
501  HcalTestNumbering::unpackHcalIndex(id, det, z, group, ieta, iphi, layer);
502  double jitter = time - timeOfFlight(det, layer, eta);
503  if (jitter < 0)
504  jitter = 0;
505  if (e < 0 || e > 1.)
506  e = 0;
507  double escl = e * scale(det, layer);
508  unsigned int idx = HcalTBNumberingScheme::getUnitID(id, mode);
509  CaloHit hit(det, layer, escl, eta, phi, jitter, idx);
510  hhits.push_back(hit);
511  CaloHit hitl(det, layer, escl, eta, phi, jitter, id);
512  hhitl.push_back(hitl);
513  primaries[aHit->getTrackID()] += e;
514  etot1 += escl;
515 #ifdef EDM_ML_DEBUG
516  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Hcal Hit i/p " << j << " ID 0x" << std::hex << id << " 0x"
517  << idx << std::dec << " time " << std::setw(6) << time << " " << std::setw(6)
518  << jitter << " theta " << std::setw(8) << theta << " eta " << std::setw(8) << eta
519  << " phi " << std::setw(8) << phi << " e " << std::setw(8) << e << " "
520  << std::setw(8) << escl;
521 #endif
522  }
523  }
524 
525  // Add hits in the same channel within same time slice
526  std::vector<CaloHit>::iterator itr;
527  int nHit = hhits.size();
528  std::vector<CaloHit*> hits(nHit);
529  for (j = 0, itr = hhits.begin(); itr != hhits.end(); j++, itr++) {
530  hits[j] = &hhits[j];
531  }
532  sort(hits.begin(), hits.end(), CaloHitIdMore());
533  std::vector<CaloHit*>::iterator k1, k2;
534  int nhit = 0;
535  for (k1 = hits.begin(); k1 != hits.end(); k1++) {
536  int det = (**k1).det();
537  int layer = (**k1).layer();
538  double ehit = (**k1).e();
539  double eta = (**k1).eta();
540  double phi = (**k1).phi();
541  double jitter = (**k1).t();
542  uint32_t unitID = (**k1).id();
543  int jump = 0;
544  for (k2 = k1 + 1; k2 != hits.end() && fabs(jitter - (**k2).t()) < 1 && unitID == (**k2).id(); k2++) {
545  ehit += (**k2).e();
546  jump++;
547  }
548  nhit++;
549  CaloHit hit(det, layer, ehit, eta, phi, jitter, unitID);
550  hcalHitCache.push_back(hit);
551  etot2 += ehit;
552  k1 += jump;
553 #ifdef EDM_ML_DEBUG
554  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Hcal Hit store " << nhit << " ID 0x" << std::hex << unitID
555  << std::dec << " time " << std::setw(6) << jitter << " eta " << std::setw(8) << eta
556  << " phi " << std::setw(8) << phi << " e " << std::setw(8) << ehit;
557 #endif
558  }
559 #ifdef EDM_ML_DEBUG
560  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Stores " << nhit << " HCal hits from " << nHit
561  << " input hits E(Hcal) " << etot1 << " " << etot2;
562 #endif
563  //Repeat for Hit in each layer (hhits and hhitl sizes are the same)
564  for (j = 0, itr = hhitl.begin(); itr != hhitl.end(); j++, itr++) {
565  hits[j] = &hhitl[j];
566  }
567  sort(hits.begin(), hits.end(), CaloHitIdMore());
568  int nhitl = 0;
569  double etotl = 0;
570  for (k1 = hits.begin(); k1 != hits.end(); k1++) {
571  int det = (**k1).det();
572  int layer = (**k1).layer();
573  double ehit = (**k1).e();
574  double eta = (**k1).eta();
575  double phi = (**k1).phi();
576  double jitter = (**k1).t();
577  uint32_t unitID = (**k1).id();
578  int jump = 0;
579  for (k2 = k1 + 1; k2 != hits.end() && fabs(jitter - (**k2).t()) < 1 && unitID == (**k2).id(); k2++) {
580  ehit += (**k2).e();
581  jump++;
582  }
583  nhitl++;
584  CaloHit hit(det, layer, ehit, eta, phi, jitter, unitID);
585  hcalHitLayer.push_back(hit);
586  etotl += ehit;
587  k1 += jump;
588 #ifdef EDM_ML_DEBUG
589  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Hcal Hit store " << nhitl << " ID 0x" << std::hex << unitID
590  << std::dec << " time " << std::setw(6) << jitter << " eta " << std::setw(8) << eta
591  << " phi " << std::setw(8) << phi << " e " << std::setw(8) << ehit;
592 #endif
593  }
594 #ifdef EDM_ML_DEBUG
595  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Stores " << nhitl << " HCal hits from " << nHit
596  << " input hits E(Hcal) " << etot1 << " " << etotl;
597 #endif
598  // Look for the Hit Collection of ECal
599  std::vector<CaloHit> ehits;
600  sdName = names[1];
601  idHC = G4SDManager::GetSDMpointer()->GetCollectionID(sdName);
602  theHC = (CaloG4HitCollection*)allHC->GetHC(idHC);
603  etot1 = etot2 = 0;
604 #ifdef EDM_ML_DEBUG
605  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Hit Collection for " << sdName << " of ID " << idHC
606  << " is obtained at " << theHC << " with " << theHC->entries() << " entries";
607 #endif
608  if (idHC >= 0 && theHC != nullptr) {
609  thehc_entries = theHC->entries();
610  ehits.reserve(theHC->entries());
611  for (j = 0; j < thehc_entries; j++) {
612  CaloG4Hit* aHit = (*theHC)[j];
613  double e = aHit->getEnergyDeposit() / CLHEP::GeV;
614  double time = aHit->getTimeSlice();
615  if (e < 0 || e > 100000.)
616  e = 0;
617  if (e > 0) {
618  math::XYZPoint pos = aHit->getEntry();
619  unsigned int id = aHit->getUnitID();
620  double theta = pos.theta();
621  double eta = -log(tan(theta * 0.5));
622  double phi = pos.phi();
623  int det, z, group, ieta, iphi, layer;
624  HcalTestNumbering::unpackHcalIndex(id, det, z, group, ieta, iphi, layer);
625  CaloHit hit(det, 0, e, eta, phi, time, id);
626  ehits.push_back(hit);
627  primaries[aHit->getTrackID()] += e;
628  etot1 += e;
629 #ifdef EDM_ML_DEBUG
630  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Ecal Hit i/p " << j << " ID 0x" << std::hex << id
631  << std::dec << " time " << std::setw(6) << time << " theta " << std::setw(8)
632  << theta << " eta " << std::setw(8) << eta << " phi " << std::setw(8) << phi
633  << " e " << std::setw(8) << e;
634 #endif
635  }
636  }
637  }
638 
639  // Add hits in the same channel within same time slice
640  nHit = ehits.size();
641  std::vector<CaloHit*> hite(nHit);
642  for (j = 0, itr = ehits.begin(); itr != ehits.end(); j++, itr++) {
643  hite[j] = &ehits[j];
644  }
645  sort(hite.begin(), hite.end(), CaloHitIdMore());
646  nhit = 0;
647  for (k1 = hite.begin(); k1 != hite.end(); k1++) {
648  int det = (**k1).det();
649  int layer = (**k1).layer();
650  double ehit = (**k1).e();
651  double eta = (**k1).eta();
652  double phi = (**k1).phi();
653  double jitter = (**k1).t();
654  uint32_t unitID = (**k1).id();
655  int jump = 0;
656  for (k2 = k1 + 1; k2 != hite.end() && fabs(jitter - (**k2).t()) < 1 && unitID == (**k2).id(); k2++) {
657  ehit += (**k2).e();
658  jump++;
659  }
660  nhit++;
661  CaloHit hit(det, layer, ehit, eta, phi, jitter, unitID);
662  ecalHitCache.push_back(hit);
663  etot2 += ehit;
664  k1 += jump;
665 #ifdef EDM_ML_DEBUG
666  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Ecal Hit store " << nhit << " ID 0x" << std::hex << unitID
667  << std::dec << " time " << std::setw(6) << jitter << " eta " << std::setw(8) << eta
668  << " phi " << std::setw(8) << phi << " e " << std::setw(8) << ehit;
669 #endif
670  }
671 #ifdef EDM_ML_DEBUG
672  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Stores " << nhit << " ECal hits from " << nHit
673  << " input hits E(Ecal) " << etot1 << " " << etot2;
674 #endif
675  // Find Primary info:
676  nPrimary = (int)(primaries.size());
677  int trackID = 0;
678  G4PrimaryParticle* thePrim = nullptr;
679  int nvertex = (*evt)()->GetNumberOfPrimaryVertex();
680 #ifdef EDM_ML_DEBUG
681  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Event has " << nvertex << " verteices";
682 #endif
683  if (nvertex <= 0)
684  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis::EndOfEvent ERROR: no vertex found for event " << evNum;
685  for (int i = 0; i < nvertex; i++) {
686  G4PrimaryVertex* avertex = (*evt)()->GetPrimaryVertex(i);
687  if (avertex == nullptr) {
688  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis::EndOfEvent ERR: pointer to vertex = 0 for event " << evNum;
689  } else {
690  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::Vertex number :" << i << " " << avertex->GetPosition();
691  int npart = avertex->GetNumberOfParticle();
692  if (npart == 0)
693  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis::End Of Event ERR: no primary!";
694  if (thePrim == nullptr)
695  thePrim = avertex->GetPrimary(trackID);
696  }
697  }
698 
699  if (thePrim != nullptr) {
700  double px = thePrim->GetPx();
701  double py = thePrim->GetPy();
702  double pz = thePrim->GetPz();
703  double p = std::sqrt(pow(px, 2.) + pow(py, 2.) + pow(pz, 2.));
704  pInit = p / CLHEP::GeV;
705  if (p == 0)
706  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis:: EndOfEvent ERR: primary has p=0 ";
707  else {
708  double costheta = pz / p;
709  double theta = acos(std::min(std::max(costheta, -1.), 1.));
710  etaInit = -log(tan(theta / 2));
711  if (px != 0 || py != 0)
712  phiInit = atan2(py, px);
713  }
714  particleType = thePrim->GetPDGcode();
715  } else
716  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis::EndOfEvent ERR: could not find primary";
717 }

References TauDecayModes::dec, MillePedeFileConverter_cfg::e, ecalHitCache, PVValHelper::eta, etaInit, evNum, CaloG4Hit::getEnergyDeposit(), CaloG4Hit::getEntry(), CaloG4Hit::getTimeSlice(), CaloG4Hit::getTrackID(), HcalTBNumberingScheme::getUnitID(), CaloG4Hit::getUnitID(), GeV, watchdog::group, hcalHitCache, hcalHitLayer, hfClusterShapes_cfi::hits, mps_fire::i, training_settings::idx, LEDCalibrationChannels::ieta, createfilelist::int, LEDCalibrationChannels::iphi, dqmiolumiharvest::j, dqm-mbProfile::log, SiStripPI::max, min(), mode, names, npart, nPrimary, AlCaHLTBitMon_ParallelJobs::p, particleType, phi, phiInit, pInit, funct::pow(), multPhiCorr_741_25nsDY_cfi::px, multPhiCorr_741_25nsDY_cfi::py, scale(), mathSSE::sqrt(), AlCaHLTBitMon_QueryRunRegistry::string, funct::tan(), theta(), ntuplemaker::time, timeOfFlight(), unitID(), HcalTestNumbering::unpackHcalIndex(), and z.

Referenced by update().

◆ fillEvent()

void HcalTB04Analysis::fillEvent ( PHcalTB04Info product)
private

Definition at line 940 of file HcalTB04Analysis.cc.

940  {
941  //Setup the ID's
942  product.setIDs(idHcal, idXtal);
943 
944  //Beam Information
946 
947  //Energy deposits in the crystals and towers
948  product.setEdepHcal(esimh, eqie);
949  product.setEdepHcal(esime, enois);
950 
951  // Total Energy
952  product.setEdep(etots, eecals, ehcals, etotq, eecalq, ehcalq);
953 
954  // Lateral Profile
955  product.setTrnsProf(eseta, eqeta, esphi, eqphi);
956 
957  // Longitudianl profile
958  product.setLongProf(eslay, eqlay);
959 
960  //Save Hits
961  int i, nhit = 0;
962  std::vector<CaloHit>::iterator itr;
963  for (i = 0, itr = ecalHitCache.begin(); itr != ecalHitCache.end(); i++, itr++) {
964  uint32_t id = itr->id();
965  int det, z, group, ieta, iphi, lay;
967  product.saveHit(det, lay, ieta, iphi, itr->e(), itr->t());
968  nhit++;
969 #ifdef EDM_ML_DEBUG
970  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Save Hit " << std::setw(3) << i + 1 << " ID 0x" << std::hex
971  << group << std::dec << " " << std::setw(2) << det << " " << std::setw(2) << lay
972  << " " << std::setw(1) << z << " " << std::setw(3) << ieta << " " << std::setw(3)
973  << iphi << " T " << std::setw(6) << itr->t() << " E " << std::setw(6) << itr->e();
974 #endif
975  }
976  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Saves " << nhit << " hits from Crystals";
977  int hit = nhit;
978  nhit = 0;
979 
980  for (i = hit, itr = hcalHitCache.begin(); itr != hcalHitCache.end(); i++, itr++) {
981  uint32_t id = itr->id();
982  int det, z, group, ieta, iphi, lay;
984  product.saveHit(det, lay, ieta, iphi, itr->e(), itr->t());
985  nhit++;
986 #ifdef EDM_ML_DEBUG
987  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Save Hit " << std::setw(3) << i + 1 << " ID 0x" << std::hex
988  << group << std::dec << " " << std::setw(2) << det << " " << std::setw(2) << lay
989  << " " << std::setw(1) << z << " " << std::setw(3) << ieta << " " << std::setw(3)
990  << iphi << " T " << std::setw(6) << itr->t() << " E " << std::setw(6) << itr->e();
991 #endif
992  }
993  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Saves " << nhit << " hits from HCal";
994 
995  //Vertex associated quantities
996  product.setVtxPrim(evNum,
997  pvType,
998  pvPosition.x(),
999  pvPosition.y(),
1000  pvPosition.z(),
1001  pvUVW.x(),
1002  pvUVW.y(),
1003  pvUVW.z(),
1004  pvMomentum.x(),
1005  pvMomentum.y(),
1006  pvMomentum.z());
1007  for (unsigned int i = 0; i < secTrackID.size(); i++) {
1008  product.setVtxSec(
1010  }
1011 }

References TauDecayModes::dec, ecalHitCache, eecalq, eecals, ehcalq, ehcals, enois, eqeta, eqie, eqlay, eqphi, eseta, esime, esimh, eslay, esphi, etaInit, etotq, etots, evNum, watchdog::group, hcalHitCache, mps_fire::i, hit::id, idHcal, idXtal, LEDCalibrationChannels::ieta, LEDCalibrationChannels::iphi, nPrimary, particleType, phiInit, pInit, pvMomentum, pvPosition, pvType, pvUVW, PHcalTB04Info::saveHit(), secEkin, secMomentum, secPartID, secTrackID, PHcalTB04Info::setEdep(), PHcalTB04Info::setEdepHcal(), PHcalTB04Info::setIDs(), PHcalTB04Info::setLongProf(), PHcalTB04Info::setPrimary(), PHcalTB04Info::setTrnsProf(), PHcalTB04Info::setVtxPrim(), PHcalTB04Info::setVtxSec(), HcalTestNumbering::unpackHcalIndex(), x, y, and z.

Referenced by produce().

◆ finalAnalysis()

void HcalTB04Analysis::finalAnalysis ( )
private

Definition at line 829 of file HcalTB04Analysis.cc.

829  {
830  //Beam Information
832 
833  // Total Energy
834  eecals = ehcals = eecalq = ehcalq = 0.;
835  for (int i = 0; i < nTower; i++) {
836  ehcals += esimh[i];
837  ehcalq += eqie[i];
838  }
839  for (int i = 0; i < nCrystal; i++) {
840  eecals += esime[i];
841  eecalq += enois[i];
842  }
843  etots = eecals + ehcals;
844  etotq = eecalq + ehcalq;
845 #ifdef EDM_ML_DEBUG
846  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Energy deposit at Sim Level (Total) " << etots << " (ECal) "
847  << eecals << " (HCal) " << ehcals
848  << "\nHcalTB04Analysis:: Energy deposit at Qie Level (Total) " << etotq << " (ECal) "
849  << eecalq << " (HCal) " << ehcalq;
850 #endif
852 
853  // Lateral Profile
854  for (int i = 0; i < 5; i++) {
855  eseta[i] = 0.;
856  eqeta[i] = 0.;
857  }
858  for (int i = 0; i < 3; i++) {
859  esphi[i] = 0.;
860  eqphi[i] = 0.;
861  }
862  double e1 = 0, e2 = 0;
863  unsigned int id;
864  for (int i = 0; i < nTower; i++) {
865  int det, z, group, ieta, iphi, layer;
866  id = idTower[i];
867  HcalTestNumbering::unpackHcalIndex(id, det, z, group, ieta, iphi, layer);
868  iphi -= (icphi - 1);
869  if (icphi > 4) {
870  if (ieta == 0)
871  ieta = 2;
872  else
873  ieta = -1;
874  } else {
875  ieta = ieta - iceta + 2;
876  }
877  if (iphi >= 0 && iphi < 3 && ieta >= 0 && ieta < 5) {
878  eseta[ieta] += esimh[i];
879  esphi[iphi] += esimh[i];
880  e1 += esimh[i];
881  eqeta[ieta] += eqie[i];
882  eqphi[iphi] += eqie[i];
883  e2 += eqie[i];
884  }
885  }
886  for (int i = 0; i < 3; i++) {
887  if (e1 > 0)
888  esphi[i] /= e1;
889  if (e2 > 0)
890  eqphi[i] /= e2;
891  }
892  for (int i = 0; i < 5; i++) {
893  if (e1 > 0)
894  eseta[i] /= e1;
895  if (e2 > 0)
896  eqeta[i] /= e2;
897  }
898 #ifdef EDM_ML_DEBUG
899  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Energy fraction along Eta and Phi (Sim/Qie)";
900  for (int i = 0; i < 5; i++)
901  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: [" << i << "] Eta Sim = " << eseta[i] << " Qie = " << eqeta[i]
902  << " Phi Sim = " << esphi[i] << " Qie = " << eqphi[i];
903 #endif
905 
906  // Longitudianl profile
907  for (int i = 0; i < 20; i++) {
908  eslay[i] = 0.;
909  eqlay[i] = 0.;
910  }
911  e1 = 0;
912  e2 = 0;
913  for (int i = 0; i < nTower; i++) {
914  int det, z, group, ieta, iphi, layer;
915  id = idTower[i];
916  HcalTestNumbering::unpackHcalIndex(id, det, z, group, ieta, iphi, layer);
917  iphi -= (icphi - 1);
918  layer -= 1;
919  if (iphi >= 0 && iphi < 3 && layer >= 0 && layer < 20) {
920  eslay[layer] += esimh[i];
921  e1 += esimh[i];
922  eqlay[layer] += eqie[i];
923  e2 += eqie[i];
924  }
925  }
926  for (int i = 0; i < 20; i++) {
927  if (e1 > 0)
928  eslay[i] /= e1;
929  if (e2 > 0)
930  eqlay[i] /= e2;
931  }
932 #ifdef EDM_ML_DEBUG
933  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Energy fraction along Layer";
934  for (int i = 0; i < 20; i++)
935  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: [" << i << "] Sim = " << eslay[i] << " Qie = " << eqlay[i];
936 #endif
938 }

References StorageManager_cfg::e1, eecalq, eecals, ehcalq, ehcals, enois, eqeta, eqie, eqlay, eqphi, eseta, esime, esimh, eslay, esphi, etaInit, etotq, etots, HcalTB04Histo::fillEdep(), HcalTB04Histo::fillLongProf(), HcalTB04Histo::fillPrimary(), HcalTB04Histo::fillTrnsProf(), watchdog::group, histo, mps_fire::i, iceta, icphi, triggerObjects_cff::id, idTower, LEDCalibrationChannels::ieta, LEDCalibrationChannels::iphi, nCrystal, nTower, phiInit, pInit, HcalTestNumbering::unpackHcalIndex(), and z.

Referenced by update().

◆ init()

void HcalTB04Analysis::init ( void  )
private

Definition at line 216 of file HcalTB04Analysis.cc.

216  {
218  nTower = idTower.size();
219  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Save information from " << nTower << " HCal towers";
220  idHcal.reserve(nTower);
221  for (int i = 0; i < nTower; i++) {
222  int id = unitID(idTower[i]);
223  idHcal.push_back(id);
224 #ifdef EDM_ML_DEBUG
225  edm::LogVerbatim("HcalTBSim") << "\tTower[" << i << "] Original " << std::hex << idTower[i] << " Stored "
226  << idHcal[i] << std::dec;
227 #endif
228  }
229 
230  if (!hcalOnly) {
231  int det = 10;
232  uint32_t id1;
233  nCrystal = 0;
234  for (int lay = 1; lay < 8; lay++) {
235  for (int icr = 1; icr < 8; icr++) {
236  id1 = HcalTestNumbering::packHcalIndex(det, 0, 1, icr, lay, 1);
237  int id = unitID(id1);
238  idEcal.push_back(id1);
239  idXtal.push_back(id);
240  nCrystal++;
241  }
242  }
243  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Save information from " << nCrystal << " ECal Crystals";
244 #ifdef EDM_ML_DEBUG
245  for (int i = 0; i < nCrystal; i++) {
246  edm::LogVerbatim("HcalTBSim") << "\tCrystal[" << i << "] Original " << std::hex << idEcal[i] << " Stored "
247  << idXtal[i] << std::dec;
248  }
249 #endif
250  }
251  // Profile vectors
252  eseta.reserve(5);
253  eqeta.reserve(5);
254  esphi.reserve(3);
255  eqphi.reserve(3);
256  eslay.reserve(20);
257  eqlay.reserve(20);
258  for (int i = 0; i < 5; i++) {
259  eseta.push_back(0.);
260  eqeta.push_back(0.);
261  }
262  for (int i = 0; i < 3; i++) {
263  esphi.push_back(0.);
264  eqphi.push_back(0.);
265  }
266  for (int i = 0; i < 20; i++) {
267  eslay.push_back(0.);
268  eqlay.push_back(0.);
269  }
270 
271  // counter
272  count = 0;
273  evNum = 0;
274  clear();
275 }

References clear(), count, TauDecayModes::dec, eqeta, eqlay, eqphi, eseta, eslay, esphi, evNum, HcalTBNumberingScheme::getUnitIDs(), hcalOnly, mps_fire::i, globals_cff::id1, idEcal, idHcal, idTower, idXtal, mode, nCrystal, nTower, HcalTestNumbering::packHcalIndex(), and unitID().

Referenced by HcalTB04Analysis().

◆ operator=()

const HcalTB04Analysis& HcalTB04Analysis::operator= ( const HcalTB04Analysis )
privatedelete

◆ produce()

void HcalTB04Analysis::produce ( edm::Event e,
const edm::EventSetup  
)
overridevirtual

Implements SimProducer.

Definition at line 210 of file HcalTB04Analysis.cc.

210  {
211  std::unique_ptr<PHcalTB04Info> product(new PHcalTB04Info);
212  fillEvent(*product);
213  e.put(std::move(product));
214 }

References MillePedeFileConverter_cfg::e, fillEvent(), and eostools::move().

◆ qieAnalysis()

void HcalTB04Analysis::qieAnalysis ( CLHEP::HepRandomEngine *  engine)
private

Definition at line 719 of file HcalTB04Analysis.cc.

719  {
720  int hittot = hcalHitCache.size();
721  if (hittot <= 0)
722  hittot = 1;
723  std::vector<CaloHit> hits(hittot);
724  std::vector<int> todo(nTower, 0);
725 
726 #ifdef EDM_ML_DEBUG
727  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::qieAnalysis: Size " << hits.size() << " " << todo.size() << " "
728  << idTower.size() << " " << esimh.size() << " " << eqie.size();
729 #endif
730  // Loop over all HCal hits
731  for (unsigned int k1 = 0; k1 < hcalHitCache.size(); k1++) {
732  CaloHit hit = hcalHitCache[k1];
733  uint32_t id = hit.id();
734  int nhit = 0;
735  double esim = hit.e();
736  hits[nhit] = hit;
737  for (unsigned int k2 = k1 + 1; k2 < hcalHitCache.size(); k2++) {
738  hit = hcalHitCache[k2];
739  if (hit.id() == id) {
740  nhit++;
741  hits[nhit] = hit;
742  esim += hit.e();
743  }
744  }
745  k1 += nhit;
746  nhit++;
747  std::vector<int> cd = myQie->getCode(nhit, hits, engine);
748  double eq = myQie->getEnergy(cd);
749 #ifdef EDM_ML_DEBUG
750  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: ID 0x" << std::hex << id << std::dec << " registers " << esim
751  << " energy from " << nhit << " hits starting with hit # " << k1
752  << " energy with noise " << eq;
753 #endif
754  for (int k2 = 0; k2 < nTower; k2++) {
755  if (id == idTower[k2]) {
756  todo[k2] = 1;
757  esimh[k2] = esim;
758  eqie[k2] = eq;
759  }
760  }
761  }
762 
763  // Towers with no hit
764  for (int k2 = 0; k2 < nTower; k2++) {
765  if (todo[k2] == 0) {
766  std::vector<int> cd = myQie->getCode(0, hits, engine);
767  double eq = myQie->getEnergy(cd);
768  esimh[k2] = 0;
769  eqie[k2] = eq;
770 #ifdef EDM_ML_DEBUG
771  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: ID 0x" << std::hex << idTower[k2] << std::dec
772  << " registers " << esimh[k2] << " energy from hits and energy after QIE analysis "
773  << eqie[k2];
774 #endif
775  }
776  }
777 }

References hippyaddtobaddatafiles::cd(), TauDecayModes::dec, edm::eq(), eqie, esimh, HcalQie::getCode(), HcalQie::getEnergy(), hcalHitCache, hfClusterShapes_cfi::hits, triggerObjects_cff::id, hit::id, idTower, myQie, nTower, and DQMOfflineHeavyIons_cff::todo.

Referenced by update().

◆ scale()

double HcalTB04Analysis::scale ( int  det,
int  layer 
)
private

Definition at line 1060 of file HcalTB04Analysis.cc.

1060  {
1061  double tmp = 1.;
1062  if (det == static_cast<int>(HcalBarrel)) {
1063  if (layer == 1)
1064  tmp = scaleHB0;
1065  else if (layer == 17)
1066  tmp = scaleHB16;
1067  else if (layer > 17)
1068  tmp = scaleHO;
1069  } else {
1070  if (layer <= 2)
1071  tmp = scaleHE0;
1072  }
1073  return tmp;
1074 }

References HcalBarrel, scaleHB0, scaleHB16, scaleHE0, scaleHO, and createJobs::tmp.

Referenced by fillBuffer().

◆ timeOfFlight()

double HcalTB04Analysis::timeOfFlight ( int  det,
int  layer,
double  eta 
)
private

Definition at line 1076 of file HcalTB04Analysis.cc.

1076  {
1077  double theta = 2.0 * atan(exp(-eta));
1078  double dist = beamOffset;
1079  if (det == static_cast<int>(HcalBarrel)) {
1080  const double rLay[19] = {1836.0,
1081  1902.0,
1082  1962.0,
1083  2022.0,
1084  2082.0,
1085  2142.0,
1086  2202.0,
1087  2262.0,
1088  2322.0,
1089  2382.0,
1090  2448.0,
1091  2514.0,
1092  2580.0,
1093  2646.0,
1094  2712.0,
1095  2776.0,
1096  2862.5,
1097  3847.0,
1098  4052.0};
1099  if (layer > 0 && layer <= 19)
1100  dist += rLay[layer - 1] * mm / sin(theta);
1101  } else {
1102  const double zLay[19] = {4034.0,
1103  4032.0,
1104  4123.0,
1105  4210.0,
1106  4297.0,
1107  4384.0,
1108  4471.0,
1109  4558.0,
1110  4645.0,
1111  4732.0,
1112  4819.0,
1113  4906.0,
1114  4993.0,
1115  5080.0,
1116  5167.0,
1117  5254.0,
1118  5341.0,
1119  5428.0,
1120  5515.0};
1121  if (layer > 0 && layer <= 19)
1122  dist += zLay[layer - 1] * mm / cos(theta);
1123  }
1124 
1125  double tmp = dist / c_light / ns;
1126 #ifdef EDM_ML_DEBUG
1127  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::timeOfFlight " << tmp << " for det/lay " << det << " " << layer
1128  << " eta/theta " << eta << " " << theta / deg << " dist " << dist;
1129 #endif
1130  return tmp;
1131 }

References beamOffset, funct::cos(), PVValHelper::eta, JetChargeProducer_cfi::exp, HcalBarrel, funct::sin(), theta(), and createJobs::tmp.

Referenced by fillBuffer().

◆ unitID()

int HcalTB04Analysis::unitID ( uint32_t  id)
private

Definition at line 1049 of file HcalTB04Analysis.cc.

1049  {
1050  int det, z, group, ieta, iphi, lay;
1052  group = (det & 15) << 20;
1053  group += ((lay - 1) & 31) << 15;
1054  group += (z & 1) << 14;
1055  group += (ieta & 127) << 7;
1056  group += (iphi & 127);
1057  return group;
1058 }

References watchdog::group, LEDCalibrationChannels::ieta, LEDCalibrationChannels::iphi, HcalTestNumbering::unpackHcalIndex(), and z.

Referenced by fillBuffer(), and init().

◆ update() [1/4]

void HcalTB04Analysis::update ( const BeginOfEvent )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const BeginOfEvent * >.

Definition at line 319 of file HcalTB04Analysis.cc.

319  {
320  evNum = (*evt)()->GetEventID();
321  clear();
322  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis: =====> Begin of event = " << evNum;
323 }

References clear(), and evNum.

Referenced by progressbar.ProgressBar::__next__(), MatrixUtil.Matrix::__setitem__(), MatrixUtil.Steps::__setitem__(), progressbar.ProgressBar::finish(), and MatrixUtil.Steps::overwrite().

◆ update() [2/4]

void HcalTB04Analysis::update ( const BeginOfRun )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const BeginOfRun * >.

Definition at line 277 of file HcalTB04Analysis.cc.

277  {
278  int irun = (*run)()->GetRunID();
279  edm::LogVerbatim("HcalTBSim") << " =====> Begin of Run = " << irun;
280 
281  G4SDManager* sd = G4SDManager::GetSDMpointerIfExist();
282  if (sd != nullptr) {
283  std::string sdname = names[0];
284  G4VSensitiveDetector* aSD = sd->FindSensitiveDetector(sdname);
285  if (aSD == nullptr) {
286  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis::beginOfRun: No SD"
287  << " with name " << sdname << " in this "
288  << "Setup";
289  } else {
290  HCalSD* theCaloSD = dynamic_cast<HCalSD*>(aSD);
291  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::beginOfRun: Finds SD with name " << theCaloSD->GetName()
292  << " in this Setup";
294  theCaloSD->setNumberingScheme(org);
295  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::beginOfRun: set a new numbering scheme";
296  }
297  if (!hcalOnly) {
298  sdname = names[1];
299  aSD = sd->FindSensitiveDetector(sdname);
300  if (aSD == nullptr) {
301  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis::beginOfRun: No SD"
302  << " with name " << sdname << " in this "
303  << "Setup";
304  } else {
305  ECalSD* theCaloSD = dynamic_cast<ECalSD*>(aSD);
306  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::beginOfRun: Finds SD with name " << theCaloSD->GetName()
307  << " in this Setup";
309  theCaloSD->setNumberingScheme(org);
310  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::beginOfRun: set a new numbering scheme";
311  }
312  }
313  } else {
314  edm::LogWarning("HcalTBSim") << "HcalTB04Analysis::beginOfRun: Could "
315  << "not get SD Manager!";
316  }
317 }

References hcalOnly, names, sd, ECalSD::setNumberingScheme(), HCalSD::setNumberingScheme(), and AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by progressbar.ProgressBar::__next__(), MatrixUtil.Matrix::__setitem__(), MatrixUtil.Steps::__setitem__(), progressbar.ProgressBar::finish(), and MatrixUtil.Steps::overwrite().

◆ update() [3/4]

void HcalTB04Analysis::update ( const EndOfEvent )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const EndOfEvent * >.

Definition at line 430 of file HcalTB04Analysis.cc.

430  {
431  count++;
432 
433  //fill the buffer
434 #ifdef EDM_ML_DEBUG
435  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::Fill event " << (*evt)()->GetEventID();
436 #endif
437  fillBuffer(evt);
438 
439  //QIE analysis
440 #ifdef EDM_ML_DEBUG
441  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::Do QIE analysis with " << hcalHitCache.size() << " hits";
442 #endif
443  CLHEP::HepRandomEngine* engine = G4Random::getTheEngine();
444  qieAnalysis(engine);
445 
446  //Energy in Crystal Matrix
447  if (!hcalOnly) {
448 #ifdef EDM_ML_DEBUG
449  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::Do Xtal analysis with " << ecalHitCache.size() << " hits";
450 #endif
451  xtalAnalysis(engine);
452  }
453 
454  //Final Analysis
455 #ifdef EDM_ML_DEBUG
456  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::Final analysis";
457 #endif
458  finalAnalysis();
459 
460  int iEvt = (*evt)()->GetEventID();
461  if (iEvt < 10)
462  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Event " << iEvt;
463  else if ((iEvt < 100) && (iEvt % 10 == 0))
464  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Event " << iEvt;
465  else if ((iEvt < 1000) && (iEvt % 100 == 0))
466  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Event " << iEvt;
467  else if ((iEvt < 10000) && (iEvt % 1000 == 0))
468  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: Event " << iEvt;
469 }

References count, ecalHitCache, fillBuffer(), finalAnalysis(), hcalHitCache, hcalOnly, qieAnalysis(), and xtalAnalysis().

Referenced by progressbar.ProgressBar::__next__(), MatrixUtil.Matrix::__setitem__(), MatrixUtil.Steps::__setitem__(), progressbar.ProgressBar::finish(), and MatrixUtil.Steps::overwrite().

◆ update() [4/4]

void HcalTB04Analysis::update ( const G4Step *  )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const G4Step * >.

Definition at line 325 of file HcalTB04Analysis.cc.

325  {
326  if (aStep != nullptr) {
327  //Get Step properties
328  G4ThreeVector thePreStepPoint = aStep->GetPreStepPoint()->GetPosition();
329  G4ThreeVector thePostStepPoint;
330 
331  // Get Tracks properties
332  G4Track* aTrack = aStep->GetTrack();
333  int trackID = aTrack->GetTrackID();
334  int parentID = aTrack->GetParentID();
335  const G4ThreeVector& position = aTrack->GetPosition();
336  G4ThreeVector momentum = aTrack->GetMomentum();
337  G4String partType = aTrack->GetDefinition()->GetParticleType();
338  G4String partSubType = aTrack->GetDefinition()->GetParticleSubType();
339  int partPDGEncoding = aTrack->GetDefinition()->GetPDGEncoding();
340 #ifdef EDM_ML_DEBUG
341  bool isPDGStable = aTrack->GetDefinition()->GetPDGStable();
342 #endif
343  double pDGlifetime = aTrack->GetDefinition()->GetPDGLifeTime();
344  double gammaFactor = aStep->GetPreStepPoint()->GetGamma();
345 
346  if (!pvFound) { //search for v1
347  double stepDeltaEnergy = aStep->GetDeltaEnergy();
348  double kinEnergy = aTrack->GetKineticEnergy();
349 
350  // look for DeltaE > 10% kinEnergy of particle, or particle death - Ek=0
351  if (trackID == 1 && parentID == 0 && ((kinEnergy == 0.) || (fabs(stepDeltaEnergy / kinEnergy) > 0.1))) {
352  pvType = -1;
353  if (kinEnergy == 0.) {
354  pvType = 0;
355  } else {
356  if (fabs(stepDeltaEnergy / kinEnergy) > 0.1)
357  pvType = 1;
358  }
359  pvFound = true;
361  pvMomentum = momentum;
362  // Rotated coord.system:
363  pvUVW = (*beamline_RM) * (pvPosition);
364 
365  //Volume name requires some checks:
366  G4String thePostPVname = "NoName";
367  G4StepPoint* thePostPoint = aStep->GetPostStepPoint();
368  if (thePostPoint) {
369  thePostStepPoint = thePostPoint->GetPosition();
370  G4VPhysicalVolume* thePostPV = thePostPoint->GetPhysicalVolume();
371  if (thePostPV)
372  thePostPVname = thePostPV->GetName();
373  }
374 #ifdef EDM_ML_DEBUG
375  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: V1 found at: " << thePostStepPoint
376  << " G4VPhysicalVolume: " << thePostPVname;
377  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::fill_v1Pos: Primary Track momentum: " << pvMomentum
378  << " psoition " << pvPosition << " u/v/w " << pvUVW;
379 #endif
380  }
381  } else {
382  // watch for secondaries originating @v1, including the surviving primary
383  if ((trackID != 1 && parentID == 1 && (aTrack->GetCurrentStepNumber() == 1) && (thePreStepPoint == pvPosition)) ||
384  (trackID == 1 && thePreStepPoint == pvPosition)) {
385 #ifdef EDM_ML_DEBUG
386  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::A secondary... PDG:" << partPDGEncoding
387  << " TrackID:" << trackID << " ParentID:" << parentID
388  << " stable: " << isPDGStable << " Tau: " << pDGlifetime
389  << " cTauGamma=" << c_light * pDGlifetime * gammaFactor * 1000.
390  << "um GammaFactor: " << gammaFactor;
391 #endif
392  secTrackID.push_back(trackID);
393  secPartID.push_back(partPDGEncoding);
394  secMomentum.push_back(momentum);
395  secEkin.push_back(aTrack->GetKineticEnergy());
396 
397  // Check for short-lived secondaries: cTauGamma<100um
398  double ctaugamma_um = CLHEP::c_light * pDGlifetime * gammaFactor * 1000.;
399  if ((ctaugamma_um > 0.) && (ctaugamma_um < 100.)) { //short-lived secondary
400  shortLivedSecondaries.push_back(trackID);
401  } else { //normal secondary - enter into the V1-calorimetric tree
402  // histos->fill_v1cSec (aTrack);
403  }
404  }
405  // Also watch for tertiary particles coming from
406  // short-lived secondaries from V1
407  if (aTrack->GetCurrentStepNumber() == 1) {
408  if (!shortLivedSecondaries.empty()) {
409  int pid = parentID;
410  std::vector<int>::iterator pos1 = shortLivedSecondaries.begin();
411  std::vector<int>::iterator pos2 = shortLivedSecondaries.end();
412  std::vector<int>::iterator pos;
413  for (pos = pos1; pos != pos2; pos++) {
414  if (*pos == pid) { //ParentID is on the list of short-lived
415  // secondary
416 #ifdef EDM_ML_DEBUG
417  edm::LogVerbatim("HcalTBSim")
418  << "HcalTB04Analysis:: A tertiary... PDG:" << partPDGEncoding << " TrackID:" << trackID
419  << " ParentID:" << parentID << " stable: " << isPDGStable << " Tau: " << pDGlifetime
420  << " cTauGamma=" << c_light * pDGlifetime * gammaFactor * 1000. << "um GammaFactor: " << gammaFactor;
421 #endif
422  }
423  }
424  }
425  }
426  }
427  }
428 }

References position, pvFound, pvMomentum, pvPosition, pvType, pvUVW, secEkin, secMomentum, secPartID, secTrackID, and shortLivedSecondaries.

Referenced by progressbar.ProgressBar::__next__(), MatrixUtil.Matrix::__setitem__(), MatrixUtil.Steps::__setitem__(), progressbar.ProgressBar::finish(), and MatrixUtil.Steps::overwrite().

◆ xtalAnalysis()

void HcalTB04Analysis::xtalAnalysis ( CLHEP::HepRandomEngine *  engine)
private

Definition at line 779 of file HcalTB04Analysis.cc.

779  {
780  CLHEP::RandGaussQ randGauss(*engine);
781 
782  // Crystal Data
783  std::vector<int> iok(nCrystal, 0);
784 #ifdef EDM_ML_DEBUG
785  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis::xtalAnalysis: Size " << iok.size() << " " << idEcal.size() << " "
786  << esime.size() << " " << enois.size();
787 #endif
788  for (unsigned int k1 = 0; k1 < ecalHitCache.size(); k1++) {
789  uint32_t id = ecalHitCache[k1].id();
790  int nhit = 0;
791  double esim = ecalHitCache[k1].e();
792  for (unsigned int k2 = k1 + 1; k2 < ecalHitCache.size(); k2++) {
793  if (ecalHitCache[k2].id() == id) {
794  nhit++;
795  esim += ecalHitCache[k2].e();
796  }
797  }
798  k1 += nhit;
799  nhit++;
800  double eq = esim + randGauss.fire(0., ecalNoise);
801 #ifdef EDM_ML_DEBUG
802  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: ID 0x" << std::hex << id << std::dec << " registers " << esim
803  << " energy from " << nhit << " hits starting with hit # " << k1
804  << " energy with noise " << eq;
805 #endif
806  for (int k2 = 0; k2 < nCrystal; k2++) {
807  if (id == idEcal[k2]) {
808  iok[k2] = 1;
809  esime[k2] = esim;
810  enois[k2] = eq;
811  }
812  }
813  }
814 
815  // Crystals with no hit
816  for (int k2 = 0; k2 < nCrystal; k2++) {
817  if (iok[k2] == 0) {
818  esime[k2] = 0;
819  enois[k2] = randGauss.fire(0., ecalNoise);
820 #ifdef EDM_ML_DEBUG
821  edm::LogVerbatim("HcalTBSim") << "HcalTB04Analysis:: ID 0x" << std::hex << idEcal[k2] << std::dec
822  << " registers " << esime[k2] << " energy from hits and energy from noise "
823  << enois[k2];
824 #endif
825  }
826  }
827 }

References TauDecayModes::dec, ecalHitCache, ecalNoise, enois, edm::eq(), esime, triggerObjects_cff::id, idEcal, and nCrystal.

Referenced by update().

Member Data Documentation

◆ beamline_RM

G4RotationMatrix* HcalTB04Analysis::beamline_RM
private

Definition at line 118 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis().

◆ beamOffset

double HcalTB04Analysis::beamOffset
private

Definition at line 114 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), and timeOfFlight().

◆ count

int HcalTB04Analysis::count
private

Definition at line 121 of file HcalTB04Analysis.cc.

Referenced by init(), update(), and ~HcalTB04Analysis().

◆ ecalHitCache

std::vector<CaloHit> HcalTB04Analysis::ecalHitCache
private

Definition at line 129 of file HcalTB04Analysis.cc.

Referenced by clear(), fillBuffer(), fillEvent(), update(), and xtalAnalysis().

◆ ecalNoise

double HcalTB04Analysis::ecalNoise
private

Definition at line 114 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), and xtalAnalysis().

◆ eecalq

double HcalTB04Analysis::eecalq
private

Definition at line 133 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and finalAnalysis().

◆ eecals

double HcalTB04Analysis::eecals
private

Definition at line 133 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and finalAnalysis().

◆ ehcalq

double HcalTB04Analysis::ehcalq
private

Definition at line 133 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and finalAnalysis().

◆ ehcals

double HcalTB04Analysis::ehcals
private

Definition at line 133 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and finalAnalysis().

◆ enois

std::vector<double> HcalTB04Analysis::enois
private

Definition at line 131 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), finalAnalysis(), and xtalAnalysis().

◆ eqeta

std::vector<double> HcalTB04Analysis::eqeta
private

Definition at line 132 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), finalAnalysis(), and init().

◆ eqie

std::vector<double> HcalTB04Analysis::eqie
private

Definition at line 131 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), finalAnalysis(), and qieAnalysis().

◆ eqlay

std::vector<double> HcalTB04Analysis::eqlay
private

Definition at line 132 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), finalAnalysis(), and init().

◆ eqphi

std::vector<double> HcalTB04Analysis::eqphi
private

Definition at line 132 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), finalAnalysis(), and init().

◆ eseta

std::vector<double> HcalTB04Analysis::eseta
private

Definition at line 132 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), finalAnalysis(), and init().

◆ esime

std::vector<double> HcalTB04Analysis::esime
private

Definition at line 131 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), finalAnalysis(), and xtalAnalysis().

◆ esimh

std::vector<double> HcalTB04Analysis::esimh
private

Definition at line 131 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), finalAnalysis(), and qieAnalysis().

◆ eslay

std::vector<double> HcalTB04Analysis::eslay
private

Definition at line 132 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), finalAnalysis(), and init().

◆ esphi

std::vector<double> HcalTB04Analysis::esphi
private

Definition at line 132 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), finalAnalysis(), and init().

◆ etaInit

double HcalTB04Analysis::etaInit
private

Definition at line 128 of file HcalTB04Analysis.cc.

Referenced by clear(), fillBuffer(), fillEvent(), and finalAnalysis().

◆ etotq

double HcalTB04Analysis::etotq
private

Definition at line 133 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and finalAnalysis().

◆ etots

double HcalTB04Analysis::etots
private

Definition at line 133 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and finalAnalysis().

◆ evNum

int HcalTB04Analysis::evNum
private

Definition at line 136 of file HcalTB04Analysis.cc.

Referenced by fillBuffer(), fillEvent(), init(), and update().

◆ hcalHitCache

std::vector<CaloHit> HcalTB04Analysis::hcalHitCache
private

Definition at line 130 of file HcalTB04Analysis.cc.

Referenced by clear(), fillBuffer(), fillEvent(), qieAnalysis(), and update().

◆ hcalHitLayer

std::vector<CaloHit> HcalTB04Analysis::hcalHitLayer
private

Definition at line 130 of file HcalTB04Analysis.cc.

Referenced by clear(), and fillBuffer().

◆ hcalOnly

bool HcalTB04Analysis::hcalOnly
private

Definition at line 112 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), init(), and update().

◆ histo

HcalTB04Histo* HcalTB04Analysis::histo
private

Definition at line 109 of file HcalTB04Analysis.cc.

Referenced by finalAnalysis(), HcalTB04Analysis(), and ~HcalTB04Analysis().

◆ iceta

int HcalTB04Analysis::iceta
private

Definition at line 115 of file HcalTB04Analysis.cc.

Referenced by finalAnalysis(), and HcalTB04Analysis().

◆ icphi

int HcalTB04Analysis::icphi
private

Definition at line 115 of file HcalTB04Analysis.cc.

Referenced by finalAnalysis(), and HcalTB04Analysis().

◆ idEcal

std::vector<uint32_t> HcalTB04Analysis::idEcal
private

Definition at line 124 of file HcalTB04Analysis.cc.

Referenced by init(), and xtalAnalysis().

◆ idHcal

std::vector<int> HcalTB04Analysis::idHcal
private

Definition at line 123 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and init().

◆ idTower

std::vector<uint32_t> HcalTB04Analysis::idTower
private

Definition at line 124 of file HcalTB04Analysis.cc.

Referenced by finalAnalysis(), init(), and qieAnalysis().

◆ idXtal

std::vector<int> HcalTB04Analysis::idXtal
private

Definition at line 123 of file HcalTB04Analysis.cc.

Referenced by fillEvent(), and init().

◆ mode

int HcalTB04Analysis::mode
private

Definition at line 113 of file HcalTB04Analysis.cc.

Referenced by fillBuffer(), HcalTB04Analysis(), and init().

◆ myQie

HcalQie* HcalTB04Analysis::myQie
private

Definition at line 108 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), qieAnalysis(), and ~HcalTB04Analysis().

◆ names

std::vector<std::string> HcalTB04Analysis::names
private

Definition at line 117 of file HcalTB04Analysis.cc.

Referenced by fillBuffer(), HcalTB04Analysis(), and update().

◆ nCrystal

int HcalTB04Analysis::nCrystal
private

Definition at line 122 of file HcalTB04Analysis.cc.

Referenced by clear(), finalAnalysis(), init(), and xtalAnalysis().

◆ nPrimary

int HcalTB04Analysis::nPrimary
private

Definition at line 127 of file HcalTB04Analysis.cc.

Referenced by clear(), fillBuffer(), and fillEvent().

◆ nTower

int HcalTB04Analysis::nTower
private

Definition at line 122 of file HcalTB04Analysis.cc.

Referenced by clear(), finalAnalysis(), init(), and qieAnalysis().

◆ particleType

int HcalTB04Analysis::particleType
private

Definition at line 127 of file HcalTB04Analysis.cc.

Referenced by clear(), fillBuffer(), and fillEvent().

◆ phiInit

double HcalTB04Analysis::phiInit
private

Definition at line 128 of file HcalTB04Analysis.cc.

Referenced by clear(), fillBuffer(), fillEvent(), and finalAnalysis().

◆ pInit

double HcalTB04Analysis::pInit
private

Definition at line 128 of file HcalTB04Analysis.cc.

Referenced by clear(), fillBuffer(), fillEvent(), and finalAnalysis().

◆ pvFound

bool HcalTB04Analysis::pvFound
private

Definition at line 135 of file HcalTB04Analysis.cc.

Referenced by clear(), and update().

◆ pvMomentum

G4ThreeVector HcalTB04Analysis::pvMomentum
private

Definition at line 137 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ pvPosition

G4ThreeVector HcalTB04Analysis::pvPosition
private

Definition at line 137 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ pvType

int HcalTB04Analysis::pvType
private

Definition at line 136 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ pvUVW

G4ThreeVector HcalTB04Analysis::pvUVW
private

Definition at line 137 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ scaleHB0

double HcalTB04Analysis::scaleHB0
private

Definition at line 116 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), and scale().

◆ scaleHB16

double HcalTB04Analysis::scaleHB16
private

Definition at line 116 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), and scale().

◆ scaleHE0

double HcalTB04Analysis::scaleHE0
private

Definition at line 116 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), and scale().

◆ scaleHO

double HcalTB04Analysis::scaleHO
private

Definition at line 116 of file HcalTB04Analysis.cc.

Referenced by HcalTB04Analysis(), and scale().

◆ secEkin

std::vector<double> HcalTB04Analysis::secEkin
private

Definition at line 140 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ secMomentum

std::vector<G4ThreeVector> HcalTB04Analysis::secMomentum
private

Definition at line 139 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ secPartID

std::vector<int> HcalTB04Analysis::secPartID
private

Definition at line 138 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ secTrackID

std::vector<int> HcalTB04Analysis::secTrackID
private

Definition at line 138 of file HcalTB04Analysis.cc.

Referenced by clear(), fillEvent(), and update().

◆ shortLivedSecondaries

std::vector<int> HcalTB04Analysis::shortLivedSecondaries
private

Definition at line 141 of file HcalTB04Analysis.cc.

Referenced by clear(), and update().

◆ type

int HcalTB04Analysis::type
private

Definition at line 113 of file HcalTB04Analysis.cc.

HcalTB04Analysis::esime
std::vector< double > esime
Definition: HcalTB04Analysis.cc:131
HcalTB04Analysis::particleType
int particleType
Definition: HcalTB04Analysis.cc:127
DDAxes::y
HcalTB04Analysis::xtalAnalysis
void xtalAnalysis(CLHEP::HepRandomEngine *)
Definition: HcalTB04Analysis.cc:779
CaloG4Hit::getTrackID
int getTrackID() const
Definition: CaloG4Hit.h:64
mps_fire.i
i
Definition: mps_fire.py:355
HcalTB04Analysis::idXtal
std::vector< int > idXtal
Definition: HcalTB04Analysis.cc:123
HcalTB04Analysis::iceta
int iceta
Definition: HcalTB04Analysis.cc:115
HcalTB04Analysis::timeOfFlight
double timeOfFlight(int det, int layer, double eta)
Definition: HcalTB04Analysis.cc:1076
DQMOfflineHeavyIons_cff.todo
todo
Definition: DQMOfflineHeavyIons_cff.py:112
HcalTB04Analysis::beamline_RM
G4RotationMatrix * beamline_RM
Definition: HcalTB04Analysis.cc:118
hit::id
unsigned int id
Definition: SiStripHitEffFromCalibTree.cc:92
hfClusterShapes_cfi.hits
hits
Definition: hfClusterShapes_cfi.py:5
HcalTB04Analysis::pvUVW
G4ThreeVector pvUVW
Definition: HcalTB04Analysis.cc:137
HcalTB04Analysis::hcalHitCache
std::vector< CaloHit > hcalHitCache
Definition: HcalTB04Analysis.cc:130
min
T min(T a, T b)
Definition: MathUtil.h:58
HCalSD
Definition: HCalSD.h:38
CaloG4Hit::getUnitID
uint32_t getUnitID() const
Definition: CaloG4Hit.h:65
multPhiCorr_741_25nsDY_cfi.py
py
Definition: multPhiCorr_741_25nsDY_cfi.py:12
HcalTB04Analysis::ecalHitCache
std::vector< CaloHit > ecalHitCache
Definition: HcalTB04Analysis.cc:129
HcalTB04Histo::fillTrnsProf
void fillTrnsProf(const std::vector< double > &es1, const std::vector< double > &eq1, const std::vector< double > &es2, const std::vector< double > &eq2)
Definition: HcalTB04Histo.cc:98
HcalTB04Analysis::histo
HcalTB04Histo * histo
Definition: HcalTB04Analysis.cc:109
HcalTB04Analysis::beamOffset
double beamOffset
Definition: HcalTB04Analysis.cc:114
AlCaHLTBitMon_ParallelJobs.p
p
Definition: AlCaHLTBitMon_ParallelJobs.py:153
globals_cff.id1
id1
Definition: globals_cff.py:32
pos
Definition: PixelAliasList.h:18
HcalTB04Analysis::ehcals
double ehcals
Definition: HcalTB04Analysis.cc:133
HcalTB04Analysis::eecalq
double eecalq
Definition: HcalTB04Analysis.cc:133
PHcalTB04Info::setIDs
void setIDs(const std::vector< int > &, const std::vector< int > &)
Definition: PHcalTB04Info.cc:69
HcalTB04Analysis::ehcalq
double ehcalq
Definition: HcalTB04Analysis.cc:133
HcalTB04Analysis::idTower
std::vector< uint32_t > idTower
Definition: HcalTB04Analysis.cc:124
PHcalTB04Info::setPrimary
void setPrimary(int primary, int id, double energy, double eta, double phi)
Definition: PHcalTB04Info.cc:95
HcalTB04Analysis::eqlay
std::vector< double > eqlay
Definition: HcalTB04Analysis.cc:132
HcalTB04Analysis::pvType
int pvType
Definition: HcalTB04Analysis.cc:136
HcalTB04Analysis::scale
double scale(int det, int layer)
Definition: HcalTB04Analysis.cc:1060
HcalTB04Analysis::unitID
int unitID(uint32_t id)
Definition: HcalTB04Analysis.cc:1049
DDAxes::x
PHcalTB04Info::saveHit
void saveHit(int det, int lay, int eta, int phi, double e, double t)
Definition: PHcalTB04Info.cc:185
HcalTB04Histo
Definition: HcalTB04Histo.h:31
HcalBarrel
Definition: HcalAssistant.h:33
HcalTB04Analysis::esphi
std::vector< double > esphi
Definition: HcalTB04Analysis.cc:132
createJobs.tmp
tmp
align.sh
Definition: createJobs.py:716
CaloG4Hit::getTimeSlice
double getTimeSlice() const
Definition: CaloG4Hit.h:66
training_settings.idx
idx
Definition: training_settings.py:16
PHcalTB04Info::setEdep
void setEdep(double simtot, double sime, double simh, double digtot, double dige, double digh)
Definition: PHcalTB04Info.cc:105
PHcalTB04Info::setTrnsProf
void setTrnsProf(const std::vector< double > &es1, const std::vector< double > &eq1, const std::vector< double > &es2, const std::vector< double > &eq2)
Definition: PHcalTB04Info.cc:149
HcalTB04Analysis::pvMomentum
G4ThreeVector pvMomentum
Definition: HcalTB04Analysis.cc:137
npart
double npart
Definition: HydjetWrapper.h:46
funct::sin
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
LEDCalibrationChannels.iphi
iphi
Definition: LEDCalibrationChannels.py:64
HcalTB04Analysis::nTower
int nTower
Definition: HcalTB04Analysis.cc:122
EcalNumberingScheme
Definition: EcalNumberingScheme.h:14
HcalTB04Analysis::eecals
double eecals
Definition: HcalTB04Analysis.cc:133
HcalTB04Analysis::init
void init()
Definition: HcalTB04Analysis.cc:216
funct::cos
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
HcalTestNumbering::unpackHcalIndex
static void unpackHcalIndex(const uint32_t &idx, int &det, int &z, int &depth, int &eta, int &phi, int &lay)
Definition: HcalTestNumbering.cc:18
HcalTB04Histo::fillPrimary
void fillPrimary(double energy, double eta, double phi)
Definition: HcalTB04Histo.cc:78
HcalTB04Analysis::ecalNoise
double ecalNoise
Definition: HcalTB04Analysis.cc:114
HcalTB04Analysis::enois
std::vector< double > enois
Definition: HcalTB04Analysis.cc:131
HcalTB04Analysis::secMomentum
std::vector< G4ThreeVector > secMomentum
Definition: HcalTB04Analysis.cc:139
PVValHelper::eta
Definition: PVValidationHelpers.h:69
mathSSE::sqrt
T sqrt(T t)
Definition: SSEVec.h:19
ECalSD::setNumberingScheme
void setNumberingScheme(EcalNumberingScheme *)
Definition: ECalSD.cc:290
CaloG4Hit::getEnergyDeposit
double getEnergyDeposit() const
Definition: CaloG4Hit.h:77
DDAxes::z
HcalTB04Analysis::pvPosition
G4ThreeVector pvPosition
Definition: HcalTB04Analysis.cc:137
HcalTB04Analysis::myQie
HcalQie * myQie
Definition: HcalTB04Analysis.cc:108
PHcalTB04Info::setLongProf
void setLongProf(const std::vector< double > &es, const std::vector< double > &eq)
Definition: PHcalTB04Info.cc:171
HcalTB04Analysis::phiInit
double phiInit
Definition: HcalTB04Analysis.cc:128
HcalTB04Analysis::icphi
int icphi
Definition: HcalTB04Analysis.cc:115
HcalTB04Analysis::esimh
std::vector< double > esimh
Definition: HcalTB04Analysis.cc:131
theta
Geom::Theta< T > theta() const
Definition: Basic3DVectorLD.h:150
HcalTB04Analysis::etots
double etots
Definition: HcalTB04Analysis.cc:133
CaloHitIdMore
Definition: CaloHit.h:41
ECalSD
Definition: ECalSD.h:30
HcalTB04Analysis::qieAnalysis
void qieAnalysis(CLHEP::HepRandomEngine *)
Definition: HcalTB04Analysis.cc:719
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
edm::LogWarning
Definition: MessageLogger.h:141
HcalTB04Analysis::hcalHitLayer
std::vector< CaloHit > hcalHitLayer
Definition: HcalTB04Analysis.cc:130
HcalTB04Analysis::eslay
std::vector< double > eslay
Definition: HcalTB04Analysis.cc:132
LEDCalibrationChannels.ieta
ieta
Definition: LEDCalibrationChannels.py:63
edm::ParameterSet
Definition: ParameterSet.h:36
math::XYZPoint
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
HcalTestNumbering::packHcalIndex
static uint32_t packHcalIndex(int det, int z, int depth, int eta, int phi, int lay)
Definition: HcalTestNumbering.cc:7
HcalTB04Analysis::secEkin
std::vector< double > secEkin
Definition: HcalTB04Analysis.cc:140
HcalTB04Analysis::names
std::vector< std::string > names
Definition: HcalTB04Analysis.cc:117
HcalTB04Analysis::finalAnalysis
void finalAnalysis()
Definition: HcalTB04Analysis.cc:829
HcalTestNumberingScheme
Definition: HcalTestNumberingScheme.h:11
HcalTB04Analysis::secTrackID
std::vector< int > secTrackID
Definition: HcalTB04Analysis.cc:138
SiStripPI::max
Definition: SiStripPayloadInspectorHelper.h:169
PHcalTB04Info::setVtxSec
void setVtxSec(int id, int pdg, double px, double py, double pz, double ek)
Definition: PHcalTB04Info.cc:218
GeV
const double GeV
Definition: MathUtil.h:16
HcalTB04Analysis::fillEvent
void fillEvent(PHcalTB04Info &)
Definition: HcalTB04Analysis.cc:940
PHcalTB04Info::setVtxPrim
void setVtxPrim(int evNum, int type, double x, double y, double z, double u, double v, double w, double px, double py, double pz)
Definition: PHcalTB04Info.cc:198
StorageManager_cfg.e1
e1
Definition: StorageManager_cfg.py:16
position
static int position[264][3]
Definition: ReadPGInfo.cc:289
funct::tan
Tan< T >::type tan(const T &t)
Definition: Tan.h:22
createfilelist.int
int
Definition: createfilelist.py:10
HcalTB04Analysis::eqphi
std::vector< double > eqphi
Definition: HcalTB04Analysis.cc:132
edm::LogVerbatim
Definition: MessageLogger.h:297
HcalTB04Analysis::fillBuffer
void fillBuffer(const EndOfEvent *evt)
Definition: HcalTB04Analysis.cc:471
HcalQie::getCode
std::vector< int > getCode(int, const std::vector< CaloHit > &, CLHEP::HepRandomEngine *)
Definition: HcalQie.cc:268
CaloHit
Definition: CaloHit.h:12
HcalTB04Histo::fillEdep
void fillEdep(double etots, double eecals, double ehcals, double etotq, double eecalq, double ehcalq)
Definition: HcalTB04Histo.cc:85
CaloG4Hit
Definition: CaloG4Hit.h:32
edm::eq
bool eq(const ELstring &s1, const ELstring s2)
Definition: ELstring.cc:39
HcalTB04Analysis::nPrimary
int nPrimary
Definition: HcalTB04Analysis.cc:127
itr
std::vector< std::pair< float, float > >::iterator itr
Definition: HGCDigitizer.cc:28
HcalTB04Analysis::shortLivedSecondaries
std::vector< int > shortLivedSecondaries
Definition: HcalTB04Analysis.cc:141
HcalNumberingScheme
Definition: HcalNumberingScheme.h:13
HcalTBNumberingScheme::getUnitIDs
static std::vector< uint32_t > getUnitIDs(const int type, const int mode)
Definition: HcalTBNumberingScheme.cc:69
HcalTB04Analysis::etotq
double etotq
Definition: HcalTB04Analysis.cc:133
HcalTB04Analysis::count
int count
Definition: HcalTB04Analysis.cc:121
PHcalTB04Info::setEdepHcal
void setEdepHcal(const std::vector< double > &esim, const std::vector< double > &edig)
Definition: PHcalTB04Info.cc:133
HcalTB04Analysis::secPartID
std::vector< int > secPartID
Definition: HcalTB04Analysis.cc:138
DDAxes::phi
HCalSD::setNumberingScheme
void setNumberingScheme(HcalNumberingScheme *)
Definition: HCalSD.cc:550
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
multPhiCorr_741_25nsDY_cfi.px
px
Definition: multPhiCorr_741_25nsDY_cfi.py:10
HcalTB04Analysis::eqie
std::vector< double > eqie
Definition: HcalTB04Analysis.cc:131
type
type
Definition: HCALResponse.h:21
eostools.move
def move(src, dest)
Definition: eostools.py:511
HcalTB04Analysis::scaleHB0
double scaleHB0
Definition: HcalTB04Analysis.cc:116
HcalTB04Analysis::idHcal
std::vector< int > idHcal
Definition: HcalTB04Analysis.cc:123
HcalTB04Analysis::evNum
int evNum
Definition: HcalTB04Analysis.cc:136
HcalTB04Analysis::eqeta
std::vector< double > eqeta
Definition: HcalTB04Analysis.cc:132
triggerObjects_cff.id
id
Definition: triggerObjects_cff.py:31
HcalTB04Analysis::hcalOnly
bool hcalOnly
Definition: HcalTB04Analysis.cc:112
HcalTB04Analysis::idEcal
std::vector< uint32_t > idEcal
Definition: HcalTB04Analysis.cc:124
CaloG4HitCollection
G4THitsCollection< CaloG4Hit > CaloG4HitCollection
Definition: CaloG4HitCollection.h:11
HcalTB04Analysis::clear
void clear()
Definition: HcalTB04Analysis.cc:1013
HcalTB04Analysis::mode
int mode
Definition: HcalTB04Analysis.cc:113
dqm-mbProfile.log
log
Definition: dqm-mbProfile.py:17
HcalTB04Analysis::scaleHB16
double scaleHB16
Definition: HcalTB04Analysis.cc:116
HcalQie::getEnergy
double getEnergy(const std::vector< int > &)
Definition: HcalQie.cc:354
sd
double sd
Definition: CascadeWrapper.h:113
hippyaddtobaddatafiles.cd
def cd(newdir)
Definition: hippyaddtobaddatafiles.py:40
HcalTB04Analysis::nCrystal
int nCrystal
Definition: HcalTB04Analysis.cc:122
funct::pow
Power< A, B >::type pow(const A &a, const B &b)
Definition: Power.h:30
HcalTB04Analysis::scaleHE0
double scaleHE0
Definition: HcalTB04Analysis.cc:116
PHcalTB04Info
Definition: PHcalTB04Info.h:33
HcalTB04Analysis::pvFound
bool pvFound
Definition: HcalTB04Analysis.cc:135
HcalTBNumberingScheme::getUnitID
static uint32_t getUnitID(const uint32_t id, const int mode)
Definition: HcalTBNumberingScheme.cc:26
dqmiolumiharvest.j
j
Definition: dqmiolumiharvest.py:66
JetChargeProducer_cfi.exp
exp
Definition: JetChargeProducer_cfi.py:6
ntuplemaker.time
time
Definition: ntuplemaker.py:310
HcalQie
Definition: HcalQie.h:18
HcalTB04Analysis::eseta
std::vector< double > eseta
Definition: HcalTB04Analysis.cc:132
HcalTB04Analysis::pInit
double pInit
Definition: HcalTB04Analysis.cc:128
TauDecayModes.dec
dec
Definition: TauDecayModes.py:143
HcalTB04Histo::fillLongProf
void fillLongProf(const std::vector< double > &es, const std::vector< double > &eq)
Definition: HcalTB04Histo.cc:126
HcalTB04XtalNumberingScheme
Definition: HcalTB04XtalNumberingScheme.h:24
hit
Definition: SiStripHitEffFromCalibTree.cc:88
CaloG4Hit::getEntry
math::XYZPoint getEntry() const
Definition: CaloG4Hit.h:46
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37
watchdog.group
group
Definition: watchdog.py:82
HcalTB04Analysis::scaleHO
double scaleHO
Definition: HcalTB04Analysis.cc:116
HcalTB04Analysis::etaInit
double etaInit
Definition: HcalTB04Analysis.cc:128