Loading...
Searching...
No Matches
Par03RunAction.cc
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26#include "Par03RunAction.hh"
28
29#include "G4AnalysisManager.hh"
30
33 , fDetector(aDetector)
34{
35 // Create analysis manager
36 G4AnalysisManager* analysisManager = G4AnalysisManager::Instance();
37 analysisManager->SetDefaultFileType("root");
38
39 // Default filename, can be overriden with /analysis/setFileName
40 analysisManager->SetFileName("Par03Output");
41}
42
43//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
44
46
47//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
48
50{
51 // Get detector dimensions
52 G4int cellNumZ = fDetector->GetNbOfLayers();
53 G4int cellNumRho = fDetector->GetNbOfRhoCells();
54 G4double cellSizeZ = fDetector->GetLength() / cellNumZ;
55 G4double cellSizeRho = fDetector->GetRadius() / cellNumRho;
56 // Default max value of energy stored in histogram (in GeV)
57 G4double maxEnergy = 100;
58
59 // Get analysis manager
60 auto analysisManager = G4AnalysisManager::Instance();
61
62 // Creating control histograms
63 analysisManager->CreateH1("energyParticle",
64 "Primary energy;E_{MC} (GeV);Entries", 256, 0,
65 1.1 * maxEnergy);
66 analysisManager->CreateH1("energyDeposited",
67 "Deposited energy;E_{MC} (GeV);Entries", 256, 0,
68 1.1 * maxEnergy);
69 analysisManager->CreateH1(
70 "energyRatio",
71 "Ratio of energy deposited to primary;E_{dep} / E_{MC};Entries", 1024, 0,
72 1);
73 analysisManager->CreateH1("time", "Simulation time; time (s);Entries", 2048,
74 0, 30);
75 analysisManager->CreateH1(
76 "longProfile", "Longitudinal profile;t (mm);#LTE#GT (MeV)", cellNumZ,
77 -0.5 * cellSizeZ, (cellNumZ - 0.5) * cellSizeZ);
78 analysisManager->CreateH1(
79 "transProfile", "Transverse profile;r (mm);#LTE#GT (MeV)", cellNumRho,
80 -0.5 * cellSizeRho, (cellNumRho - 0.5) * cellSizeRho);
81 analysisManager->CreateH1(
82 "longFirstMoment",
83 "First moment of longitudinal distribution;#LT#lambda#GT (mm);Entries",
84 1024, -0.5 * cellSizeZ,
85 cellNumZ * cellSizeZ / 2); // arbitrary scaling of max value on axis
86 analysisManager->CreateH1("transFirstMoment",
87 "First moment of transverse distribution;#LTr#GT "
88 "(mm);Entries",
89 1024, -0.5 * cellSizeRho,
90 cellNumRho * cellSizeRho /
91 10); // arbitrary scaling of max value on axis
92 analysisManager->CreateH1(
93 "longSecondMoment",
94 "Second moment of longitudinal distribution;#LT#lambda^{2}#GT "
95 "(mm^{2});Entries",
96 1024, 0,
97 std::pow(cellNumZ * cellSizeZ, 2) /
98 25); // arbitrary scaling of max value on axis
99 analysisManager->CreateH1(
100 "transSecondMoment",
101 "Second moment of transverse distribution;#LTr^{2}#GT (mm^{2});Entries",
102 1024, 0,
103 std::pow(cellNumRho * cellSizeRho, 2) /
104 25); // arbitrary scaling of max value on axis
105 analysisManager->CreateH1(
106 "hitType", "hit type;type (0=full, 1= fast);Entries", 2, -0.5, 1.5);
107
108 // Open an output file
109 analysisManager->OpenFile();
110}
111
112//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
113
115{
116 auto analysisManager = G4AnalysisManager::Instance();
117 analysisManager->Write();
118 analysisManager->CloseFile();
119 analysisManager->Clear();
120}
Par03DetectorConstruction * fDetector
Pointer to detector construction to retrieve the detector dimensions to setup the histograms.
virtual ~Par03RunAction()
virtual void BeginOfRunAction(const G4Run *) final
Open the file for the analysis.
virtual void EndOfRunAction(const G4Run *) final
Write and close the file.
Par03RunAction(Par03DetectorConstruction *aDetector)
Constructor. Defines the histograms.

Applications | User Support | Publications | Collaboration