VMC Examples Version 6.6
Loading...
Searching...
No Matches
A01MCApplication Class Reference

Implementation of the TVirtualMCApplication. More...

#include <A01MCApplication.h>

Inheritance diagram for A01MCApplication:

Public Member Functions

 A01MCApplication (const char *name, const char *title)
 
 A01MCApplication ()
 
virtual ~A01MCApplication ()
 
void InitMC (const char *setup)
 
void RunMC (Int_t nofEvents)
 
void FinishRun ()
 
void ReadEvent (Int_t i)
 
virtual TVirtualMCApplicationCloneForWorker () const
 
virtual void InitOnWorker ()
 
virtual void FinishRunOnWorker ()
 
virtual void ConstructGeometry ()
 
virtual void InitGeometry ()
 
virtual void AddParticles ()
 
virtual void AddIons ()
 
virtual void GeneratePrimaries ()
 
virtual void BeginEvent ()
 
virtual void BeginPrimary ()
 
virtual void PreTrack ()
 
virtual void Stepping ()
 
virtual void PostTrack ()
 
virtual void FinishPrimary ()
 
virtual void FinishEvent ()
 
void SetCuts ()
 
void SetWriteStack (Bool_t writeStack)
 
void SetWriteHits (Bool_t writeHits)
 
void SetUseLocalMagField (Bool_t localMagField)
 
void SetVerboseLevel (Int_t verboseLevel)
 
A01RootDetectorConstructionGetDetectorConstruction () const
 
A01PrimaryGeneratorGetPrimaryGenerator () const
 
A01DriftChamberSDGetDriftChamberSD1 () const
 
A01DriftChamberSDGetDriftChamberSD2 () const
 
A01EmCalorimeterSDGetEmCalorimeterSD () const
 
A01HadCalorimeterSDGetHadCalorimeterSD () const
 
A01HodoscopeSDGetHodoscopeSD1 () const
 
A01HodoscopeSDGetHodoscopeSD2 () const
 
Bool_t GetUseLocalMagField () const
 

Private Member Functions

 A01MCApplication (const A01MCApplication &origin)
 
void RegisterStack () const
 

Private Attributes

TMCRootManager * fRootManager
 Root manager.
 
Bool_t fWriteStack
 Option to write stack.
 
Bool_t fWriteHits
 
Bool_t fUseLocalMagField
 Option to use local magnetic field (working only with Geant4 !)
 
TMCVerbose fVerbose
 VMC verbose helper.
 
Ex03MCStackfStack
 VMC stack.
 
A01RootDetectorConstructionfDetConstruction
 Detector construction.
 
A01DriftChamberSDfDriftChamberSD1
 Drift Chamber 1 SD.
 
A01DriftChamberSDfDriftChamberSD2
 Drift Chamber 2 SD.
 
A01EmCalorimeterSDfEmCalorimeterSD
 Em Calorimeter SD.
 
A01HadCalorimeterSDfHadCalorimeterSD
 Had Calorimeter SD.
 
A01HodoscopeSDfHodoscopeSD1
 Hodoscope 1 SD.
 
A01HodoscopeSDfHodoscopeSD2
 Hodoscope 2 SD.
 
A01PrimaryGeneratorfPrimaryGenerator
 Primary generator.
 
A01MagFieldfMagField
 Magnetic field.
 
Bool_t fIsMaster
 If is on master thread.
 

Detailed Description

Implementation of the TVirtualMCApplication.

Date
12/05/2012
Author
I. Hrivnacova; IPN, Orsay

Definition at line 42 of file A01MCApplication.h.

Constructor & Destructor Documentation

◆ A01MCApplication() [1/3]

A01MCApplication::A01MCApplication ( const char * name,
const char * title )

Standard constructor

Parameters
nameThe MC application name
titleThe MC application description

Definition at line 50 of file A01MCApplication.cxx.

