test
CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Protected Member Functions | Private Attributes
RunManager Class Reference

#include <RunManager.h>

Public Member Functions

void abortEvent ()
 
void abortRun (bool softAbort=false)
 
void Connect (RunAction *)
 
void Connect (EventAction *)
 
void Connect (TrackingAction *)
 
void Connect (SteppingAction *)
 
const G4Event * currentEvent () const
 
const G4Run * currentRun () const
 
const Generatorgenerator () const
 
SimTrackManagerGetSimTrackManager ()
 
void initG4 (const edm::EventSetup &es)
 
void initializeRun ()
 
void initializeUserActions ()
 
void produce (edm::Event &inpevt, const edm::EventSetup &es)
 
std::vector< std::shared_ptr
< SimProducer > > 
producers () const
 
 RunManager (edm::ParameterSet const &p)
 
std::vector
< SensitiveCaloDetector * > & 
sensCaloDetectors ()
 
std::vector
< SensitiveTkDetector * > & 
sensTkDetectors ()
 
G4SimEventsimEvent ()
 
void stopG4 ()
 
void terminateRun ()
 
 ~RunManager ()
 

Protected Member Functions

void DumpMagneticField (const G4Field *) const
 
G4Event * generateEvent (edm::Event &inpevt)
 
void resetGenParticleId (edm::Event &inpevt)
 

Private Attributes

bool firstRun
 
edm::ESWatcher
< IdealGeometryRecord
idealGeomRcdWatcher_
 
edm::ESWatcher
< IdealMagneticFieldRecord
idealMagRcdWatcher_
 
AttachSDm_attach
 
bool m_check
 
sim::ChordFinderSetterm_chordFinderSetter
 
G4Event * m_currentEvent
 
G4Run * m_currentRun
 
int m_EvtMgrVerbosity
 
sim::FieldBuilderm_fieldBuilder
 
std::string m_FieldFile
 
std::vector< std::string > m_G4Commands
 
edm::ParameterSet m_g4overlap
 
Generatorm_generator
 
std::string m_InTag
 
G4RunManagerKernel * m_kernel
 
bool m_managerInitialized
 
bool m_nonBeam
 
edm::ParameterSet m_p
 
edm::ParameterSet m_pEventAction
 
edm::ParameterSet m_pField
 
edm::ParameterSet m_pGenerator
 
edm::ParameterSet m_pGeometry
 
std::auto_ptr< PhysicsListm_physicsList
 
std::string m_PhysicsTablesDir
 
edm::ParameterSet m_pPhysics
 
PrimaryTransformerm_primaryTransformer
 
std::unique_ptr
< DDG4ProductionCuts
m_prodCuts
 
std::vector< std::shared_ptr
< SimProducer > > 
m_producers
 
edm::ParameterSet m_pRunAction
 
edm::ParameterSet m_pStackingAction
 
edm::ParameterSet m_pSteppingAction
 
edm::ParameterSet m_pTrackingAction
 
bool m_pUseMagneticField
 
edm::ParameterSet m_pVertexGenerator
 
std::string m_RegionFile
 
SimActivityRegistry m_registry
 
bool m_RestorePhysicsTables
 
bool m_runAborted
 
bool m_runInitialized
 
SimRunInterfacem_runInterface
 
bool m_runTerminated
 
std::vector
< SensitiveCaloDetector * > 
m_sensCaloDets
 
std::vector
< SensitiveTkDetector * > 
m_sensTkDets
 
G4SimEventm_simEvent
 
bool m_StorePhysicsTables
 
edm::InputTag m_theLHCTlinkTag
 
std::auto_ptr< SimTrackManagerm_trackManager
 
RunActionm_userRunAction
 
std::vector< std::shared_ptr
< SimWatcher > > 
m_watchers
 
std::string m_WriteFile
 

Detailed Description

Definition at line 58 of file RunManager.h.

Constructor & Destructor Documentation

RunManager::RunManager ( edm::ParameterSet const &  p)

Definition at line 109 of file RunManager.cc.

References SimActivityRegistry::connect(), createWatchers(), edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), m_check, m_FieldFile, m_generator, m_InTag, m_kernel, m_p, m_pGenerator, m_producers, m_RegionFile, m_registry, m_runInterface, m_userRunAction, m_watchers, m_WriteFile, and AlCaHLTBitMon_QueryRunRegistry::string.

