CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Private Member Functions | Private Attributes
HcalForwardAnalysis Class Reference

#include <HcalForwardAnalysis.h>

Inheritance diagram for HcalForwardAnalysis:
SimProducer Observer< const BeginOfRun * > Observer< const BeginOfEvent * > Observer< const EndOfEvent * > Observer< const G4Step * > SimWatcher

Classes

struct  Photon
 

Public Member Functions

 HcalForwardAnalysis (const edm::ParameterSet &p)
 
void produce (edm::Event &, const edm::EventSetup &) override
 
 ~HcalForwardAnalysis () override
 
- Public Member Functions inherited from SimProducer
const SimProduceroperator= (const SimProducer &)=delete
 
void registerProducts (edm::ProducesCollector producesCollector)
 
 SimProducer ()
 
 SimProducer (const SimProducer &)=delete
 
- Public Member Functions inherited from SimWatcher
const SimWatcheroperator= (const SimWatcher &)=delete
 
 SimWatcher ()
 
 SimWatcher (const SimWatcher &)=delete
 
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 fillEvent ()
 
 HcalForwardAnalysis (const HcalForwardAnalysis &)=delete
 
void init ()
 
const HcalForwardAnalysisoperator= (const HcalForwardAnalysis &)=delete
 
void parseDetId (int id, int &tower, int &cell, int &fiber)
 
void setPhotons (const EndOfEvent *evt)
 
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...
 

Private Attributes

int count
 
int evNum
 
int fiberId [10000]
 
bool fillt
 
float lambda [10000]
 
int nphot
 
float primMomX
 
float primMomY
 
float primMomZ
 
float primT
 
float primX
 
float primY
 
float primZ
 
float t [10000]
 
int theEventCounter
 
edm::Service< TFileServicetheFile
 
std::vector< std::string > theNames
 
std::vector< PhotonthePhotons
 
TTree * theTree
 
float x [10000]
 
float y [10000]
 
float z [10000]
 

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 33 of file HcalForwardAnalysis.h.

Constructor & Destructor Documentation

◆ HcalForwardAnalysis() [1/2]

HcalForwardAnalysis::HcalForwardAnalysis ( const edm::ParameterSet p)

Definition at line 26 of file HcalForwardAnalysis.cc.

26  {
27  edm::ParameterSet m_SLP = p.getParameter<edm::ParameterSet>("HFShowerLibraryProducer");
28  theNames = m_SLP.getParameter<std::vector<std::string> >("Names");
29  //LibVer = m_HS.getParameter<std::string> ("LibVer");
30  //produces<HFShowerPhotonCollection> ();
31  init();
32  theEventCounter = 0;
33  nphot = 0;
34  for (int i = 0; i < 10000; ++i) {
35  x[i] = 0.;
36  y[i] = 0.;
37  z[i] = 0.;
38  t[i] = 0.;
39  lambda[i] = 0.;
40  fiberId[i] = 0;
41  }
42  primX = primY = primZ = primT = 0.;
43  primMomX = primMomY = primMomZ = 0.;
44 }

References fiberId, edm::ParameterSet::getParameter(), mps_fire::i, init(), lambda, nphot, AlCaHLTBitMon_ParallelJobs::p, primMomX, primMomY, primMomZ, primT, primX, primY, primZ, t, theEventCounter, theNames, x, y, and z.

◆ ~HcalForwardAnalysis()

HcalForwardAnalysis::~HcalForwardAnalysis ( )
override

Definition at line 46 of file HcalForwardAnalysis.cc.

46 {}

◆ HcalForwardAnalysis() [2/2]

HcalForwardAnalysis::HcalForwardAnalysis ( const HcalForwardAnalysis )
privatedelete

Member Function Documentation

◆ clear()

void HcalForwardAnalysis::clear ( void  )
private

Definition at line 275 of file HcalForwardAnalysis.cc.

275  {
276  nphot = 0;
277  for (int i = 0; i < 10000; ++i) {
278  x[i] = 0.;
279  y[i] = 0.;
280  z[i] = 0.;
281  t[i] = 0.;
282  lambda[i] = 0.;
283  fiberId[i] = 0;
284  }
285  primX = primY = primZ = primT = 0.;
286  primMomX = primMomY = primMomZ = 0.;
287 
288  thePhotons.clear();
289 }