51 : TVirtualMCApplication(name, title),
52 fRootManager(0),
53 fWriteStack(true),
54 fWriteHits(true),
55 fUseLocalMagField(false),
56 fVerbose(0),
57 fStack(0),
66 fMagField(0),
67 fIsMaster(kTRUE)
68{
69 /// Standard constructor
70 /// \param name The MC application name
71 /// \param title The MC application description
72
73 // Create a user stack
74 fStack = new Ex03MCStack(1000);
75
76 // Create detector construction
77 fDetConstruction = new A01RootDetectorConstruction("A01geometry.root");
78
79 // Create SDs
80 fDriftChamberSD1 = new A01DriftChamberSD("Chamber1", "wirePlane1Logical");
81 fDriftChamberSD2 = new A01DriftChamberSD("Chamber2", "wirePlane2Logical");
82 fEmCalorimeterSD = new A01EmCalorimeterSD("EmCalorimeter");
83 fHadCalorimeterSD = new A01HadCalorimeterSD("HadCalorimeter");
84 fHodoscopeSD1 = new A01HodoscopeSD("Hodoscope1", "hodoscope1Logical");
85 fHodoscopeSD2 = new A01HodoscopeSD("Hodoscope2", "hodoscope2Logical");
86
87 // Create a primary generator
88 fPrimaryGenerator = new A01PrimaryGenerator(fStack);
89
90 // Constant magnetic field (in kiloGauss)
91 // field value: 1.0*tesla (= 10.0 kiloGauss) in y
92 if (!fUseLocalMagField) {
93 fMagField = new A01MagField(0, 10.0, 0);
94 }
95}
A01HodoscopeSD * fHodoscopeSD2
Hodoscope 2 SD.
A01MagField * fMagField
Magnetic field.
A01DriftChamberSD * fDriftChamberSD1
Drift Chamber 1 SD.
Bool_t fIsMaster
If is on master thread.
A01RootDetectorConstruction * fDetConstruction
Detector construction.
A01DriftChamberSD * fDriftChamberSD2
Drift Chamber 2 SD.
TMCVerbose fVerbose
VMC verbose helper.
A01HadCalorimeterSD * fHadCalorimeterSD
Had Calorimeter SD.
Bool_t fWriteStack
Option to write stack.
Bool_t fUseLocalMagField
Option to use local magnetic field (working only with Geant4 !)
Ex03MCStack * fStack
VMC stack.
A01PrimaryGenerator * fPrimaryGenerator
Primary generator.
TMCRootManager * fRootManager
Root manager.
A01EmCalorimeterSD * fEmCalorimeterSD
Em Calorimeter SD.
A01HodoscopeSD * fHodoscopeSD1
Hodoscope 1 SD.

◆ A01MCApplication() [2/3]

A01MCApplication::A01MCApplication ( )

Default constructor

Definition at line 143 of file A01MCApplication.cxx.

144 : TVirtualMCApplication(),
145 fRootManager(0),
146 fWriteStack(true),
147 fWriteHits(true),
148 fUseLocalMagField(false),
149 fStack(0),
155 fHodoscopeSD1(0),
156 fHodoscopeSD2(0),
158 fMagField(0),
159 fIsMaster(kTRUE)
160{
161 /// Default constructor
162}

◆ ~A01MCApplication()

A01MCApplication::~A01MCApplication ( )
virtual

Destructor

Definition at line 165 of file A01MCApplication.cxx.

166{
167 /// Destructor
168
169 // cout << "A01MCApplication::~A01MCApplication " << this << endl;
170
171 delete fRootManager;
172 delete fStack;
173 if (fIsMaster) delete fDetConstruction;
174 delete fDriftChamberSD1;
175 delete fDriftChamberSD2;
176 delete fEmCalorimeterSD;
177 delete fHadCalorimeterSD;
178 delete fHodoscopeSD1;
179 delete fHodoscopeSD2;
180 delete fPrimaryGenerator;
181 delete fMagField;
182 delete gMC;
183
184 // cout << "Done A01MCApplication::~A01MCApplication " << this << endl;
185}

