G4-ExampleB0/main.cpp

38 lines
1.1 KiB
C++
Raw Normal View History

#include "ActionInitialization.h"
#include "DetectorConstruction.h"
2022-04-28 20:18:48 +08:00
#include "G4MTRunManager.hh"
2022-04-29 13:57:31 +08:00
#include "G4ScoringManager.hh"
2022-04-28 20:18:48 +08:00
#include "G4UIExecutive.hh"
2022-04-29 13:57:31 +08:00
#include "G4UImanager.hh"
2022-04-28 20:18:48 +08:00
#include "G4VisExecutive.hh"
#include "PrimaryGeneratorAction.h"
#include "QBBC.hh"
2022-04-29 13:57:31 +08:00
2022-04-28 20:18:48 +08:00
int main(int argc, char** argv) {
G4UIExecutive* ui = nullptr;
2022-04-29 13:57:31 +08:00
if (argc == 1) ui = new G4UIExecutive(argc, argv);
2022-04-28 20:18:48 +08:00
G4MTRunManager* runManager = new G4MTRunManager;
G4VisExecutive* visManager = new G4VisExecutive;
G4UImanager* UIManager = G4UImanager::GetUIpointer();
G4ScoringManager::GetScoringManager();
2022-04-28 20:18:48 +08:00
runManager->SetUserInitialization(new DetectorConstruction());
runManager->SetUserInitialization(new QBBC);
runManager->SetUserInitialization(new ActionInitialization());
2022-04-28 20:18:48 +08:00
visManager->Initialize();
2022-04-29 13:57:31 +08:00
if (!ui) {
G4String command = "/control/execute ";
2022-04-28 20:18:48 +08:00
G4String fileName = argv[1];
UIManager->ApplyCommand(command + fileName);
} else {
UIManager->ApplyCommand("/control/execute vis.mac");
ui->SessionStart();
delete ui;
}
delete runManager;
delete visManager;
return 0;
}