References fiberId, mps_fire::i, lambda, nphot, primMomX, primMomY, primMomZ, primT, primX, primY, primZ, t, thePhotons, x, y, and z.

Referenced by init(), and update().

◆ fillEvent()

void HcalForwardAnalysis::fillEvent ( )
private

Definition at line 253 of file HcalForwardAnalysis.cc.

253  {
254  /*
255  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis: =====> filledEvent";
256  */
257  nphot = int(thePhotons.size());
258  for (int i = 0; i < nphot; ++i) {
259  x[i] = thePhotons[i].x;
260  y[i] = thePhotons[i].y;
261  z[i] = thePhotons[i].z;
262  t[i] = thePhotons[i].t;
263  lambda[i] = thePhotons[i].lambda;
264  fiberId[i] = thePhotons[i].fiberId;
265  }
266  theTree->Fill();
267 }

References fiberId, mps_fire::i, createfilelist::int, lambda, nphot, t, thePhotons, theTree, x, y, and z.

Referenced by produce().

◆ init()

void HcalForwardAnalysis::init ( void  )
private

Definition at line 57 of file HcalForwardAnalysis.cc.

57  {
58  theTree = theFile->make<TTree>("CherenkovPhotons", "Cherenkov Photons");
59  theTree->Branch("nphot", &nphot, "nphot/I");
60  theTree->Branch("x", &x, "x[nphot]/F");
61  theTree->Branch("y", &y, "y[nphot]/F");
62  theTree->Branch("z", &z, "z[nphot]/F");
63  theTree->Branch("t", &t, "t[nphot]/F");
64  theTree->Branch("lambda", &lambda, "lambda[nphot]/F");
65  theTree->Branch("fiberId", &fiberId, "fiberId[nphot]/I");
66  theTree->Branch("primX", &primX, "primX/F");
67  theTree->Branch("primY", &primY, "primY/F");
68  theTree->Branch("primZ", &primZ, "primZ/F");
69  theTree->Branch("primMomX", &primMomX, "primMomX/F");
70  theTree->Branch("primMomY", &primMomY, "primMomY/F");
71  theTree->Branch("primMomZ", &primMomZ, "primMomZ/F");
72  theTree->Branch("primT", &primT, "primT/F");
73 
74  // counter
75  count = 0;
76  evNum = 0;
77  clear();
78 }

References clear(), count, evNum, fiberId, lambda, TFileService::make(), nphot, primMomX, primMomY, primMomZ, primT, primX, primY, primZ, t, theFile, theTree, x, y, and z.

Referenced by HcalForwardAnalysis().

◆ operator=()

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

◆ parseDetId()

void HcalForwardAnalysis::parseDetId ( int  id,
int &  tower,
int &  cell,
int &  fiber 
)
private

Definition at line 269 of file HcalForwardAnalysis.cc.

269  {
270  tower = id / 10000;
271  cell = id / 10 - tower * 10;
272  fiber = id - tower * 10000 - cell * 10;
273 }

References hgcalTowerProducer_cfi::tower.

Referenced by setPhotons().

◆ produce()

void HcalForwardAnalysis::produce ( edm::Event iEvent,
const edm::EventSetup  
)
overridevirtual

Implements SimProducer.

Definition at line 52 of file HcalForwardAnalysis.cc.

52  {
53  if (fillt)
54  fillEvent();
55 }

References fillEvent(), and fillt.

◆ setPhotons()

void HcalForwardAnalysis::setPhotons ( const EndOfEvent evt)
private

Definition at line 111 of file HcalForwardAnalysis.cc.