◆ A01MCApplication() [3/3]

A01MCApplication::A01MCApplication ( const A01MCApplication & origin)
private

Copy constructor (for clonig on worker thread in MT mode).

Parameters
originThe source object (on master).

Definition at line 98 of file A01MCApplication.cxx.

99 : TVirtualMCApplication(origin.GetName(), origin.GetTitle()),
100 fRootManager(0),
101 fWriteStack(origin.fWriteStack),
102 fWriteHits(origin.fWriteHits),
104 fVerbose(origin.fVerbose),
105 fStack(0),
111 fHodoscopeSD1(0),
112 fHodoscopeSD2(0),
114 fMagField(0),
115 fIsMaster(kFALSE)
116{
117 /// Copy constructor (for clonig on worker thread in MT mode).
118 /// \param origin The source object (on master).
119
120 // Create a user stack
121 fStack = new Ex03MCStack(1000);
122
123 // Create SDs
124 fDriftChamberSD1 = new A01DriftChamberSD(*(origin.fDriftChamberSD1));
125 fDriftChamberSD2 = new A01DriftChamberSD(*(origin.fDriftChamberSD2));
126 fEmCalorimeterSD = new A01EmCalorimeterSD(*(origin.fEmCalorimeterSD));
127 fHadCalorimeterSD = new A01HadCalorimeterSD(*(origin.fHadCalorimeterSD));
128 fHodoscopeSD1 = new A01HodoscopeSD(*(origin.fHodoscopeSD1));
129 fHodoscopeSD2 = new A01HodoscopeSD(*(origin.fHodoscopeSD2));
130
131 // Create a primary generator
133 new A01PrimaryGenerator(*(origin.fPrimaryGenerator), fStack);
134
135 // Constant magnetic field (in kiloGauss)
136 // field value: 1.0*tesla (= 10.0 kiloGauss) in y
137 if (!fUseLocalMagField) {
138 fMagField = new A01MagField(0, 10.0, 0);
139 }
140}

Member Function Documentation

◆ InitMC()

void A01MCApplication::InitMC ( const char * setup)

Initialize MC. The selection of the concrete MC is done in the macro.

Parameters
setupThe name of the configuration macro

Definition at line 207 of file A01MCApplication.cxx.

208{
209 /// Initialize MC.
210 /// The selection of the concrete MC is done in the macro.
211 /// \param setup The name of the configuration macro
212
213 fVerbose.InitMC();
214
215 if (TString(setup) != "") {
216 gROOT->LoadMacro(setup);
217 gInterpreter->ProcessLine("Config()");
218 if (!gMC) {
219 Fatal(
220 "InitMC", "Processing Config() has failed. (No MC is instantiated.)");
221 }
222 }
223
224// MT support available from root v 5.34/18
225#if ROOT_VERSION_CODE >= 336402
226 // Create Root manager
227 if (!gMC->IsMT()) {
228 fRootManager = new TMCRootManager(GetName(), TMCRootManager::kWrite);
229 // fRootManager->SetDebug(true);
230 }
231#else
232 // Create Root manager
233 fRootManager = new TMCRootManager(GetName(), TMCRootManager::kWrite);
234 // fRootManager->SetDebug(true);
235#endif
236
237 // Set data to MC
238 gMC->SetStack(fStack);
239 gMC->SetMagField(fMagField);
240
241 // Init MC
242 gMC->Init();
243 gMC->BuildPhysics();
244
246}
void RegisterStack() const

◆ RunMC()

void A01MCApplication::RunMC ( Int_t nofEvents)

Run MC.

Parameters
nofEventsNumber of events to be processed

Definition at line 249 of file A01MCApplication.cxx.

250{
251 /// Run MC.
252 /// \param nofEvents Number of events to be processed
253
254 fVerbose.RunMC(nofEvents);
255
256 gMC->ProcessRun(nofEvents);
257 FinishRun();
258}

