File indexing completed on 2025-04-04 08:05:13
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033 #ifndef Run_h
0034 #define Run_h 1
0035
0036 #include "G4Run.hh"
0037 #include "G4VProcess.hh"
0038 #include "globals.hh"
0039
0040 #include <map>
0041
0042 class DetectorConstruction;
0043 class G4ParticleDefinition;
0044 class G4HadronicProcessStore;
0045 class G4Material;
0046 class G4Element;
0047
0048
0049
0050 class Run : public G4Run
0051 {
0052 public:
0053 Run(DetectorConstruction*);
0054 ~Run() override = default;
0055
0056 public:
0057 void SetPrimary(G4ParticleDefinition* particle, G4double energy);
0058 void SetTargetXXX(G4bool);
0059 void CountProcesses(G4VProcess* process);
0060 void SumTrack(G4double);
0061 void CountNuclearChannel(G4String, G4double);
0062 void ParticleCount(G4String, G4double);
0063 void Balance(G4double);
0064 void CountGamma(G4int);
0065
0066 void Merge(const G4Run*) override;
0067 void EndOfRun(G4bool);
0068
0069 private:
0070 void PrintXS(const G4VProcess*, const G4Material*, const G4Element*, G4HadronicProcessStore*,
0071 G4double dens, G4double& sum1, G4double& sum2);
0072
0073 struct ParticleData
0074 {
0075 ParticleData() : fCount(0), fEmean(0.), fEmin(0.), fEmax(0.) {}
0076 ParticleData(G4int count, G4double ekin, G4double emin, G4double emax)
0077 : fCount(count), fEmean(ekin), fEmin(emin), fEmax(emax)
0078 {}
0079 G4int fCount;
0080 G4double fEmean;
0081 G4double fEmin;
0082 G4double fEmax;
0083 };
0084
0085 struct NuclChannel
0086 {
0087 NuclChannel() : fCount(0), fQ(0.) {}
0088 NuclChannel(G4int count, G4double Q) : fCount(count), fQ(Q) {}
0089 G4int fCount;
0090 G4double fQ;
0091 };
0092
0093 private:
0094 DetectorConstruction* fDetector = nullptr;
0095 G4ParticleDefinition* fParticle = nullptr;
0096 G4double fEkin = 0.;
0097
0098 std::map<G4String, G4int> fProcCounter;
0099
0100 G4int fTotalCount = 0;
0101 G4int fGammaCount = 0;
0102 G4double fSumTrack = 0.;
0103 G4double fSumTrack2 = 0.;
0104
0105 std::map<G4String, NuclChannel> fNuclChannelMap;
0106 std::map<G4String, ParticleData> fParticleDataMap;
0107
0108 G4bool fTargetXXX = false;
0109 G4double fPbalance[3];
0110 G4int fNbGamma[3];
0111 };
0112
0113
0114
0115 #endif