111  {
112  fillt = true;
113  int idHC, j;
114  FiberG4HitsCollection* theHC;
115  // Look for the Hit Collection of HCal
116  G4HCofThisEvent* allHC = (*evt)()->GetHCofThisEvent();
117  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis:: Has " << allHC->GetNumberOfCollections()
118  << " collections";
119  for (int k = 0; k < allHC->GetNumberOfCollections(); ++k) {
120  G4String name = (allHC->GetHC(k) == nullptr) ? "Unknown" : allHC->GetHC(k)->GetName();
121  G4String nameSD = (allHC->GetHC(k) == nullptr) ? "Unknown" : allHC->GetHC(k)->GetSDname();
122  edm::LogVerbatim("HcalForwardLib") << "Collecttion[" << k << "] " << allHC->GetHC(k) << " " << name << ":"
123  << nameSD;
124  }
125  std::string sdName = theNames[0]; //name for fiber hits
126  idHC = G4SDManager::GetSDMpointer()->GetCollectionID(sdName);
127  theHC = (FiberG4HitsCollection*)allHC->GetHC(idHC);
128  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons() Hit Collection for " << sdName << " of ID "
129  << idHC << " is obtained at " << theHC;
130  std::vector<HFShowerPhoton> ShortFiberPhotons;
131  std::vector<HFShowerPhoton> LongFiberPhotons;
132  LongFiberPhotons.clear();
133  ShortFiberPhotons.clear();
134  if (idHC >= 0 && theHC != nullptr) {
135  int thehc_entries = theHC->entries();
136  edm::LogVerbatim("HcalForwardLib") << "FiberhitSize " << thehc_entries;
137  for (j = 0; j < thehc_entries; j++) {
138  FiberG4Hit* aHit = (*theHC)[j];
139  std::vector<HFShowerPhoton> thePhotonsFromHit = aHit->photon();
140  edm::LogVerbatim("HcalForwardLib") << "Fiberhit " << j << " has " << thePhotonsFromHit.size() << " photons.";
141  int fTowerId = -1;
142  int fCellId = -1;
143  int fFiberId = -1;
144  parseDetId(aHit->towerId(), fTowerId, fCellId, fFiberId);
145  for (unsigned int iph = 0; iph < thePhotonsFromHit.size(); ++iph) {
146  if (aHit->depth() == 1)
147  LongFiberPhotons.push_back(thePhotonsFromHit[iph]);
148  if (aHit->depth() == 2)
149  ShortFiberPhotons.push_back(thePhotonsFromHit[iph]);
150  }
151  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons() NbPhotons " << thePhotonsFromHit.size()
152  << " towerId " << fTowerId << " cellId " << fCellId << " fiberId " << fFiberId
153  << " depth " << aHit->depth();
154  }
155  } else {
156  fillt = false;
157  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons(): No Photons!";
158  return;
159  }
160  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons() LongFibPhotons: " << LongFiberPhotons.size()
161  << " ShortFibPhotons: " << ShortFiberPhotons.size();
162  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons() LongFibPhotons: " << LongFiberPhotons.size()
163  << " ShortFibPhotons: " << ShortFiberPhotons.size();
164 
165  //Chamber hits to find information about primary particle on surface
166  HFShowerG4HitsCollection* theChamberHC;
167  G4HCofThisEvent* allChamberHC = (*evt)()->GetHCofThisEvent();
168  sdName = theNames[1];
169  idHC = G4SDManager::GetSDMpointer()->GetCollectionID(sdName);
170  theChamberHC = (HFShowerG4HitsCollection*)allChamberHC->GetHC(idHC);
171  math::XYZPoint primPosOnSurf(0, 0, 0);
172  math::XYZPoint primMomDirOnSurf(0, 0, 0);
173  float primTimeOnSurf = 0;
174  // the chamber hit is for primary particle, but step size can be small
175  // (in newer Geant4 versions) and as a result primary particle may have
176  // multiple hits. We want to take last one which is close the HF absorber
177  // if (idHC >= 0 && theChamberHC != nullptr && theChamberHC->entries()>0) {
178  if (idHC >= 0 && theChamberHC != nullptr) {
179  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons() Chamber Hits size: "
180  << theChamberHC->entries();
181  int thec_hc_entries = theChamberHC->entries();
182  for (j = 0; j < thec_hc_entries; ++j) {
183  HFShowerG4Hit* aHit = (*theChamberHC)[j];
184  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons() Chamber Hit id " << aHit->hitId()
185  << " track id " << aHit->trackId() << " prim. pos. " << aHit->globalPosition()
186  << " prom mom. dir. " << aHit->primaryMomDir() << " time " << aHit->time();
187  primPosOnSurf.SetXYZ(aHit->globalPosition().x(), aHit->globalPosition().y(), aHit->globalPosition().z());
188  primMomDirOnSurf.SetXYZ(aHit->primaryMomDir().x(), aHit->primaryMomDir().y(), aHit->primaryMomDir().z());
189  primTimeOnSurf = aHit->time();
190  }
191  } else {
192  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons(): No Chamber hits are stored";
193  fillt = false;
194  return;
195  }
196  primX = primPosOnSurf.x();
197  primY = primPosOnSurf.y();
198  primZ = primPosOnSurf.z();
199  if (primZ < 990) { // there were interactions before HF
200  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::setPhotons(): First interaction before HF";
201  fillt = false;
202  return;
203  }
204  primT = primTimeOnSurf;
205  primMomX = primMomDirOnSurf.x();
206  primMomY = primMomDirOnSurf.y();
207  primMomZ = primMomDirOnSurf.z();
208  //angles for rotation matrices
209  double theta = primMomDirOnSurf.theta();
210  double phi = primMomDirOnSurf.phi();
211 
212  // my insert ----------------------------------------------------------------
213  double sphi = sin(phi);
214  double cphi = cos(phi);
215  double ctheta = cos(theta);
216  double stheta = sin(theta);
217 
218  double pex = 0, pey = 0, zv = 0;
219  double xx, yy, zz;
220 
221  for (unsigned int k = 0; k < LongFiberPhotons.size(); ++k) {
222  HFShowerPhoton aPhoton = LongFiberPhotons[k];
223  // global coordinates
224  xx = aPhoton.x();
225  yy = aPhoton.y();
226  zz = aPhoton.z();
227 
228  // local coordinates in rotated to shower axis system and vs shower origin
229  pex = xx * ctheta * cphi + yy * ctheta * sphi - zz * stheta;
230  pey = -xx * sphi + yy * cphi;
231  zv = xx * stheta * cphi + yy * stheta * sphi + zz * ctheta - primZ / ctheta;
232 
233  double photonProdTime = aPhoton.t() - primTimeOnSurf;
234  thePhotons.push_back(Photon(1, pex, pey, zv, photonProdTime, aPhoton.lambda()));
235  }
236  for (unsigned int k = 0; k < ShortFiberPhotons.size(); ++k) {
237  HFShowerPhoton aPhoton = ShortFiberPhotons[k];
238  // global coordinates
239  xx = aPhoton.x();
240  yy = aPhoton.y();
241  zz = aPhoton.z();
242 
243  // local coordinates in rotated to shower axis system and vs shower origin
244  pex = xx * ctheta * cphi + yy * ctheta * sphi - zz * stheta;
245  pey = -xx * sphi + yy * cphi;
246  zv = xx * stheta * cphi + yy * stheta * sphi + zz * ctheta - primZ / ctheta;
247 
248  double photonProdTime = aPhoton.t() - primTimeOnSurf;
249  thePhotons.push_back(Photon(2, pex, pey, zv, photonProdTime, aPhoton.lambda()));
250  }
251 }