◆ FinishRun()

void A01MCApplication::FinishRun ( )

Finish MC run.

Definition at line 261 of file A01MCApplication.cxx.

262{
263 /// Finish MC run.
264
265 fVerbose.FinishRun();
266
267 if (fRootManager && (fWriteStack || fWriteHits)) {
268 fRootManager->WriteAll();
269 fRootManager->Close();
270 }
271}

◆ ReadEvent()

void A01MCApplication::ReadEvent ( Int_t i)

Read i -th event and print hits.

Parameters
iThe number of event to be read

Definition at line 307 of file A01MCApplication.cxx.

308{
309 /// Read \em i -th event and print hits.
310 /// \param i The number of event to be read
311
312 fDriftChamberSD1->Register();
313 fDriftChamberSD2->Register();
314 fEmCalorimeterSD->Register();
315 fHadCalorimeterSD->Register();
316 fHodoscopeSD1->Register();
317 fHodoscopeSD2->Register();
319 fRootManager->ReadEvent(i);
320}

◆ CloneForWorker()

TVirtualMCApplication * A01MCApplication::CloneForWorker ( ) const
virtual

Definition at line 274 of file A01MCApplication.cxx.

275{
276 // cout << "A01MCApplication::CloneForWorker " << this << endl;
277 return new A01MCApplication(*this);
278}

◆ InitOnWorker()

void A01MCApplication::InitOnWorker ( )
virtual

Definition at line 281 of file A01MCApplication.cxx.

282{
283 // cout << "A01MCApplication::InitForWorker " << this << endl;
284
285 // Create Root manager
286 fRootManager = new TMCRootManager(GetName(), TMCRootManager::kWrite);
287 // fRootManager->SetDebug(true);
288
289 // Set data to MC
290 gMC->SetStack(fStack);
291 gMC->SetMagField(fMagField);
292
294}

◆ FinishRunOnWorker()

void A01MCApplication::FinishRunOnWorker ( )
virtual

Definition at line 297 of file A01MCApplication.cxx.

298{
299 // cout << "A01MCApplication::FinishWorkerRun: " << endl;
300 if (fRootManager) {
301 fRootManager->WriteAll();
302 fRootManager->Close();
303 }
304}

◆ ConstructGeometry()

void A01MCApplication::ConstructGeometry ( )
virtual

Construct geometry using detector contruction class.

Definition at line 323 of file A01MCApplication.cxx.

324{
325 /// Construct geometry using detector contruction class.
326
327 fVerbose.ConstructGeometry();
328 fDetConstruction->ConstructGeometry();
329}

◆ InitGeometry()

void A01MCApplication::InitGeometry ( )
virtual

Initialize geometry

Definition at line 332 of file A01MCApplication.cxx.

333{
334 /// Initialize geometry
335
336 fVerbose.InitGeometry();
337
338 // Set cuts in G3 equivalent to 1mm cut in G4
339 if (TString(gMC->GetName()) == "TGeant3TGeo") SetCuts();
340
341 fDriftChamberSD1->Initialize();
342 fDriftChamberSD2->Initialize();
343 fEmCalorimeterSD->Initialize();
344 fHadCalorimeterSD->Initialize();
345 fHodoscopeSD1->Initialize();
346 fHodoscopeSD2->Initialize();
347}

◆ AddParticles()

void A01MCApplication::AddParticles ( )
virtual

Nothing to be done

Definition at line 350 of file A01MCApplication.cxx.

351{
352 /// Nothing to be done
353
354 fVerbose.AddParticles();
355}

◆ AddIons()

void A01MCApplication::AddIons ( )
virtual

Nothing to be done

Definition at line 358 of file A01MCApplication.cxx.

359{
360 /// Nothing to be done
361
362 fVerbose.AddIons();
363}

◆ GeneratePrimaries()

