CMS 3D CMS Logo

SimG4FluxProducer.h
Go to the documentation of this file.
1 #ifndef SimG4CMSForwardSimG4FluxProducer_h
2 #define SimG4CMSForwardSimG4FluxProducer_h
3 
9 
10 // to retreive hits
12 
16 
17 #include "G4Step.hh"
18 #include "G4LogicalVolumeStore.hh"
19 #include "G4PhysicalVolumeStore.hh"
20 
21 #include <vector>
22 #include <string>
23 #include <map>
24 
26  public Observer<const BeginOfRun *>,
27  public Observer<const BeginOfEvent *>,
28  public Observer<const G4Step *> {
29 public:
31  ~SimG4FluxProducer() override;
32 
33  void produce(edm::Event &, const edm::EventSetup &) override;
34 
35 private:
36  SimG4FluxProducer(const SimG4FluxProducer &) = delete; // stop default
37  const SimG4FluxProducer &operator=(const SimG4FluxProducer &) = delete;
38 
39  // observer classes
40  void update(const BeginOfRun *run) override;
41  void update(const BeginOfEvent *evt) override;
42  void update(const G4Step *step) override;
43 
44  void endOfEvent(ParticleFlux &pflx, unsigned int k);
45  G4VPhysicalVolume *getTopPV();
46  std::map<G4LogicalVolume *, std::pair<unsigned int, std::string>>::iterator findLV(G4LogicalVolume *plv);
47 
48 private:
49  std::vector<std::string> LVNames_;
50  std::vector<int> LVTypes_;
51  G4VPhysicalVolume *topPV_;
52  std::map<G4LogicalVolume *, std::pair<unsigned int, std::string>> mapLV_;
53 
54  // some private members for ananlysis
55  unsigned int count_;
56  bool init_;
57  std::map<std::pair<G4LogicalVolume *, unsigned int>, ParticleFlux> store_;
58 };
59 
60 #endif
std::map< G4LogicalVolume *, std::pair< unsigned int, std::string > > mapLV_
const SimG4FluxProducer & operator=(const SimG4FluxProducer &)=delete
SimG4FluxProducer(const edm::ParameterSet &p)
~SimG4FluxProducer() override
void produce(edm::Event &, const edm::EventSetup &) override
G4VPhysicalVolume * topPV_
std::vector< int > LVTypes_
void update(const BeginOfRun *run) override
This routine will be called when the appropriate signal arrives.
std::map< G4LogicalVolume *, std::pair< unsigned int, std::string > >::iterator findLV(G4LogicalVolume *plv)
G4VPhysicalVolume * getTopPV()
std::vector< std::string > LVNames_
void endOfEvent(ParticleFlux &pflx, unsigned int k)
std::map< std::pair< G4LogicalVolume *, unsigned int >, ParticleFlux > store_
step
Definition: StallMonitor.cc:94