References funct::cos(), FiberG4Hit::depth(), fillt, HFShowerG4Hit::globalPosition(), HFShowerG4Hit::hitId(), dqmiolumiharvest::j, dqmdumpme::k, HFShowerPhoton::lambda(), Skims_PA_cff::name, parseDetId(), phi, FiberG4Hit::photon(), nanoDQM_cff::Photon, HFShowerG4Hit::primaryMomDir(), primMomX, primMomY, primMomZ, primT, primX, primY, primZ, funct::sin(), AlCaHLTBitMon_QueryRunRegistry::string, HFShowerPhoton::t(), theNames, thePhotons, theta(), HFShowerG4Hit::time(), FiberG4Hit::towerId(), HFShowerG4Hit::trackId(), HFShowerPhoton::x(), geometryCSVtoXML::xx, HFShowerPhoton::y(), geometryCSVtoXML::yy, HFShowerPhoton::z(), gpuVertexFinder::zv, and geometryCSVtoXML::zz.

Referenced by update().

◆ update() [1/4]

void HcalForwardAnalysis::update ( const BeginOfEvent )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const BeginOfEvent * >.

Definition at line 85 of file HcalForwardAnalysis.cc.

85  {
86  evNum = (*evt)()->GetEventID();
87  clear();
88  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis: =====> Begin of event = " << evNum;
89 }

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 HcalForwardAnalysis::update ( const BeginOfRun )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const BeginOfRun * >.