110  : m_generator(0), m_nonBeam(p.getParameter<bool>("NonBeamEvent")),
112  m_managerInitialized(false),
113  m_runInitialized(false), m_runTerminated(false), m_runAborted(false),
114  firstRun(true),
115  m_pUseMagneticField(p.getParameter<bool>("UseMagneticField")),
117  m_PhysicsTablesDir(p.getParameter<std::string>("PhysicsTablesDirectory")),
118  m_StorePhysicsTables(p.getParameter<bool>("StorePhysicsTables")),
119  m_RestorePhysicsTables(p.getParameter<bool>("RestorePhysicsTables")),
120  m_EvtMgrVerbosity(p.getUntrackedParameter<int>("G4EventManagerVerbosity",0)),
121  m_pField(p.getParameter<edm::ParameterSet>("MagneticField")),
122  m_pGenerator(p.getParameter<edm::ParameterSet>("Generator")),
123  m_pPhysics(p.getParameter<edm::ParameterSet>("Physics")),
124  m_pRunAction(p.getParameter<edm::ParameterSet>("RunAction")),
125  m_pEventAction(p.getParameter<edm::ParameterSet>("EventAction")),
126  m_pStackingAction(p.getParameter<edm::ParameterSet>("StackingAction")),
127  m_pTrackingAction(p.getParameter<edm::ParameterSet>("TrackingAction")),
128  m_pSteppingAction(p.getParameter<edm::ParameterSet>("SteppingAction")),
129  m_g4overlap(p.getParameter<edm::ParameterSet>("G4CheckOverlap")),
130  m_G4Commands(p.getParameter<std::vector<std::string> >("G4Commands")),
131  m_p(p), m_fieldBuilder(0), m_chordFinderSetter(nullptr),
132  m_theLHCTlinkTag(p.getParameter<edm::InputTag>("theLHCTlinkTag"))
133 {
134  m_kernel = new G4RunManagerKernel();
135 
136  m_check = p.getUntrackedParameter<bool>("CheckOverlap",false);
137  m_WriteFile = p.getUntrackedParameter<std::string>("FileNameGDML","");
138  m_FieldFile = p.getUntrackedParameter<std::string>("FileNameField","");
139  m_RegionFile = p.getUntrackedParameter<std::string>("FileNameRegions","");
140 
141  m_userRunAction = 0;
142  m_runInterface = 0;
143 
144  //Look for an outside SimActivityRegistry
145  // this is used by the visualization code
146  edm::Service<SimActivityRegistry> otherRegistry;
147  if(otherRegistry){
148  m_registry.connect(*otherRegistry);
149  }
150 
152 
154  m_InTag = m_pGenerator.getParameter<std::string>("HepMCProductLabel") ;
155 
156 }
T getParameter(std::string const &) const
bool m_check
Definition: RunManager.h:128
edm::ParameterSet m_pGenerator
Definition: RunManager.h:131
G4Event * m_currentEvent
Definition: RunManager.h:117
SimActivityRegistry m_registry
Definition: RunManager.h:148
edm::ParameterSet m_p
Definition: RunManager.h:141
std::vector< std::shared_ptr< SimProducer > > m_producers
Definition: RunManager.h:150
void connect(Observer< const BeginOfJob * > *iObject)
Generator * m_generator
Definition: RunManager.h:104
static void createWatchers(const edm::ParameterSet &iP, SimActivityRegistry &iReg, std::vector< std::shared_ptr< SimWatcher > > &oWatchers, std::vector< std::shared_ptr< SimProducer > > &oProds)
Definition: RunManager.cc:75
bool m_pUseMagneticField
Definition: RunManager.h:115
bool m_nonBeam
Definition: RunManager.h:107
int m_EvtMgrVerbosity
Definition: RunManager.h:127
std::string m_WriteFile
Definition: RunManager.h:162
bool firstRun
Definition: RunManager.h:114
SimRunInterface * m_runInterface
Definition: RunManager.h:120
bool m_RestorePhysicsTables
Definition: RunManager.h:126
std::vector< std::shared_ptr< SimWatcher > > m_watchers
Definition: RunManager.h:149
G4Run * m_currentRun
Definition: RunManager.h:116
edm::ParameterSet m_pStackingAction
Definition: RunManager.h:136
edm::ParameterSet m_pEventAction
Definition: RunManager.h:135
bool m_runTerminated
Definition: RunManager.h:112
edm::ParameterSet m_pField
Definition: RunManager.h:130
edm::ParameterSet m_pPhysics
Definition: RunManager.h:133
edm::ParameterSet m_pSteppingAction
Definition: RunManager.h:138
edm::ParameterSet m_g4overlap
Definition: RunManager.h:139
RunAction * m_userRunAction
Definition: RunManager.h:119
std::string m_InTag
Definition: RunManager.h:105
bool m_runInitialized
Definition: RunManager.h:111
sim::ChordFinderSetter * m_chordFinderSetter
Definition: RunManager.h:154
std::string m_RegionFile
Definition: RunManager.h:163
PrimaryTransformer * m_primaryTransformer
Definition: RunManager.h:109
sim::FieldBuilder * m_fieldBuilder
Definition: RunManager.h:153
std::string m_PhysicsTablesDir
Definition: RunManager.h:124
bool m_StorePhysicsTables
Definition: RunManager.h:125
edm::ParameterSet m_pRunAction
Definition: RunManager.h:134
edm::ParameterSet m_pTrackingAction
Definition: RunManager.h:137
std::vector< std::string > m_G4Commands
Definition: RunManager.h:140
std::string m_FieldFile
Definition: RunManager.h:161
G4SimEvent * m_simEvent
Definition: RunManager.h:118
bool m_managerInitialized
Definition: RunManager.h:110
edm::InputTag m_theLHCTlinkTag
Definition: RunManager.h:159
G4RunManagerKernel * m_kernel
Definition: RunManager.h:102
bool m_runAborted
Definition: RunManager.h:113
RunManager::~RunManager ( )

Definition at line 158 of file RunManager.cc.

References m_runInterface, m_runTerminated, and terminateRun().

159 {
160  if (!m_runTerminated) { terminateRun(); }
161  G4StateManager::GetStateManager()->SetNewState(G4State_Quit);
162  G4GeometryManager::GetInstance()->OpenGeometry();
163  // if (m_kernel!=0) delete m_kernel;
164  delete m_runInterface;
165 }
SimRunInterface * m_runInterface
Definition: RunManager.h:120
void terminateRun()
Definition: RunManager.cc:479
bool m_runTerminated
Definition: RunManager.h:112

Member Function Documentation

void RunManager::abortEvent ( )

Definition at line 400 of file RunManager.cc.

References m_currentEvent, m_kernel, m_runTerminated, TrackingAction::PostUserTrackingAction(), and lumiQTWidget::t.

Referenced by SimRunInterface::abortEvent(), and abortRun().

401 {
402  if (m_runTerminated) { return; }
403  G4Track* t =
404  m_kernel->GetEventManager()->GetTrackingManager()->GetTrack();
405  t->SetTrackStatus(fStopAndKill) ;
406 
407  // CMS-specific act
408  //
409  TrackingAction* uta =
410  (TrackingAction*)m_kernel->GetEventManager()->GetUserTrackingAction() ;
411  uta->PostUserTrackingAction(t) ;
412 
413  m_currentEvent->SetEventAborted();
414 
415  // do NOT call this method for now
416  // because it'll set abortRequested=true (withing G4EventManager)
417  // this will make Geant4, in the event *next* after the aborted one
418  // NOT to get the primary, thus there's NOTHING to trace, and it goes
419  // to the end of G4Event::DoProcessing(G4Event*), where abortRequested
420  // will be reset to true again
421  //
422  //m_kernel->GetEventManager()->AbortCurrentEvent();
423  //
424  // instead, mimic what it does, except (re)setting abortRequested
425  //
426  m_kernel->GetEventManager()->GetStackManager()->clear() ;
427  m_kernel->GetEventManager()->GetTrackingManager()->EventAborted() ;
428 
429  G4StateManager* stateManager = G4StateManager::GetStateManager();
430  stateManager->SetNewState(G4State_GeomClosed);
431 }
G4Event * m_currentEvent
Definition: RunManager.h:117
bool m_runTerminated
Definition: RunManager.h:112
virtual void PostUserTrackingAction(const G4Track *aTrack)
G4RunManagerKernel * m_kernel
Definition: RunManager.h:102
void RunManager::abortRun ( bool  softAbort = false)