void A01MCApplication::GeneratePrimaries ( )
virtual

Fill the user stack (derived from TVirtualMCStack) with primary particles.

Definition at line 366 of file A01MCApplication.cxx.

367{
368 /// Fill the user stack (derived from TVirtualMCStack) with primary particles.
369
370 fVerbose.GeneratePrimaries();
371 fPrimaryGenerator->GeneratePrimaries();
372}

◆ BeginEvent()

void A01MCApplication::BeginEvent ( )
virtual

User actions at beginning of event

Definition at line 375 of file A01MCApplication.cxx.

376{
377 /// User actions at beginning of event
378
379 fVerbose.BeginEvent();
380
381 // Clear TGeo tracks (if filled)
382 if (TString(gMC->GetName()) == "TGeant3TGeo" &&
383 gGeoManager->GetListOfTracks() && gGeoManager->GetTrack(0) &&
384 ((TVirtualGeoTrack*)gGeoManager->GetTrack(0))->HasPoints()) {
385
386 gGeoManager->ClearTracks();
387 // if (gPad) gPad->Clear();
388 }
389}

◆ BeginPrimary()

void A01MCApplication::BeginPrimary ( )
virtual

User actions at beginning of a primary track.

Definition at line 392 of file A01MCApplication.cxx.

393{
394 /// User actions at beginning of a primary track.
395
396 fVerbose.BeginPrimary();
397}

◆ PreTrack()

void A01MCApplication::PreTrack ( )
virtual

User actions at beginning of each track

Definition at line 400 of file A01MCApplication.cxx.

401{
402 /// User actions at beginning of each track
403
404 fVerbose.PreTrack();
405}

◆ Stepping()

void A01MCApplication::Stepping ( )
virtual

User actions at each step

Definition at line 408 of file A01MCApplication.cxx.

409{
410 /// User actions at each step
411
412 fVerbose.Stepping();
413 fDriftChamberSD1->ProcessHits();
414 fDriftChamberSD2->ProcessHits();
415 fEmCalorimeterSD->ProcessHits();
416 fHadCalorimeterSD->ProcessHits();
417 fHodoscopeSD1->ProcessHits();
418 fHodoscopeSD2->ProcessHits();
419}

◆ PostTrack()

void A01MCApplication::PostTrack ( )
virtual

User actions after finishing each track

Definition at line 422 of file A01MCApplication.cxx.

423{
424 /// User actions after finishing each track
425
426 fVerbose.PostTrack();
427}

◆ FinishPrimary()

void A01MCApplication::FinishPrimary ( )
virtual

User actions after finishing each primary track

Definition at line 430 of file A01MCApplication.cxx.

431{
432 /// User actions after finishing each primary track
433
434 fVerbose.FinishPrimary();
435}

◆ FinishEvent()

void A01MCApplication::FinishEvent ( )
virtual

User actions after finishing an event

Definition at line 438 of file A01MCApplication.cxx.

439{
440 /// User actions after finishing an event
441
442 fVerbose.FinishEvent();
443
444 // Geant3 + TGeo
445 // (use TGeo functions for visualization)
446 if (TString(gMC->GetName()) == "TGeant3TGeo") {
447
448 // Draw volume
449 gGeoManager->SetVisOption(0);
450 gGeoManager->SetTopVisible();
451 gGeoManager->GetTopVolume()->Draw();
452
453 // Draw tracks (if filled)
454 // Available when this feature is activated via
455 // gMC->SetCollectTracks(kTRUE);
456 if (gGeoManager->GetListOfTracks() && gGeoManager->GetTrack(0) &&
457 ((TVirtualGeoTrack*)gGeoManager->GetTrack(0))->HasPoints()) {
458
459 gGeoManager->DrawTracks("/*"); // this means all tracks
460 }
461 }
462
463 if (fWriteStack || fWriteHits) {
464 fRootManager->Fill();
465 }
466
467 // Print info about primary particle
468 TParticle* primary = fStack->GetParticle(0);
469 cout << endl
470 << ">>> Event " << gMC->CurrentEvent()
471 << " >>> Simulation truth : " << primary->GetPDG()->GetName() << " ("
472 << primary->Px() * 1e03 << ", " << primary->Py() * 1e03 << ", "
473 << primary->Pz() * 1e03 << ") MeV" << endl;
474
475 // Call detectors
476 fHodoscopeSD1->EndOfEvent();
477 fHodoscopeSD2->EndOfEvent();
478 fDriftChamberSD1->EndOfEvent();
479 fDriftChamberSD2->EndOfEvent();
480 fEmCalorimeterSD->EndOfEvent();
481 fHadCalorimeterSD->EndOfEvent();
482
483 fStack->Reset();
484}