Definition at line 80 of file HcalForwardAnalysis.cc.

80  {
81  int irun = (*run)()->GetRunID();
82  edm::LogVerbatim("HcalForwardLib") << " =====> Begin of Run = " << irun;
83 }

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

◆ update() [3/4]

void HcalForwardAnalysis::update ( const EndOfEvent )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const EndOfEvent * >.

Definition at line 93 of file HcalForwardAnalysis.cc.

93  {
94  count++;
95 
96  //fill the buffer
97  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis::Fill event " << (*evt)()->GetEventID();
98  setPhotons(evt);
99 
100  int iEvt = (*evt)()->GetEventID();
101  if (iEvt < 10)
102  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis:: Event " << iEvt;
103  else if ((iEvt < 100) && (iEvt % 10 == 0))
104  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis:: Event " << iEvt;
105  else if ((iEvt < 1000) && (iEvt % 100 == 0))
106  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis:: Event " << iEvt;
107  else if ((iEvt < 10000) && (iEvt % 1000 == 0))
108  edm::LogVerbatim("HcalForwardLib") << "HcalForwardAnalysis:: Event " << iEvt;
109 }

References count, and setPhotons().

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

◆ update() [4/4]

void HcalForwardAnalysis::update ( const G4Step *  )
overrideprivatevirtual

This routine will be called when the appropriate signal arrives.

Implements Observer< const G4Step * >.

Definition at line 91 of file HcalForwardAnalysis.cc.

91 {}

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

Member Data Documentation

◆ count

int HcalForwardAnalysis::count
private

Definition at line 78 of file HcalForwardAnalysis.h.

Referenced by init(), and update().

◆ evNum

int HcalForwardAnalysis::evNum
private

Definition at line 79 of file HcalForwardAnalysis.h.

Referenced by init(), and update().

◆ fiberId

int HcalForwardAnalysis::fiberId[10000]
private

Definition at line 84 of file HcalForwardAnalysis.h.

Referenced by clear(), fillEvent(), HcalForwardAnalysis(), and init().

◆ fillt

bool HcalForwardAnalysis::fillt
private

Definition at line 87 of file HcalForwardAnalysis.h.

Referenced by produce(), and setPhotons().

◆ lambda

float HcalForwardAnalysis::lambda[10000]
private

Definition at line 80 of file HcalForwardAnalysis.h.

Referenced by clear(), fillEvent(), HcalForwardAnalysis(), and init().

◆ nphot

int HcalForwardAnalysis::nphot
private

Definition at line 83 of file HcalForwardAnalysis.h.

Referenced by clear(), fillEvent(), HcalForwardAnalysis(), and init().

◆ primMomX

float HcalForwardAnalysis::primMomX
private

Definition at line 82 of file HcalForwardAnalysis.h.

Referenced by clear(), HcalForwardAnalysis(), init(), and setPhotons().

◆ primMomY

float HcalForwardAnalysis::primMomY
private

Definition at line 82 of file HcalForwardAnalysis.h.

Referenced by clear(), HcalForwardAnalysis(), init(), and setPhotons().

◆ primMomZ

float HcalForwardAnalysis::primMomZ
private

Definition at line 82 of file HcalForwardAnalysis.h.

Referenced by clear(), HcalForwardAnalysis(), init(), and setPhotons().

◆ primT

float HcalForwardAnalysis::primT
private

Definition at line 81 of file HcalForwardAnalysis.h.

Referenced by clear(), HcalForwardAnalysis(), init(), and setPhotons().

◆ primX

float HcalForwardAnalysis::primX
private

Definition at line 81 of file HcalForwardAnalysis.h.

