File indexing completed on 2025-04-04 08:05:19
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
0034 #ifndef SteppingAction_H
0035 #define SteppingAction_H 1
0036
0037 #include "CLHEP/Units/SystemOfUnits.h"
0038
0039 #include "G4ThreeVector.hh"
0040 #include "G4UserSteppingAction.hh"
0041 #include "globals.hh"
0042
0043 class Run;
0044
0045
0046
0047 class SteppingAction : public G4UserSteppingAction
0048 {
0049 public:
0050 SteppingAction();
0051 virtual ~SteppingAction();
0052
0053
0054
0055
0056
0057
0058
0059 virtual void UserSteppingAction(const G4Step*) override;
0060
0061
0062
0063
0064
0065
0066 void Initialize();
0067
0068
0069
0070
0071
0072 void SetRunPointer(Run* inputValue = nullptr) { fRunPtr = inputValue; }
0073
0074 private:
0075 G4bool IsPreassignedDecayEnabled() const { return fIsPreassignedDecayEnabled; }
0076 G4bool IsBoostToLabEnabled() const { return fIsBoostToLabEnabled; }
0077 G4double ToleranceEPviolations() const { return fToleranceEPviolations; }
0078 G4double ToleranceDeltaDecayRadius() const { return fToleranceDeltaDecayRadius; }
0079
0080
0081
0082
0083
0084
0085
0086
0087
0088
0089 const G4bool fIsPreassignedDecayEnabled = true;
0090 const G4bool fIsBoostToLabEnabled = true;
0091
0092
0093 G4double fToleranceEPviolations;
0094
0095
0096
0097 const G4double fToleranceDeltaDecayRadius = 1.0 * CLHEP::micrometer;
0098
0099 Run* fRunPtr;
0100
0101
0102 G4int fPrimaryParticleId;
0103 G4double fPrimaryParticleInitialKineticEnergy;
0104 G4double fPrimaryParticleInitialTotalEnergy;
0105 G4double fPrimaryParticleInitialMomentum;
0106 G4double fPrimaryParticleInitialBeta;
0107 G4double fPrimaryParticleInitialGamma;
0108 G4ThreeVector fPrimaryParticleInitial3Momentum;
0109 G4ThreeVector fPrimaryParticleInitialPosition;
0110
0111
0112
0113 G4double fMaxEkin_deltaMax;
0114 G4double fMaxEtot_deltaMax;
0115 G4double fMaxP_deltaMax;
0116 G4double fMaxPdir_deltaMax;
0117 G4double fMaxMass_deltaMax1;
0118 G4double fMaxMass_deltaMax2;
0119 G4double fMaxMass_deltaMax3;
0120 G4double fMeanMass_deltaMax3;
0121 G4double fMaxBeta_deltaMax1;
0122 G4double fMaxBeta_deltaMax2;
0123 G4double fMaxGamma_deltaMax1;
0124 G4double fMaxGamma_deltaMax2;
0125 G4double fMaxGamma_deltaMax3;
0126 G4double fMaxT_proper_deltaMax;
0127 G4double fMaxT_lab_deltaMax;
0128 G4double fMaxMc_truth_rPos_deltaMax;
0129 G4double fMeanMc_truth_rPos_deltaMax;
0130
0131
0132 G4double fMeanDeltaR_primaryDecay;
0133 G4double fMinDeltaR_primaryDecay;
0134 G4double fMaxDeltaR_primaryDecay;
0135 G4double fMeanR_primaryDecay;
0136 G4double fMinR_primaryDecay;
0137 G4double fMaxR_primaryDecay;
0138 G4double fMeanX_primaryDecay;
0139 G4double fMinX_primaryDecay;
0140 G4double fMaxX_primaryDecay;
0141 G4double fMeanY_primaryDecay;
0142 G4double fMinY_primaryDecay;
0143 G4double fMaxY_primaryDecay;
0144 G4double fMeanZ_primaryDecay;
0145 G4double fMinZ_primaryDecay;
0146 G4double fMaxZ_primaryDecay;
0147 G4double fMeanDeltaAngle_primaryDecay;
0148 G4double fMinDeltaAngle_primaryDecay;
0149 G4double fMaxDeltaAngle_primaryDecay;
0150 G4double fMeanDeltaEkin_primaryDecay;
0151 G4double fMinDeltaEkin_primaryDecay;
0152 G4double fMaxDeltaEkin_primaryDecay;
0153 G4double fMeanEkin_primaryDecay;
0154 G4double fMinEkin_primaryDecay;
0155 G4double fMaxEkin_primaryDecay;
0156 G4double fMeanPx_primaryDecay;
0157 G4double fMinPx_primaryDecay;
0158 G4double fMaxPx_primaryDecay;
0159 G4double fMeanPy_primaryDecay;
0160 G4double fMinPy_primaryDecay;
0161 G4double fMaxPy_primaryDecay;
0162 G4double fMeanPz_primaryDecay;
0163 G4double fMinPz_primaryDecay;
0164 G4double fMaxPz_primaryDecay;
0165
0166
0167
0168 G4double fMinUnderestimated_mc_truth_rPos_delta;
0169 G4double fMaxOverestimated_mc_truth_rPos_delta;
0170 G4double fMeanUnderestimated_mc_truth_rPos_delta;
0171 G4double fMeanOverestimated_mc_truth_rPos_delta;
0172 G4double fMinUnderestimated_rDeltaPos;
0173 G4double fMaxOverestimated_rDeltaPos;
0174 G4double fMeanUnderestimated_rDeltaPos;
0175 G4double fMeanOverestimated_rDeltaPos;
0176
0177
0178 G4double fMaxFloat_rDeltaPos_deltaMax;
0179
0180
0181
0182 G4double fMeanViolationE_primaryDecay;
0183 G4double fMinViolationE_primaryDecay;
0184 G4double fMaxViolationE_primaryDecay;
0185 G4double fMeanViolationPx_primaryDecay;
0186 G4double fMinViolationPx_primaryDecay;
0187 G4double fMaxViolationPx_primaryDecay;
0188 G4double fMeanViolationPy_primaryDecay;
0189 G4double fMinViolationPy_primaryDecay;
0190 G4double fMaxViolationPy_primaryDecay;
0191 G4double fMeanViolationPz_primaryDecay;
0192 G4double fMinViolationPz_primaryDecay;
0193 G4double fMaxViolationPz_primaryDecay;
0194 };
0195
0196
0197
0198 #endif