Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4DynamicParticleMSC.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//
27// -------------------------------------------------------------------
28//
29// GEANT4 Class file
30//
31//
32// File name: G4DynamicParticleMSC
33//
34// Author: Vladimir Ivanchenko
35//
36// Creation date: 17.08.2024
37//
38// -------------------------------------------------------------------
39//
40//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
41//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
42
45#include "G4SystemOfUnits.hh"
46#include "G4EmProcessSubType.hh"
47#include "G4LossTableManager.hh"
48#include "G4Step.hh"
49#include "G4Track.hh"
50#include "G4Log.hh"
51#include "G4Exp.hh"
52
53namespace
54{
55 constexpr G4double c_highland = 13.6*CLHEP::MeV;
56}
57
58//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
59
68
69//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
70
72{
73 lManager->DeRegister(this);
74}
75
76//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
77
78void G4DynamicParticleMSC::PreStepInitialisation(const G4Track& track)
79{
80 fMaterial = track.GetMaterial();
81 fZeff = fMaterial->GetIonisation()->GetZeffective();
82 auto dpart = track.GetDynamicParticle();
83 fEkinPreStep = dpart->GetKineticEnergy();
84 fBeta = dpart->GetBeta();
85 fCharge = dpart->GetCharge()/CLHEP::eplus;
86 fMass = std::max(dpart->GetMass(), CLHEP::electron_mass_c2);
87}
88
89//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
90
92 const G4Track& track, G4double, G4double, G4double&,
93 G4GPILSelection* selection)
94{
95 *selection = CandidateForSelection;
96 PreStepInitialisation(track);
97
98 // no step limit for the time being
99 return DBL_MAX;
100}
101
102//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
103
111
112//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
113
115 const G4Step& step)
116{
117 fParticleChange.InitialiseMSC(track, step);
118
119 // no energy loss
120 if (fCharge == 0.0) { return &fParticleChange; }
121
122 G4double geomLength = step.GetStepLength();
123 G4double y = geomLength/fMaterial->GetRadlen();
124 G4double theta0 = c_highland*std::abs(fCharge)*std::sqrt(y)*
125 (1.0 + 0.038*G4Log(y*fCharge*fCharge/(fBeta*fBeta)))/fBeta;
126
127 if (theta0 < 0.001) { return &fParticleChange; }
128 G4double cost = 1.0;
130 if (theta0 < 1.0) {
131 G4double theta2 = theta0*theta0;
132 cost -= theta2*G4Log(1.0 + r*(G4Exp(2.0/theta2) - 1.0));
133 } else {
134 cost -= 2.0*r;
135 }
136 G4double phi = CLHEP::twopi*G4UniformRand();
137 G4double sint = std::sqrt((1.0 - cost)*(1.0 + cost));
138 fNewDir.set(sint*std::cos(phi), sint*std::sin(phi), cost);
139 fNewDir.rotateUz(step.GetPostStepPoint()->GetMomentumDirection());
140
141 fParticleChange.ProposeMomentumDirection(fNewDir);
142 fParticleChange.ProposeTrueStepLength(geomLength);
143 return &fParticleChange;
144}
145
146//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
147
154
155//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
156
158 G4double previousStepSize,
159 G4double currentMinimalStep,
160 G4double& currentSafety)
161{
163 G4double x = AlongStepGetPhysicalInteractionLength(track, previousStepSize,
164 currentMinimalStep,
165 currentSafety, &selection);
166 return x;
167}
168
169//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
170
171void G4DynamicParticleMSC::ProcessDescription(std::ostream& out) const
172{
173 out << "G4DynamicParticleMSC: no delta rays" << G4endl;
174}
175
176//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
@ fDynamicMultipleScattering
G4double condition(const G4ErrorSymMatrix &m)
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
Definition G4Exp.hh:180
G4ForceCondition
@ NotForced
@ Forced
G4GPILSelection
@ CandidateForSelection
@ NotCandidateForSelection
G4double G4Log(G4double x)
Definition G4Log.hh:227
double G4double
Definition G4Types.hh:83
#define G4endl
Definition G4ios.hh:67
#define G4UniformRand()
Definition Randomize.hh:52
void ProcessDescription(std::ostream &) const override
G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double previousStepSize, G4double currentMinimumStep, G4double &currentSafety, G4GPILSelection *selection) override
G4double GetMeanFreePath(const G4Track &, G4double, G4ForceCondition *condition) override
G4double PostStepGetPhysicalInteractionLength(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) override
G4double GetContinuousStepLimit(const G4Track &track, G4double previousStepSize, G4double currentMinimalStep, G4double &currentSafety) override
G4VParticleChange * AlongStepDoIt(const G4Track &, const G4Step &) override
G4double GetZeffective() const
static G4LossTableManager * Instance()
G4IonisParamMat * GetIonisation() const
const G4ThreeVector & GetMomentumDirection() const
G4double GetStepLength() const
G4StepPoint * GetPostStepPoint() const
G4Material * GetMaterial() const
const G4DynamicParticle * GetDynamicParticle() const
G4VContinuousDiscreteProcess(const G4String &, G4ProcessType aType=fNotDefined)
void SetVerboseLevel(G4int value)
void SetProcessSubType(G4int)
#define DBL_MAX
Definition templates.hh:62