Referenced by clear(), HcalForwardAnalysis(), init(), and setPhotons().

◆ primY

float HcalForwardAnalysis::primY
private

Definition at line 81 of file HcalForwardAnalysis.h.

Referenced by clear(), HcalForwardAnalysis(), init(), and setPhotons().

◆ primZ

float HcalForwardAnalysis::primZ
private

Definition at line 81 of file HcalForwardAnalysis.h.

Referenced by clear(), HcalForwardAnalysis(), init(), and setPhotons().

◆ t

float HcalForwardAnalysis::t[10000]
private

Definition at line 80 of file HcalForwardAnalysis.h.

Referenced by clear(), fillEvent(), HcalForwardAnalysis(), and init().

◆ theEventCounter

int HcalForwardAnalysis::theEventCounter
private

Definition at line 77 of file HcalForwardAnalysis.h.

Referenced by HcalForwardAnalysis().

◆ theFile

edm::Service<TFileService> HcalForwardAnalysis::theFile
private

Definition at line 75 of file HcalForwardAnalysis.h.

Referenced by init().

◆ theNames

std::vector<std::string> HcalForwardAnalysis::theNames
private

Definition at line 86 of file HcalForwardAnalysis.h.

Referenced by HcalForwardAnalysis(), and setPhotons().

◆ thePhotons

std::vector<Photon> HcalForwardAnalysis::thePhotons
private

Definition at line 85 of file HcalForwardAnalysis.h.

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

◆ theTree

TTree* HcalForwardAnalysis::theTree
private

Definition at line 76 of file HcalForwardAnalysis.h.

Referenced by fillEvent(), and init().

◆ x

float HcalForwardAnalysis::x[10000]
private

◆ y

float HcalForwardAnalysis::y[10000]
private

◆ z