Definition at line 497 of file RunManager.cc.

References abortEvent(), m_currentRun, m_runAborted, m_runInitialized, and terminateRun().

Referenced by SimRunInterface::abortRun(), ExceptionHandler::Notify(), and produce().

498 {
499  m_runAborted = false;
500  if (!softAbort) { abortEvent(); }
501  if (m_currentRun!=0) { delete m_currentRun; m_currentRun = 0; }
502  m_runInitialized = false;
503  m_runAborted = true;
504  terminateRun();
505 }
void abortEvent()
Definition: RunManager.cc:400
void terminateRun()
Definition: RunManager.cc:479
G4Run * m_currentRun
Definition: RunManager.h:116
bool m_runInitialized
Definition: RunManager.h:111
bool m_runAborted
Definition: RunManager.h:113
void RunManager::Connect ( RunAction runAction)

Definition at line 521 of file RunManager.cc.

References SimActivityRegistry::beginOfRunSignal_, sim_act::Signaler< T >::connect(), SimActivityRegistry::endOfRunSignal_, RunAction::m_beginOfRunSignal, RunAction::m_endOfRunSignal, and m_registry.

Referenced by SimRunInterface::Connect(), and initializeUserActions().

522 {
525 }
SimActivityRegistry m_registry
Definition: RunManager.h:148
SimActivityRegistry::EndOfRunSignal m_endOfRunSignal
Definition: RunAction.h:24
BeginOfRunSignal beginOfRunSignal_
EndOfRunSignal endOfRunSignal_
void connect(Observer< const T * > *iObs)
does not take ownership of memory
Definition: Signaler.h:59
SimActivityRegistry::BeginOfRunSignal m_beginOfRunSignal
Definition: RunAction.h:23
void RunManager::Connect ( EventAction eventAction)

Definition at line 527 of file RunManager.cc.

References SimActivityRegistry::beginOfEventSignal_, sim_act::Signaler< T >::connect(), SimActivityRegistry::endOfEventSignal_, EventAction::m_beginOfEventSignal, EventAction::m_endOfEventSignal, and m_registry.

528 {
531 }
SimActivityRegistry m_registry
Definition: RunManager.h:148
EndOfEventSignal endOfEventSignal_
SimActivityRegistry::EndOfEventSignal m_endOfEventSignal
Definition: EventAction.h:46
BeginOfEventSignal beginOfEventSignal_
void connect(Observer< const T * > *iObs)
does not take ownership of memory
Definition: Signaler.h:59
SimActivityRegistry::BeginOfEventSignal m_beginOfEventSignal
Definition: EventAction.h:45
void RunManager::Connect ( TrackingAction trackingAction)

Definition at line 533 of file RunManager.cc.

References SimActivityRegistry::beginOfTrackSignal_, sim_act::Signaler< T >::connect(), SimActivityRegistry::endOfTrackSignal_, TrackingAction::m_beginOfTrackSignal, TrackingAction::m_endOfTrackSignal, and m_registry.

534 {
537 }
SimActivityRegistry m_registry
Definition: RunManager.h:148
SimActivityRegistry::EndOfTrackSignal m_endOfTrackSignal
void connect(Observer< const T * > *iObs)
does not take ownership of memory
Definition: Signaler.h:59
EndOfTrackSignal endOfTrackSignal_
BeginOfTrackSignal beginOfTrackSignal_
SimActivityRegistry::BeginOfTrackSignal m_beginOfTrackSignal
void RunManager::Connect ( SteppingAction steppingAction)

Definition at line 539 of file RunManager.cc.

References sim_act::Signaler< T >::connect(), SimActivityRegistry::g4StepSignal_, SteppingAction::m_g4StepSignal, and m_registry.

540 {
542 }
SimActivityRegistry m_registry
Definition: RunManager.h:148
SimActivityRegistry::G4StepSignal m_g4StepSignal
void connect(Observer< const T * > *iObs)
does not take ownership of memory
Definition: Signaler.h:59
const G4Event* RunManager::currentEvent ( ) const
inline

Definition at line 76 of file RunManager.h.

References m_currentEvent.

76 { return m_currentEvent; }
G4Event * m_currentEvent
Definition: RunManager.h:117
const G4Run* RunManager::currentRun ( ) const
inline

Definition at line 72 of file RunManager.h.

References m_currentRun.

72 { return m_currentRun; }
G4Run * m_currentRun
Definition: RunManager.h:116
void RunManager::DumpMagneticField ( const G4Field *  field) const
protected

Definition at line 544 of file RunManager.cc.

References funct::cos(), groupFilesInBlocks::fout, i, j, m_FieldFile, GenerateHcalLaserBadRunList::out, phi, point, alignCSCRings::r, funct::sin(), z, and SiStripMonitorClusterAlca_cfi::zmax.

Referenced by initG4().

545 {
546  std::ofstream fout(m_FieldFile.c_str(), std::ios::out);
547  if(fout.fail()){
548  edm::LogWarning("SimG4CoreApplication")
549  << " RunManager WARNING : "
550  << "error opening file <" << m_FieldFile << "> for magnetic field";
551  } else {
552  double rmax = 9000*mm;
553  double zmax = 16000*mm;
554 
555  double dr = 5*cm;
556  double dz = 20*cm;
557 
558  int nr = (int)(rmax/dr);
559  int nz = 2*(int)(zmax/dz);
560 
561  double r = 0.0;
562  double z0 = -zmax;
563  double z;
564 
565  double phi = 0.0;
566  double cosf = cos(phi);
567  double sinf = sin(phi);
568 
569  double point[4] = {0.0,0.0,0.0,0.0};
570  double bfield[3] = {0.0,0.0,0.0};
571 
572  fout << std::setprecision(6);
573  for(int i=0; i<=nr; ++i) {
574  z = z0;
575  for(int j=0; j<=nz; ++j) {
576  point[0] = r*cosf;
577  point[1] = r*sinf;
578  point[2] = z;
579  field->GetFieldValue(point, bfield);
580  fout << "R(mm)= " << r/mm << " phi(deg)= " << phi/degree
581  << " Z(mm)= " << z/mm << " Bz(tesla)= " << bfield[2]/tesla
582  << " Br(tesla)= " << (bfield[0]*cosf + bfield[1]*sinf)/tesla
583  << " Bphi(tesla)= " << (bfield[0]*sinf - bfield[1]*cosf)/tesla
584  << G4endl;
585  z += dz;
586  }
587  r += dr;
588  }
589 
590  fout.close();
591  }
592 }
int i
Definition: DBlmapReader.cc:9
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
int j
Definition: DBlmapReader.cc:9
std::string m_FieldFile
Definition: RunManager.h:161
*vegas h *****************************************************used in the default bin number in original ***version of VEGAS is ***a higher bin number might help to derive a more precise ***grade subtle point
Definition: invegas.h:5
G4Event * RunManager::generateEvent ( edm::Event inpevt)
protected

