Geant4.10
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Functions
electronScattering.cc File Reference

Main program of the medical/electronScattering example. More...

#include "G4RunManager.hh"
#include "G4UImanager.hh"
#include "Randomize.hh"
#include "DetectorConstruction.hh"
#include "PhysicsList.hh"
#include "PrimaryGeneratorAction.hh"
#include "RunAction.hh"
#include "EventAction.hh"
#include "TrackingAction.hh"
#include "SteppingVerbose.hh"

Go to the source code of this file.

Functions

int main (int argc, char **argv)
 

Detailed Description

Main program of the medical/electronScattering example.

Definition in file electronScattering.cc.

Function Documentation

int main ( int  argc,
char **  argv 
)

Definition at line 57 of file electronScattering.cc.

References G4UImanager::ApplyCommand(), G4UImanager::GetUIpointer(), G4VisManager::Initialize(), G4UIExecutive::SessionStart(), G4VSteppingVerbose::SetInstance(), CLHEP::HepRandom::setTheEngine(), G4RunManager::SetUserAction(), and G4RunManager::SetUserInitialization().

57  {
58 
59  //choose the Random engine
61 
62  //my Verbose output class
64 
65  // Construct the default run manager
66  G4RunManager * runManager = new G4RunManager;
67 
68  // set mandatory initialization classes
69  DetectorConstruction* detector;
70  detector = new DetectorConstruction;
71  runManager->SetUserInitialization(detector);
72  runManager->SetUserInitialization(new PhysicsList());
73 
74  // set user action classes
75  //
76  //primaryGenerator
77  PrimaryGeneratorAction* primary = new PrimaryGeneratorAction(detector);
78  runManager->SetUserAction(primary);
79 
80  //runAction
81  RunAction* runaction = new RunAction(detector,primary);
82  runManager->SetUserAction(runaction);
83 
84  //eventAction
85  EventAction* eventaction = new EventAction();
86  runManager->SetUserAction(eventaction);
87 
88  //trackAction
89  TrackingAction* trackingaction = new TrackingAction(detector,runaction);
90  runManager->SetUserAction(trackingaction);
91 
92  // get the pointer to the User Interface manager
94 
95  if (argc!=1) // batch mode
96  {
97  G4String command = "/control/execute ";
98  G4String fileName = argv[1];
99  UI->ApplyCommand(command+fileName);
100  }
101 
102  else //define visualization and UI terminal for interactive mode
103  {
104 #ifdef G4VIS_USE
105  G4VisManager* visManager = new G4VisExecutive;
106  visManager->Initialize();
107 #endif
108 
109 #ifdef G4UI_USE
110  G4UIExecutive * ui = new G4UIExecutive(argc,argv);
111  ui->SessionStart();
112  delete ui;
113 #endif
114 
115 #ifdef G4VIS_USE
116  delete visManager;
117 #endif
118  }
119 
120  // job termination
121  //
122  delete runManager;
123 
124  return 0;
125 }
virtual void SetUserInitialization(G4VUserDetectorConstruction *userInit)
static G4UImanager * GetUIpointer()
Definition: G4UImanager.cc:58
void Initialize()
static void SetInstance(G4VSteppingVerbose *Instance)
static void setTheEngine(HepRandomEngine *theNewEngine)
Definition: Random.cc:170
G4int ApplyCommand(const char *aCommand)
Definition: G4UImanager.cc:419
virtual void SetUserAction(G4UserRunAction *userAction)