float HcalForwardAnalysis::z[10000]
private
HcalForwardAnalysis::fillt
bool fillt
Definition: HcalForwardAnalysis.h:87
HcalForwardAnalysis::y
float y[10000]
Definition: HcalForwardAnalysis.h:80
HFShowerPhoton::y
float y() const
Definition: HFShowerPhoton.h:25
HcalForwardAnalysis::primY
float primY
Definition: HcalForwardAnalysis.h:81
mps_fire.i
i
Definition: mps_fire.py:428
geometryCSVtoXML.zz
zz
Definition: geometryCSVtoXML.py:19
HFShowerG4Hit::primaryMomDir
G4ThreeVector primaryMomDir() const
Definition: HFShowerG4Hit.h:52
HFShowerG4HitsCollection
G4THitsCollection< HFShowerG4Hit > HFShowerG4HitsCollection
Definition: HFShowerG4Hit.h:55
HcalForwardAnalysis::primMomZ
float primMomZ
Definition: HcalForwardAnalysis.h:82
HcalForwardAnalysis::t
float t[10000]
Definition: HcalForwardAnalysis.h:80
HcalForwardAnalysis::thePhotons
std::vector< Photon > thePhotons
Definition: HcalForwardAnalysis.h:85
hgcalTowerProducer_cfi.tower
tower
Definition: hgcalTowerProducer_cfi.py:4
HcalForwardAnalysis::primX
float primX
Definition: HcalForwardAnalysis.h:81
HFShowerPhoton::t
float t() const
Definition: HFShowerPhoton.h:28
gpuVertexFinder::zv
float *__restrict__ zv
Definition: gpuFitVertices.h:26
HcalForwardAnalysis::setPhotons
void setPhotons(const EndOfEvent *evt)
Definition: HcalForwardAnalysis.cc:111
HcalForwardAnalysis::init
void init()
Definition: HcalForwardAnalysis.cc:57
HcalForwardAnalysis::parseDetId
void parseDetId(int id, int &tower, int &cell, int &fiber)
Definition: HcalForwardAnalysis.cc:269
HcalForwardAnalysis::x
float x[10000]
Definition: HcalForwardAnalysis.h:80
HcalForwardAnalysis::theEventCounter
int theEventCounter
Definition: HcalForwardAnalysis.h:77
funct::sin
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
FiberG4Hit
Definition: FiberG4Hit.h:14
HFShowerG4Hit
Definition: HFShowerG4Hit.h:15
HcalForwardAnalysis::evNum
int evNum
Definition: HcalForwardAnalysis.h:79
funct::cos
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
HFShowerG4Hit::hitId
G4int hitId() const
Definition: HFShowerG4Hit.h:46
HFShowerG4Hit::time
G4double time() const
Definition: HFShowerG4Hit.h:49
theta
Geom::Theta< T > theta() const
Definition: Basic3DVectorLD.h:150
HcalForwardAnalysis::lambda
float lambda[10000]
Definition: HcalForwardAnalysis.h:80
dqmdumpme.k
k
Definition: dqmdumpme.py:60
HFShowerPhoton::x
float x() const
Definition: HFShowerPhoton.h:24
HcalForwardAnalysis::primZ
float primZ
Definition: HcalForwardAnalysis.h:81
HcalForwardAnalysis::nphot
int nphot
Definition: HcalForwardAnalysis.h:83
HcalForwardAnalysis::z
float z[10000]
Definition: HcalForwardAnalysis.h:80
HcalForwardAnalysis::theFile
edm::Service< TFileService > theFile
Definition: HcalForwardAnalysis.h:75
HcalForwardAnalysis::count
int count
Definition: HcalForwardAnalysis.h:78
edm::ParameterSet
Definition: ParameterSet.h:47
math::XYZPoint
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
HcalForwardAnalysis::theTree
TTree * theTree
Definition: HcalForwardAnalysis.h:76
AlCaHLTBitMon_ParallelJobs.p
def p
Definition: AlCaHLTBitMon_ParallelJobs.py:153
FiberG4Hit::depth
G4int depth() const
Definition: FiberG4Hit.h:45
geometryCSVtoXML.yy
yy
Definition: geometryCSVtoXML.py:19
FiberG4Hit::towerId
G4int towerId() const
Definition: FiberG4Hit.h:44
createfilelist.int
int
Definition: createfilelist.py:10
HFShowerPhoton::lambda
float lambda() const
Definition: HFShowerPhoton.h:27
nanoDQM_cff.Photon
Photon
Definition: nanoDQM_cff.py:96
TFileService::make
T * make(const Args &...args) const
make new ROOT object
Definition: TFileService.h:64
AlCaHLTBitMon_QueryRunRegistry.string
string string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
HcalForwardAnalysis::primMomY
float primMomY
Definition: HcalForwardAnalysis.h:82
HFShowerPhoton::z
float z() const
Definition: HFShowerPhoton.h:26
DDAxes::phi
HFShowerG4Hit::globalPosition
G4ThreeVector globalPosition() const
Definition: HFShowerG4Hit.h:51
HcalForwardAnalysis::fillEvent
void fillEvent()
Definition: HcalForwardAnalysis.cc:253
edm::LogVerbatim
Log< level::Info, true > LogVerbatim
Definition: MessageLogger.h:128
HcalForwardAnalysis::primT
float primT
Definition: HcalForwardAnalysis.h:81
HcalForwardAnalysis::primMomX
float primMomX
Definition: HcalForwardAnalysis.h:82
HcalForwardAnalysis::fiberId
int fiberId[10000]
Definition: HcalForwardAnalysis.h:84
HFShowerPhoton
Definition: HFShowerPhoton.h:13
Skims_PA_cff.name
name
Definition: Skims_PA_cff.py:17
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
HcalForwardAnalysis::theNames
std::vector< std::string > theNames
Definition: HcalForwardAnalysis.h:86
HcalForwardAnalysis::clear
void clear()
Definition: HcalForwardAnalysis.cc:275
HFShowerG4Hit::trackId
G4int trackId() const
Definition: HFShowerG4Hit.h:47
dqmiolumiharvest.j
j
Definition: dqmiolumiharvest.py:66
FiberG4HitsCollection
G4THitsCollection< FiberG4Hit > FiberG4HitsCollection
Definition: FiberG4Hit.h:54
FiberG4Hit::photon
std::vector< HFShowerPhoton > photon() const
Definition: FiberG4Hit.h:50
geometryCSVtoXML.xx
xx
Definition: geometryCSVtoXML.py:19