Definition at line 366 of file RunManager.cc.

References edm::EventID::event(), edm::Event::getByLabel(), Generator::HepMC2G4(), edm::EventBase::id(), m_currentEvent, m_generator, m_InTag, m_nonBeam, m_simEvent, Generator::nonBeamEvent2G4(), resetGenParticleId(), and Generator::setGenEvent().

Referenced by produce().

367 {
368  if (m_currentEvent!=0) { delete m_currentEvent; }
369  m_currentEvent = 0;
370  if (m_simEvent!=0) { delete m_simEvent; }
371  m_simEvent = 0;
372 
373  // 64 bits event ID in CMSSW converted into Geant4 event ID
374  G4int evtid = (G4int)inpevt.id().event();
375  G4Event * evt = new G4Event(evtid);
376 
378 
379  inpevt.getByLabel( m_InTag, HepMCEvt ) ;
380 
381  m_generator->setGenEvent(HepMCEvt->GetEvent());
382 
383  // required to reset the GenParticle Id for particles transported
384  // along the beam pipe
385  // to their original value for SimTrack creation
386  resetGenParticleId( inpevt );
387 
388  if (!m_nonBeam)
389  {
390  m_generator->HepMC2G4(HepMCEvt->GetEvent(),evt);
391  }
392  else
393  {
394  m_generator->nonBeamEvent2G4(HepMCEvt->GetEvent(),evt);
395  }
396 
397  return evt;
398 }
EventNumber_t event() const
Definition: EventID.h:41
G4Event * m_currentEvent
Definition: RunManager.h:117
void HepMC2G4(const HepMC::GenEvent *g, G4Event *e)
Definition: Generator.cc:100
Generator * m_generator
Definition: RunManager.h:104
bool m_nonBeam
Definition: RunManager.h:107
void setGenEvent(const HepMC::GenEvent *inpevt)
Definition: Generator.h:25
void resetGenParticleId(edm::Event &inpevt)
Definition: RunManager.cc:507
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:418
void nonBeamEvent2G4(const HepMC::GenEvent *g, G4Event *e)
Definition: Generator.cc:500
std::string m_InTag
Definition: RunManager.h:105
edm::EventID id() const
Definition: EventBase.h:59
G4SimEvent * m_simEvent
Definition: RunManager.h:118
const Generator* RunManager::generator ( ) const
inline

Definition at line 75 of file RunManager.h.

References m_generator.

75 { return m_generator; }
Generator * m_generator
Definition: RunManager.h:104
SimTrackManager * RunManager::GetSimTrackManager ( )

Definition at line 516 of file RunManager.cc.

References m_trackManager.

Referenced by SimRunInterface::SimRunInterface().

517 {
518  return m_trackManager.get();
519 }
std::auto_ptr< SimTrackManager > m_trackManager
Definition: RunManager.h:152
void RunManager::initG4 ( const edm::EventSetup es)

Definition at line 167 of file RunManager.cc.

References SimActivityRegistry::beginOfJobSignal_, sim::FieldBuilder::build(), trackerTree::check(), edm::ESWatcher< T >::check(), cmsHarvester::cmd, AttachSD::create(), beamerCreator::create(), SimActivityRegistry::dddWorldSignal_, dir, DumpMagneticField(), Exception, firstRun, g, reco::get(), edm::EventSetup::get(), edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), DDDWorld::GetWorldVolume(), idealGeomRcdWatcher_, idealMagRcdWatcher_, recoMuon::in, initializeRun(), initializeUserActions(), m_attach, m_check, m_chordFinderSetter, m_fieldBuilder, m_FieldFile, m_G4Commands, m_g4overlap, m_kernel, m_managerInitialized, m_p, m_pField, m_physicsList, m_PhysicsTablesDir, m_pPhysics, m_primaryTransformer, m_prodCuts, m_pUseMagneticField, m_RegionFile, m_registry, m_RestorePhysicsTables, m_sensCaloDets, m_sensTkDets, m_StorePhysicsTables, m_trackManager, m_WriteFile, map_, G4RegionReporter::ReportRegions(), and AlCaHLTBitMon_QueryRunRegistry::string.