◆ SetCuts()

void A01MCApplication::SetCuts ( )

Set cuts for e-, gamma equivalent to 1mm cut in G4.

Definition at line 517 of file A01MCApplication.cxx.

518{
519 /// Set cuts for e-, gamma equivalent to 1mm cut in G4.
520
521 Int_t mediumId = gMC->MediumId("Air");
522 if (mediumId) {
523 gMC->Gstpar(mediumId, "CUTGAM", 990.e-09);
524 gMC->Gstpar(mediumId, "BCUTE", 990.e-09);
525 gMC->Gstpar(mediumId, "CUTELE", 990.e-09);
526 gMC->Gstpar(mediumId, "DCUTE", 990.e-09);
527 }
528
529 mediumId = gMC->MediumId("G4_Galactic");
530 if (mediumId) {
531 gMC->Gstpar(mediumId, "CUTGAM", 990.e-09);
532 gMC->Gstpar(mediumId, "BCUTE", 990.e-09);
533 gMC->Gstpar(mediumId, "CUTELE", 990.e-09);
534 gMC->Gstpar(mediumId, "DCUTE", 990.e-09);
535 }
536
537 mediumId = gMC->MediumId("Scintillator");
538 if (mediumId) {
539 gMC->Gstpar(mediumId, "CUTGAM", 2.40367 - 06);
540 gMC->Gstpar(mediumId, "BCUTE", 356.639e-06);
541 gMC->Gstpar(mediumId, "CUTELE", 356.639e-06);
542 gMC->Gstpar(mediumId, "DCUTE", 356.639e-06);
543 }
544
545 mediumId = gMC->MediumId("ArgonGas");
546 if (mediumId) {
547 gMC->Gstpar(mediumId, "CUTGAM", 990.e-09);
548 gMC->Gstpar(mediumId, "BCUTE", 990.e-09);
549 gMC->Gstpar(mediumId, "CUTELE", 990.e-09);
550 gMC->Gstpar(mediumId, "DCUTE", 990.e-09);
551 }
552
553 mediumId = gMC->MediumId("CsI");
554 if (mediumId) {
555 gMC->Gstpar(mediumId, "CUTGAM", 38.5665e-06);
556 gMC->Gstpar(mediumId, "BCUTE", 689.033e-06);
557 gMC->Gstpar(mediumId, "CUTELE", 689.033e-06);
558 gMC->Gstpar(mediumId, "DCUTE", 689.033e-06);
559 }
560
561 mediumId = gMC->MediumId("Lead");
562 if (mediumId) {
563 gMC->Gstpar(mediumId, "CUTGAM", 101.843e-06);
564 gMC->Gstpar(mediumId, "BCUTE", 1.36749e-03);
565 gMC->Gstpar(mediumId, "CUTELE", 1.36749e-03);
566 gMC->Gstpar(mediumId, "DCUTE", 1.36749e-03);
567 }
568}

◆ SetWriteStack()

void A01MCApplication::SetWriteStack ( Bool_t writeStack)
inline

(In)Activate writing stack on file

Parameters
writeStackThe new value of the option

Definition at line 121 of file A01MCApplication.h.

