VMC Examples Version 6.6
Loading...
Searching...
No Matches
exampleTR.cxx
Go to the documentation of this file.
1//------------------------------------------------
2// The Virtual Monte Carlo examples
3// Copyright (C) 2014 - 2015 Ivana Hrivnacova
4// All rights reserved.
5//
6// For the licensing terms see geant4_vmc/LICENSE.
7// Contact: root-vmc@cern.ch
8//-------------------------------------------------
9
10/// \file exampleTR.cxx
11/// \brief The Geant4 VMC example TR application executable
12///
13/// \date 18/12/2015
14/// \author I. Hrivnacova; IPN, Orsay
15
16#include "MCApplication.h"
17#include "PrimaryGenerator.h"
18
19#ifdef USE_GEANT4
20#include "TG4RunConfiguration.h"
21#include "TGeant4.h"
22#endif
23
24#ifdef USE_GEANT3
25#include "TGeant3TGeo.h"
26#endif
27
28#include "TROOT.h"
29
30/// Application main program
31int main(int argc, char** argv)
32{
33 // Initialize Root threading.
34 // (Multi-threading is triggered automatically if Geant4 was built
35 // in MT mode.)
36#ifdef G4MULTITHREADED
37 ROOT::EnableThreadSafety();
38#endif
39
40 // Create MC application (thread local)
42 new VMC::TR::MCApplication("ExampleTR", "The exampleTR MC application");
44 appl->SetPrintModulo(10000);
45
46#ifdef USE_GEANT4
47 // RunConfiguration for Geant4
48 TG4RunConfiguration* runConfiguration =
49 new TG4RunConfiguration("geomRootToGeant4", "emStandard", "", false, false);
50
51 // TGeant4
52 TGeant4* geant4 = new TGeant4(
53 "TGeant4", "The Geant4 Monte Carlo", runConfiguration, argc, argv);
54
55 // Customise Geant4 setting
56 // (verbose level, global range cut, ..)
57 geant4->ProcessGeantMacro("g4config.in");
58#endif
59
60#ifdef USE_GEANT3
61 new TGeant3TGeo("C++ Interface to Geant3");
62 gMC->SetProcess("DRAY", 1);
63 gMC->SetProcess("LOSS", 1);
64 gMC->SetProcess("HADR", 0);
65#endif
66
67 // Run example
68 appl->InitMC("");
69
70#ifdef USE_GEANT4
71 // Customise Geant4 setting after initialization:
72 geant4->ProcessGeantMacro("g4config2.in");
73
74 // Setting Geant4 visualization
75 // geant4->ProcessGeantMacro("g4vis.in");
76#endif
77
78 appl->RunMC(5000);
79
80 delete appl;
81}
Implementation of the TVirtualMCApplication.
PrimaryGenerator * GetPrimaryGenerator() const
void SetPrintModulo(Int_t value)
void RunMC(Int_t nofEvents)
void InitMC(const char *setup)
void SetNofPrimaries(Int_t nofPrimaries)
int main(int argc, char **argv)
Application main program.
Definition exampleTR.cxx:31