Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VEmissionProbability.hh
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// Hadronic Process: Nuclear De-excitations
27// by V. Lara (Oct 1998)
28//
29// Modif (03 September 2008) by J. M. Quesada for external choice of inverse
30// cross section option
31// JMQ (06 September 2008) Also external choices have been added for
32// superimposed Coulomb barrier (if useSICB is set true, by default is false)
33//
34// V.Ivanchenko general clean-up since 2010
35//
36
37#ifndef G4VEmissionProbability_h
38#define G4VEmissionProbability_h 1
39
40#include "globals.hh"
41#include "G4Fragment.hh"
42
44class G4Pow;
45
47{
48public:
49
51
52 virtual ~G4VEmissionProbability() = default;
53
54 void Initialise();
55
56 virtual G4double EmissionProbability(const G4Fragment & fragment,
57 G4double anEnergy);
58
59 virtual G4double ComputeProbability(G4double anEnergy, G4double CB);
60
61 inline G4int GetZ(void) const { return theZ; }
62
63 inline G4int GetA(void) const { return theA; }
64
65 // Z, A, rmass are residual parameters
66 // fmass is SCM mass of decaying nucleus
67 // exc is an excitation of emitted fragment
68 inline void SetDecayKinematics(G4int rZ, G4int rA, G4double rmass,
69 G4double fmass);
70
71 inline G4double GetRecoilExcitation() const { return fExcRes; };
72
73 inline void SetEvapExcitation(G4double exc) { fExc = exc; };
74
75 inline G4double GetProbability() const { return pProbability; };
76
77 inline void ResetProbability() { pProbability = 0.0; };
78
79 // this method may be called only if the probability is computed
80 // for given initial fragment and decay channel
82
84 const G4VEmissionProbability & operator=
85 (const G4VEmissionProbability &right) = delete;
86 G4bool operator==(const G4VEmissionProbability &right) const = delete;
87 G4bool operator!=(const G4VEmissionProbability &right) const = delete;
88
89protected:
90
91 void ResetIntegrator(size_t nbin, G4double de, G4double eps);
92
94
97
104
105 G4double pMass = 0.0; // initial fragment
110
111private:
112
113 G4double FindRecoilExcitation(const G4double e);
114
115 G4double fExc = 0.0;
116 G4double fExcRes = 0.0;
117
118 G4double fE1 = 0.0;
119 G4double fE2 = 0.0;
120 G4double fP2 = 0.0;
121
122 G4double emin = 0.0;
123 G4double emax = 0.0;
124 G4double eCoulomb = 0.0;
125 G4double accuracy = 0.005;
126 G4double probmax = 0.0;
127 G4double elimit;
128
129 G4bool fFD = false;
130};
131
132inline void
134 G4double fmass)
135{
136 resZ = rZ;
137 resA = rA;
138 pMass = fmass;
139 pResMass = rmass;
140}
141
142#endif
double G4double
Definition: G4Types.hh:83
bool G4bool
Definition: G4Types.hh:86
int G4int
Definition: G4Types.hh:85
const G4int Z[17]
const G4double A[17]
Definition: G4Pow.hh:49
void SetEvapExcitation(G4double exc)
void ResetIntegrator(size_t nbin, G4double de, G4double eps)
G4double IntegrateProbability(G4double elow, G4double ehigh, G4double CB)
G4bool operator==(const G4VEmissionProbability &right) const =delete
G4VEmissionProbability(const G4VEmissionProbability &right)=delete
G4double GetRecoilExcitation() const
virtual G4double ComputeProbability(G4double anEnergy, G4double CB)
virtual G4double EmissionProbability(const G4Fragment &fragment, G4double anEnergy)
virtual ~G4VEmissionProbability()=default
G4bool operator!=(const G4VEmissionProbability &right) const =delete
void SetDecayKinematics(G4int rZ, G4int rA, G4double rmass, G4double fmass)
G4NuclearLevelData * pNuclearLevelData