122{
123 fWriteStack = writeStack;
124}

◆ SetWriteHits()

void A01MCApplication::SetWriteHits ( Bool_t writeHits)

(In)Activate writing hits on file and propagate this option to all SDs

Parameters
writeHitsThe new value of the option

Definition at line 487 of file A01MCApplication.cxx.

488{
489 /// (In)Activate writing hits on file and propagate this option
490 /// to all SDs
491 /// \param writeHits The new value of the option
492
493 fWriteHits = writeHits;
494 fHodoscopeSD1->SetWriteHits(writeHits);
495 fHodoscopeSD2->SetWriteHits(writeHits);
496 fDriftChamberSD1->SetWriteHits(writeHits);
497 fDriftChamberSD2->SetWriteHits(writeHits);
498 fEmCalorimeterSD->SetWriteHits(writeHits);
499 fHadCalorimeterSD->SetWriteHits(writeHits);
500}

◆ SetUseLocalMagField()

void A01MCApplication::SetUseLocalMagField ( Bool_t localMagField)

Set the option to use local magnetic field (working only with Geant4 !)

Parameters
localMagFieldThe new value of the option

Definition at line 503 of file A01MCApplication.cxx.

504{
505 /// Set the option to use local magnetic field (working only with Geant4 !)
506 /// \param localMagField The new value of the option
507
508 fUseLocalMagField = localMagField;
509 fDetConstruction->SetUseLocalMagField(localMagField);
510
511 // delete existing global field
512 delete fMagField;
513 fMagField = 0;
514}

◆ SetVerboseLevel()

void A01MCApplication::SetVerboseLevel ( Int_t verboseLevel)
inline

Set verbosity

Parameters
verboseLevelThe new verbose level value

Definition at line 128 of file A01MCApplication.h.

129{
130 fVerbose.SetLevel(verboseLevel);
131}

◆ GetDetectorConstruction()

A01RootDetectorConstruction * A01MCApplication::GetDetectorConstruction ( ) const
inline
Returns
The detector construction

Definition at line 140 of file A01MCApplication.h.

141{
142 return fDetConstruction;
143}

◆ GetPrimaryGenerator()

A01PrimaryGenerator * A01MCApplication::GetPrimaryGenerator ( ) const
inline
Returns
The primary generator

Definition at line 146 of file A01MCApplication.h.

147{
148 return fPrimaryGenerator;
149}

◆ GetDriftChamberSD1()

A01DriftChamberSD * A01MCApplication::GetDriftChamberSD1 ( ) const
inline
Returns
The Drift Chamber 1 SD

Definition at line 152 of file A01MCApplication.h.

153{
154 return fDriftChamberSD1;
155}

◆ GetDriftChamberSD2()

A01DriftChamberSD * A01MCApplication::GetDriftChamberSD2 ( ) const
inline
Returns
The Drift Chamber 2 SD

Definition at line 158 of file A01MCApplication.h.

159{
160 return fDriftChamberSD2;
161}

◆ GetEmCalorimeterSD()

A01EmCalorimeterSD * A01MCApplication::GetEmCalorimeterSD ( ) const
inline
Returns
The Em Calorimeter SD

Definition at line 164 of file A01MCApplication.h.

165{
166 return fEmCalorimeterSD;
167}

◆ GetHadCalorimeterSD()

A01HadCalorimeterSD * A01MCApplication::GetHadCalorimeterSD ( ) const
inline
Returns
The Had Calorimeter SD

Definition at line 170 of file A01MCApplication.h.

171{
172 return fHadCalorimeterSD;
173}

◆ GetHodoscopeSD1()

A01HodoscopeSD * A01MCApplication::GetHodoscopeSD1 ( ) const
inline
Returns
The Hodoscope 1 SD

Definition at line 176 of file A01MCApplication.h.

177{
178 return fHodoscopeSD1;
179}

◆ GetHodoscopeSD2()