168 {
169  bool geomChanged = idealGeomRcdWatcher_.check(es);
170  if (geomChanged && (!firstRun)) {
171  throw cms::Exception("BadConfig")
172  << "[SimG4Core RunManager]\n"
173  << "The Geometry configuration is changed during the job execution\n"
174  << "this is not allowed, the geometry must stay unchanged\n";
175  }
176  if (m_pUseMagneticField) {
177  bool magChanged = idealMagRcdWatcher_.check(es);
178  if (magChanged && (!firstRun)) {
179  throw cms::Exception("BadConfig")
180  << "[SimG4Core RunManager]\n"
181  << "The MagneticField configuration is changed during the job execution\n"
182  << "this is not allowed, the MagneticField must stay unchanged\n";
183  }
184  }
185 
186  if (m_managerInitialized) return;
187 
188  // DDDWorld: get the DDCV from the ES and use it to build the World
190  es.get<IdealGeometryRecord>().get(pDD);
191 
193  SensitiveDetectorCatalog catalog_;
194  const DDDWorld * world = new DDDWorld(&(*pDD), map_, catalog_, false);
196 
198  {
199  // setup the magnetic field
201  es.get<IdealMagneticFieldRecord>().get(pMF);
202  const GlobalPoint g(0.,0.,0.);
203 
205  m_fieldBuilder = new sim::FieldBuilder(&(*pMF), m_pField);
206  G4TransportationManager * tM =
207  G4TransportationManager::GetTransportationManager();
208  m_fieldBuilder->build( tM->GetFieldManager(),
209  tM->GetPropagatorInField(),
211  if("" != m_FieldFile) {
212  DumpMagneticField(tM->GetFieldManager()->GetDetectorField());
213  }
214  }
215 
216  // we need the track manager now
217  m_trackManager = std::auto_ptr<SimTrackManager>(new SimTrackManager);
218 
219  // attach sensitive detector
220  m_attach = new AttachSD;
221 
222  std::pair< std::vector<SensitiveTkDetector*>,
223  std::vector<SensitiveCaloDetector*> > sensDets =
224  m_attach->create(*world,(*pDD),catalog_,m_p,m_trackManager.get(),
225  m_registry);
226 
227  m_sensTkDets.swap(sensDets.first);
228  m_sensCaloDets.swap(sensDets.second);
229 
230  edm::LogInfo("SimG4CoreApplication")
231  << " RunManager: Sensitive Detector "
232  << "building finished; found "
233  << m_sensTkDets.size()
234  << " Tk type Producers, and "
235  << m_sensCaloDets.size()
236  << " Calo type producers ";
237 
239  es.get<PDTRecord>().get(fTable);
240  const HepPDT::ParticleDataTable *fPDGTable = &(*fTable);
241 
243 
244  std::auto_ptr<PhysicsListMakerBase>
245  physicsMaker(PhysicsListFactory::get()->create(
246  m_pPhysics.getParameter<std::string> ("type")));
247  if (physicsMaker.get()==0) {
248  throw SimG4Exception("Unable to find the Physics list requested");
249  }
250  m_physicsList =
251  physicsMaker->make(map_,fPDGTable,m_chordFinderSetter,m_pPhysics,m_registry);
252 
253  PhysicsList* phys = m_physicsList.get();
254  if (phys==0) {
255  throw SimG4Exception("Physics list construction failed!");
256  }
257 
258  // adding GFlash, Russian Roulette for eletrons and gamma,
259  // step limiters on top of any Physics Lists
260  phys->RegisterPhysics(new ParametrisedEMPhysics("EMoptions",m_pPhysics));
261 
262  m_physicsList->ResetStoredInAscii();
263  std::string tableDir = m_PhysicsTablesDir;
265  m_physicsList->SetPhysicsTableRetrieved(tableDir);
266  }
267  edm::LogInfo("SimG4CoreApplication")
268  << "RunManager: start initialisation of PhysicsList";
269 
270  int verb = m_pPhysics.getUntrackedParameter<int>("Verbosity",0);
271  m_physicsList->SetDefaultCutValue(m_pPhysics.getParameter<double>("DefaultCutValue")*CLHEP::cm);
272  m_physicsList->SetCutsWithDefault();
273  m_prodCuts.reset(new DDG4ProductionCuts(map_, verb, m_pPhysics));
274  m_prodCuts->update();
275 
276  m_kernel->SetPhysics(phys);
277  m_kernel->InitializePhysics();
278 
279  if (m_kernel->RunInitialization()) { m_managerInitialized = true; }
280  else {
281  throw SimG4Exception("G4RunManagerKernel initialization failed!");
282  }
283 
285  {
286  std::ostringstream dir;
287  dir << tableDir << '\0';
288  std::string cmd = std::string("/control/shell mkdir -p ")+tableDir;
289  if (!std::ifstream(dir.str().c_str(), std::ios::in))
290  G4UImanager::GetUIpointer()->ApplyCommand(cmd);
291  m_physicsList->StorePhysicsTable(tableDir);
292  }
293 
294  //tell all interesting parties that we are beginning the job
295  BeginOfJob aBeginOfJob(&es);
296  m_registry.beginOfJobSignal_(&aBeginOfJob);
297 
299 
300  if(0 < m_G4Commands.size()) {
301  G4cout << "RunManager: Requested UI commands: " << G4endl;
302  for (unsigned it=0; it<m_G4Commands.size(); ++it) {
303  G4cout << " " << m_G4Commands[it] << G4endl;
304  G4UImanager::GetUIpointer()->ApplyCommand(m_G4Commands[it]);
305  }
306  }
307 
308  if("" != m_WriteFile) {
309  G4GDMLParser gdml;
310  gdml.Write(m_WriteFile, world->GetWorldVolume(), true);
311  }
312 
313  if("" != m_RegionFile) {
314  G4RegionReporter rrep;
316  }
317 
319 
320  // If the Geant4 particle table is needed, decomment the lines below
321  //
322  // G4cout << "Output of G4ParticleTable DumpTable:" << G4endl;
323  // G4ParticleTable::GetParticleTable()->DumpTable("ALL");
324 
325  initializeRun();
326  firstRun= false;
327 }
T getParameter(std::string const &) const
bool m_check
Definition: RunManager.h:128
Map map_
T getUntrackedParameter(std::string const &, T const &) const
std::auto_ptr< SimTrackManager > m_trackManager
Definition: RunManager.h:152
edm::ESWatcher< IdealMagneticFieldRecord > idealMagRcdWatcher_
Definition: RunManager.h:157
const G4VPhysicalVolume * GetWorldVolume() const
Definition: DDDWorld.h:18
SimActivityRegistry m_registry
Definition: RunManager.h:148
edm::ParameterSet m_p
Definition: RunManager.h:141
HepPDT::ParticleDataTable ParticleDataTable
void initializeRun()
Definition: RunManager.cc:469
void initializeUserActions()
Definition: RunManager.cc:433
bool m_pUseMagneticField
Definition: RunManager.h:115
edm::ESWatcher< IdealGeometryRecord > idealGeomRcdWatcher_
Definition: RunManager.h:156
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e g
Definition: Activities.doc:4
std::vector< SensitiveCaloDetector * > m_sensCaloDets
Definition: RunManager.h:145
std::vector< SensitiveTkDetector * > m_sensTkDets
Definition: RunManager.h:144
BeginOfJobSignal beginOfJobSignal_
std::auto_ptr< PhysicsList > m_physicsList
Definition: RunManager.h:108
std::string m_WriteFile
Definition: RunManager.h:162
bool firstRun
Definition: RunManager.h:114
void build(G4FieldManager *fM=nullptr, G4PropagatorInField *fP=nullptr, ChordFinderSetter *setter=nullptr)
Definition: FieldBuilder.cc:48
bool m_RestorePhysicsTables
Definition: RunManager.h:126
edm::ParameterSet m_pField
Definition: RunManager.h:130
edm::ParameterSet m_pPhysics
Definition: RunManager.h:133
edm::ParameterSet m_g4overlap
Definition: RunManager.h:139
DDDWorldSignal dddWorldSignal_
const T & get() const
Definition: EventSetup.h:56
std::pair< std::vector< SensitiveTkDetector * >, std::vector< SensitiveCaloDetector * > > create(const DDDWorld &w, const DDCompactView &cpv, const SensitiveDetectorCatalog &clg, edm::ParameterSet const &p, const SimTrackManager *m, SimActivityRegistry &reg) const
Definition: AttachSD.cc:23
bool check(const edm::EventSetup &iSetup)
Definition: ESWatcher.h:57
void ReportRegions(const std::string &ss)
void DumpMagneticField(const G4Field *) const
Definition: RunManager.cc:544
string cmd
self.logger.debug(&quot;Path is now `%s&#39;&quot; % \ path)
sim::ChordFinderSetter * m_chordFinderSetter
Definition: RunManager.h:154
std::string m_RegionFile
Definition: RunManager.h:163
AttachSD * m_attach
Definition: RunManager.h:143
PrimaryTransformer * m_primaryTransformer
Definition: RunManager.h:109
sim::FieldBuilder * m_fieldBuilder
Definition: RunManager.h:153
std::string m_PhysicsTablesDir
Definition: RunManager.h:124
bool m_StorePhysicsTables
Definition: RunManager.h:125
dbl *** dir
Definition: mlp_gen.cc:35
std::unique_ptr< DDG4ProductionCuts > m_prodCuts
Definition: RunManager.h:147
std::vector< std::string > m_G4Commands
Definition: RunManager.h:140
std::string m_FieldFile
Definition: RunManager.h:161
bool m_managerInitialized
Definition: RunManager.h:110
T get(const Candidate &c)
Definition: component.h:55
G4RunManagerKernel * m_kernel
Definition: RunManager.h:102
void RunManager::initializeRun ( )

Definition at line 469 of file RunManager.cc.

References RunAction::BeginOfRunAction(), m_currentRun, m_runAborted, m_runInitialized, and m_userRunAction.

Referenced by initG4().

470 {
471  m_runInitialized = false;
472  if (m_currentRun==0) { m_currentRun = new G4Run(); }
473  G4StateManager::GetStateManager()->SetNewState(G4State_GeomClosed);
475  m_runAborted = false;
476  m_runInitialized = true;
477 }
G4Run * m_currentRun
Definition: RunManager.h:116
RunAction * m_userRunAction
Definition: RunManager.h:119
void BeginOfRunAction(const G4Run *aRun)
Definition: RunAction.cc:21
bool m_runInitialized
Definition: RunManager.h:111
bool m_runAborted
Definition: RunManager.h:113
void RunManager::initializeUserActions ( )

Definition at line 433 of file RunManager.cc.

References Connect(), m_EvtMgrVerbosity, m_generator, m_kernel, m_pEventAction, m_pRunAction, m_pStackingAction, m_pSteppingAction, m_pTrackingAction, m_runInterface, m_trackManager, and m_userRunAction.

Referenced by initG4().

434 {
435  m_runInterface = new SimRunInterface(this, false);
436 
439 
440  G4EventManager * eventManager = m_kernel->GetEventManager();
441  eventManager->SetVerboseLevel(m_EvtMgrVerbosity);
442 
443  if (m_generator!=0) {
444  EventAction * userEventAction =
446  Connect(userEventAction);
447  eventManager->SetUserAction(userEventAction);
448 
449  TrackingAction* userTrackingAction =
450  new TrackingAction(userEventAction,m_pTrackingAction);
451  Connect(userTrackingAction);
452  eventManager->SetUserAction(userTrackingAction);
453 
454  SteppingAction* userSteppingAction =
455  new SteppingAction(userEventAction,m_pSteppingAction);
456  Connect(userSteppingAction);
457  eventManager->SetUserAction(userSteppingAction);
458 
459  eventManager->SetUserAction(new StackingAction(userTrackingAction,
461 
462  } else {
463  edm::LogWarning("SimG4CoreApplication") << " RunManager: WARNING : "
464  << "No generator; initialized "
465  << "only RunAction!";
466  }
467 }
std::auto_ptr< SimTrackManager > m_trackManager
Definition: RunManager.h:152
Generator * m_generator
Definition: RunManager.h:104
int m_EvtMgrVerbosity
Definition: RunManager.h:127
SimRunInterface * m_runInterface
Definition: RunManager.h:120
edm::ParameterSet m_pStackingAction
Definition: RunManager.h:136
edm::ParameterSet m_pEventAction
Definition: RunManager.h:135
edm::ParameterSet m_pSteppingAction
Definition: RunManager.h:138
RunAction * m_userRunAction
Definition: RunManager.h:119
void Connect(RunAction *)
Definition: RunManager.cc:521
edm::ParameterSet m_pRunAction
Definition: RunManager.h:134
edm::ParameterSet m_pTrackingAction
Definition: RunManager.h:137
G4RunManagerKernel * m_kernel
Definition: RunManager.h:102
void RunManager::produce ( edm::Event inpevt,
const edm::EventSetup es 
)

Definition at line 335 of file RunManager.cc.

References abortRun(), G4SimEvent::collisionPoint(), edm::EventID::event(), Generator::eventWeight(), generateEvent(), Generator::genEvent(), Generator::genVertex(), G4SimEvent::hepEvent(), edm::EventBase::id(), m_currentEvent, m_generator, m_kernel, m_simEvent, G4SimEvent::nGenParts(), G4SimEvent::nTracks(), G4SimEvent::nVertices(), edm::second(), and G4SimEvent::weight().

336 {
337  m_currentEvent = generateEvent(inpevt);
338  m_simEvent = new G4SimEvent;
341  if (m_generator->genVertex() !=0 ) {
344  m_generator->genVertex()->y()/centimeter,
345  m_generator->genVertex()->z()/centimeter,
346  m_generator->genVertex()->t()/second));
347  }
348  if (m_currentEvent->GetNumberOfPrimaryVertex()==0) {
349  edm::LogError("SimG4CoreApplication")
350  << " RunManager::produce event " << inpevt.id().event()
351  << " with no G4PrimaryVertices \n Aborting Run" ;
352 
353  abortRun(false);
354  } else {
355  m_kernel->GetEventManager()->ProcessOneEvent(m_currentEvent);
356  }
357 
358  edm::LogInfo("SimG4CoreApplication")
359  << " RunManager: saved : Event " << inpevt.id().event()
360  << " of weight " << m_simEvent->weight()
361  << " with " << m_simEvent->nTracks() << " tracks and "
362  << m_simEvent->nVertices()
363  << " vertices, generated by " << m_simEvent->nGenParts() << " particles ";
364 }
EventNumber_t event() const
Definition: EventID.h:41
virtual const math::XYZTLorentzVector * genVertex() const
Definition: Generator.h:30
virtual const double eventWeight() const
Definition: Generator.h:31
ROOT::Math::LorentzVector< ROOT::Math::PxPyPzE4D< double > > XYZTLorentzVectorD
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:14
G4Event * m_currentEvent
Definition: RunManager.h:117
void abortRun(bool softAbort=false)
Definition: RunManager.cc:497
virtual const HepMC::GenEvent * genEvent() const
Definition: Generator.h:29
Generator * m_generator
Definition: RunManager.h:104
U second(std::pair< T, U > const &p)
void weight(float w)
Definition: G4SimEvent.h:27
void hepEvent(const HepMC::GenEvent *r)
Definition: G4SimEvent.h:25
unsigned int nTracks() const
Definition: G4SimEvent.h:22
unsigned int nVertices() const
Definition: G4SimEvent.h:23
unsigned int nGenParts() const
Definition: G4SimEvent.h:24
G4Event * generateEvent(edm::Event &inpevt)
Definition: RunManager.cc:366
edm::EventID id() const
Definition: EventBase.h:59
void collisionPoint(const math::XYZTLorentzVectorD &v)
Definition: G4SimEvent.h:29
G4SimEvent * m_simEvent
Definition: RunManager.h:118
G4RunManagerKernel * m_kernel
Definition: RunManager.h:102
std::vector<std::shared_ptr<SimProducer> > RunManager::producers ( ) const
inline

Definition at line 84 of file RunManager.h.

References m_producers.

84  {
85  return m_producers;
86  }
std::vector< std::shared_ptr< SimProducer > > m_producers
Definition: RunManager.h:150
void RunManager::resetGenParticleId ( edm::Event inpevt)
protected

Definition at line 507 of file RunManager.cc.

References edm::Event::getByLabel(), edm::HandleBase::isValid(), m_theLHCTlinkTag, m_trackManager, and edm::Handle< T >::product().

Referenced by generateEvent().

508 {
510  inpevt.getByLabel( m_theLHCTlinkTag, theLHCTlink );
511  if ( theLHCTlink.isValid() ) {
512  m_trackManager->setLHCTransportLink( theLHCTlink.product() );
513  }
514 }
std::auto_ptr< SimTrackManager > m_trackManager
Definition: RunManager.h:152
bool isValid() const
Definition: HandleBase.h:75
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:418
T const * product() const
Definition: Handle.h:81
edm::InputTag m_theLHCTlinkTag
Definition: RunManager.h:159
std::vector<SensitiveCaloDetector*>& RunManager::sensCaloDetectors ( )
inline

Definition at line 81 of file RunManager.h.

References m_sensCaloDets.

81  {
82  return m_sensCaloDets;
83  }
std::vector< SensitiveCaloDetector * > m_sensCaloDets
Definition: RunManager.h:145
std::vector<SensitiveTkDetector*>& RunManager::sensTkDetectors ( )
inline

Definition at line 78 of file RunManager.h.

References m_sensTkDets.

78  {
79  return m_sensTkDets;
80  }
std::vector< SensitiveTkDetector * > m_sensTkDets
Definition: RunManager.h:144
G4SimEvent* RunManager::simEvent ( )
inline

Definition at line 77 of file RunManager.h.

References m_simEvent.

Referenced by SimRunInterface::simEvent().

77 { return m_simEvent; }
G4SimEvent * m_simEvent
Definition: RunManager.h:118
void RunManager::stopG4 ( )

Definition at line 329 of file RunManager.cc.

References m_runTerminated, and terminateRun().

330 {
331  G4StateManager::GetStateManager()->SetNewState(G4State_Quit);
332  if (!m_runTerminated) { terminateRun(); }
333 }
void terminateRun()
Definition: RunManager.cc:479
bool m_runTerminated
Definition: RunManager.h:112
void RunManager::terminateRun ( )

Definition at line 479 of file RunManager.cc.

References RunAction::EndOfRunAction(), m_currentEvent, m_currentRun, m_kernel, m_runInitialized, m_runTerminated, m_simEvent, and m_userRunAction.

Referenced by abortRun(), stopG4(), and ~RunManager().

480 {
481  if (m_userRunAction!=0) {
483  delete m_userRunAction;
484  m_userRunAction = 0;
485  }
486  if (m_kernel!=0 && !m_runTerminated) {
487  delete m_currentEvent;
488  m_currentEvent = 0;
489  delete m_simEvent;
490  m_simEvent = 0;
491  m_kernel->RunTermination();
492  m_runInitialized = false;
493  m_runTerminated = true;
494  }
495 }
G4Event * m_currentEvent
Definition: RunManager.h:117
void EndOfRunAction(const G4Run *aRun)
Definition: RunAction.cc:39
G4Run * m_currentRun
Definition: RunManager.h:116
bool m_runTerminated
Definition: RunManager.h:112
RunAction * m_userRunAction
Definition: RunManager.h:119
bool m_runInitialized
Definition: RunManager.h:111
G4SimEvent * m_simEvent
Definition: RunManager.h:118
G4RunManagerKernel * m_kernel
Definition: RunManager.h:102

Member Data Documentation

bool RunManager::firstRun
private

Definition at line 114 of file RunManager.h.

Referenced by initG4().

edm::ESWatcher<IdealGeometryRecord> RunManager::idealGeomRcdWatcher_
private

Definition at line 156 of file RunManager.h.

Referenced by initG4().

edm::ESWatcher<IdealMagneticFieldRecord> RunManager::idealMagRcdWatcher_
private

Definition at line 157 of file RunManager.h.

Referenced by initG4().

AttachSD* RunManager::m_attach
private

Definition at line 143 of file RunManager.h.

Referenced by initG4().

bool RunManager::m_check
private

Definition at line 128 of file RunManager.h.

Referenced by initG4(), and RunManager().

sim::ChordFinderSetter* RunManager::m_chordFinderSetter
private

Definition at line 154 of file RunManager.h.

Referenced by initG4().

G4Event* RunManager::m_currentEvent
private

Definition at line 117 of file RunManager.h.

Referenced by abortEvent(), currentEvent(), generateEvent(), produce(), and terminateRun().

G4Run* RunManager::m_currentRun
private

Definition at line 116 of file RunManager.h.

Referenced by abortRun(), currentRun(), initializeRun(), and terminateRun().

int RunManager::m_EvtMgrVerbosity
private

Definition at line 127 of file RunManager.h.

Referenced by initializeUserActions().

sim::FieldBuilder* RunManager::m_fieldBuilder
private

Definition at line 153 of file RunManager.h.

Referenced by initG4().

std::string RunManager::m_FieldFile
private

Definition at line 161 of file RunManager.h.

Referenced by DumpMagneticField(), initG4(), and RunManager().

std::vector<std::string> RunManager::m_G4Commands
private

Definition at line 140 of file RunManager.h.

Referenced by initG4().

edm::ParameterSet RunManager::m_g4overlap
private

Definition at line 139 of file RunManager.h.

Referenced by initG4().

Generator* RunManager::m_generator
private

Definition at line 104 of file RunManager.h.

Referenced by generateEvent(), generator(), initializeUserActions(), produce(), and RunManager().

std::string RunManager::m_InTag
private

Definition at line 105 of file RunManager.h.

Referenced by generateEvent(), and RunManager().

G4RunManagerKernel* RunManager::m_kernel
private
bool RunManager::m_managerInitialized
private

Definition at line 110 of file RunManager.h.

Referenced by initG4().

bool RunManager::m_nonBeam
private

Definition at line 107 of file RunManager.h.

Referenced by generateEvent().

edm::ParameterSet RunManager::m_p
private

Definition at line 141 of file RunManager.h.

Referenced by initG4(), and RunManager().

edm::ParameterSet RunManager::m_pEventAction
private

Definition at line 135 of file RunManager.h.

Referenced by initializeUserActions().

edm::ParameterSet RunManager::m_pField
private

Definition at line 130 of file RunManager.h.

Referenced by initG4().

edm::ParameterSet RunManager::m_pGenerator
private

Definition at line 131 of file RunManager.h.

Referenced by RunManager().

edm::ParameterSet RunManager::m_pGeometry
private

Definition at line 129 of file RunManager.h.

std::auto_ptr<PhysicsList> RunManager::m_physicsList
private

Definition at line 108 of file RunManager.h.

Referenced by initG4().

std::string RunManager::m_PhysicsTablesDir
private

Definition at line 124 of file RunManager.h.

Referenced by initG4().

edm::ParameterSet RunManager::m_pPhysics
private

Definition at line 133 of file RunManager.h.

Referenced by initG4().

PrimaryTransformer* RunManager::m_primaryTransformer
private

Definition at line 109 of file RunManager.h.

Referenced by initG4().

std::unique_ptr<DDG4ProductionCuts> RunManager::m_prodCuts
private

Definition at line 147 of file RunManager.h.

Referenced by initG4().

std::vector<std::shared_ptr<SimProducer> > RunManager::m_producers
private

Definition at line 150 of file RunManager.h.

Referenced by producers(), and RunManager().

edm::ParameterSet RunManager::m_pRunAction
private

Definition at line 134 of file RunManager.h.

Referenced by initializeUserActions().

edm::ParameterSet RunManager::m_pStackingAction
private

Definition at line 136 of file RunManager.h.

Referenced by initializeUserActions().

edm::ParameterSet RunManager::m_pSteppingAction
private

Definition at line 138 of file RunManager.h.

Referenced by initializeUserActions().

edm::ParameterSet RunManager::m_pTrackingAction
private

Definition at line 137 of file RunManager.h.

Referenced by initializeUserActions().

bool RunManager::m_pUseMagneticField
private

Definition at line 115 of file RunManager.h.

Referenced by initG4().

edm::ParameterSet RunManager::m_pVertexGenerator
private

Definition at line 132 of file RunManager.h.

std::string RunManager::m_RegionFile
private

Definition at line 163 of file RunManager.h.

Referenced by initG4(), and RunManager().

SimActivityRegistry RunManager::m_registry
private

Definition at line 148 of file RunManager.h.

Referenced by Connect(), initG4(), and RunManager().

bool RunManager::m_RestorePhysicsTables
private

Definition at line 126 of file RunManager.h.

Referenced by initG4().

bool RunManager::m_runAborted
private

Definition at line 113 of file RunManager.h.

Referenced by abortRun(), and initializeRun().

bool RunManager::m_runInitialized
private

Definition at line 111 of file RunManager.h.

Referenced by abortRun(), initializeRun(), and terminateRun().

SimRunInterface* RunManager::m_runInterface
private

Definition at line 120 of file RunManager.h.

Referenced by initializeUserActions(), RunManager(), and ~RunManager().

bool RunManager::m_runTerminated
private

Definition at line 112 of file RunManager.h.

Referenced by abortEvent(), stopG4(), terminateRun(), and ~RunManager().

std::vector<SensitiveCaloDetector*> RunManager::m_sensCaloDets
private

Definition at line 145 of file RunManager.h.

Referenced by initG4(), and sensCaloDetectors().

std::vector<SensitiveTkDetector*> RunManager::m_sensTkDets
private

Definition at line 144 of file RunManager.h.

Referenced by initG4(), and sensTkDetectors().

G4SimEvent* RunManager::m_simEvent
private

Definition at line 118 of file RunManager.h.

Referenced by generateEvent(), produce(), simEvent(), and terminateRun().

bool RunManager::m_StorePhysicsTables
private

Definition at line 125 of file RunManager.h.

Referenced by initG4().

edm::InputTag RunManager::m_theLHCTlinkTag
private

Definition at line 159 of file RunManager.h.

Referenced by resetGenParticleId().

std::auto_ptr<SimTrackManager> RunManager::m_trackManager
private
RunAction* RunManager::m_userRunAction
private

Definition at line 119 of file RunManager.h.

Referenced by initializeRun(), initializeUserActions(), RunManager(), and terminateRun().

std::vector<std::shared_ptr<SimWatcher> > RunManager::m_watchers
private

Definition at line 149 of file RunManager.h.

Referenced by RunManager().

std::string RunManager::m_WriteFile
private

Definition at line 162 of file RunManager.h.

Referenced by initG4(), and RunManager().