A01HodoscopeSD * A01MCApplication::GetHodoscopeSD2 ( ) const
inline
Returns
The Hodoscope 2 SD

Definition at line 182 of file A01MCApplication.h.

183{
184 return fHodoscopeSD2;
185}

◆ GetUseLocalMagField()

Bool_t A01MCApplication::GetUseLocalMagField ( ) const
inline
Returns
The option to use local magnetic field (working only with Geant4 !)

Definition at line 188 of file A01MCApplication.h.

189{
190 return fUseLocalMagField;
191}

◆ RegisterStack()

void A01MCApplication::RegisterStack ( ) const
private

Register stack in the Root manager.

Definition at line 192 of file A01MCApplication.cxx.

193{
194 /// Register stack in the Root manager.
195
196 if (fWriteStack && fRootManager) {
197 // cout << "A01MCApplication::RegisterStack: " << endl;
198 fRootManager->Register("stack", "Ex03MCStack", &fStack);
199 }
200}

Member Data Documentation

◆ fRootManager

TMCRootManager* A01MCApplication::fRootManager
mutableprivate

Root manager.

Definition at line 96 of file A01MCApplication.h.

◆ fWriteStack

Bool_t A01MCApplication::fWriteStack
private

Option to write stack.

Definition at line 97 of file A01MCApplication.h.

◆ fWriteHits

Bool_t A01MCApplication::fWriteHits
private

Option to write hits

Definition at line 98 of file A01MCApplication.h.

◆ fUseLocalMagField

Bool_t A01MCApplication::fUseLocalMagField
private

Option to use local magnetic field (working only with Geant4 !)

Definition at line 100 of file A01MCApplication.h.

◆ fVerbose

TMCVerbose A01MCApplication::fVerbose
private

VMC verbose helper.

Definition at line 101 of file A01MCApplication.h.

◆ fStack

Ex03MCStack* A01MCApplication::fStack
private

VMC stack.

Definition at line 102 of file A01MCApplication.h.

◆ fDetConstruction

A01RootDetectorConstruction* A01MCApplication::fDetConstruction
private

Detector construction.

Definition at line 103 of file A01MCApplication.h.

◆ fDriftChamberSD1

A01DriftChamberSD* A01MCApplication::fDriftChamberSD1
private

Drift Chamber 1 SD.

Definition at line 104 of file A01MCApplication.h.

◆ fDriftChamberSD2

A01DriftChamberSD* A01MCApplication::fDriftChamberSD2
private

Drift Chamber 2 SD.

Definition at line 105 of file A01MCApplication.h.

◆ fEmCalorimeterSD

A01EmCalorimeterSD* A01MCApplication::fEmCalorimeterSD
private

Em Calorimeter SD.

Definition at line 106 of file A01MCApplication.h.

◆ fHadCalorimeterSD

A01HadCalorimeterSD* A01MCApplication::fHadCalorimeterSD
private

Had Calorimeter SD.

Definition at line 107 of file A01MCApplication.h.

◆ fHodoscopeSD1

A01HodoscopeSD* A01MCApplication::fHodoscopeSD1
private

Hodoscope 1 SD.

Definition at line 108 of file A01MCApplication.h.

◆ fHodoscopeSD2

A01HodoscopeSD* A01MCApplication::fHodoscopeSD2
private

Hodoscope 2 SD.

Definition at line 109 of file A01MCApplication.h.

◆ fPrimaryGenerator

A01PrimaryGenerator* A01MCApplication::fPrimaryGenerator
private

Primary generator.

Definition at line 110 of file A01MCApplication.h.

◆ fMagField

A01MagField* A01MCApplication::fMagField
private

Magnetic field.

Definition at line 111 of file A01MCApplication.h.

◆ fIsMaster

Bool_t A01MCApplication::fIsMaster
private

If is on master thread.

Definition at line 112 of file A01MCApplication.h.


The documentation for this class was generated from the following files: