Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4GEMChannel Class Reference

#include <G4GEMChannel.hh>

+ Inheritance diagram for G4GEMChannel:

Public Member Functions

 G4GEMChannel (G4int theA, G4int theZ, const G4String &aName, G4GEMProbability *aEmissionStrategy)
 
virtual ~G4GEMChannel ()
 
virtual G4double GetEmissionProbability (G4Fragment *theNucleus)
 
virtual G4FragmentEmittedFragment (G4Fragment *theNucleus)
 
virtual void Dump () const
 
void SetLevelDensityParameter (G4VLevelDensityParameter *aLevelDensity)
 
- Public Member Functions inherited from G4VEvaporationChannel
 G4VEvaporationChannel (const G4String &aName="")
 
virtual ~G4VEvaporationChannel ()=default
 
virtual void Initialise ()
 
virtual G4double GetLifeTime (G4Fragment *theNucleus)
 
virtual G4bool BreakUpChain (G4FragmentVector *theResult, G4Fragment *theNucleus)
 
G4FragmentVectorBreakUpFragment (G4Fragment *theNucleus)
 
virtual G4double ComputeInverseXSection (G4Fragment *theNucleus, G4double kinEnergy)
 
virtual G4double ComputeProbability (G4Fragment *theNucleus, G4double kinEnergy)
 
virtual void SetICM (G4bool)
 
virtual void RDMForced (G4bool)
 
void SetOPTxs (G4int)
 
void UseSICB (G4bool)
 
 G4VEvaporationChannel (const G4VEvaporationChannel &right)=delete
 
const G4VEvaporationChanneloperator= (const G4VEvaporationChannel &right)=delete
 
G4bool operator== (const G4VEvaporationChannel &right) const =delete
 
G4bool operator!= (const G4VEvaporationChannel &right) const =delete
 

Additional Inherited Members

- Protected Attributes inherited from G4VEvaporationChannel
G4int OPTxs {3}
 
G4bool useSICB {true}
 

Detailed Description

Definition at line 47 of file G4GEMChannel.hh.

Constructor & Destructor Documentation

◆ G4GEMChannel()

G4GEMChannel::G4GEMChannel ( G4int theA,
G4int theZ,
const G4String & aName,
G4GEMProbability * aEmissionStrategy )
explicit

Definition at line 49 of file G4GEMChannel.cc.

50 :
52 A(theA),
53 Z(theZ),
54 EmissionProbability(0.0),
55 MaximalKineticEnergy(-CLHEP::GeV),
56 theEvaporationProbabilityPtr(aEmissionStrategy),
57 secID(-1)
58{
59 theCoulombBarrierPtr = new G4GEMCoulombBarrier(theA, theZ);
60 theEvaporationProbabilityPtr->SetCoulomBarrier(theCoulombBarrierPtr);
61 theLevelDensityPtr = new G4EvaporationLevelDensityParameter;
62 MyOwnLevelDensity = true;
63 EvaporatedMass = G4NucleiProperties::GetNuclearMass(A, Z);
64 ResidualMass = CoulombBarrier = 0.0;
65 fG4pow = G4Pow::GetInstance();
66 ResidualZ = ResidualA = 0;
68 secID = G4PhysicsModelCatalog::GetModelID("model_G4GEMChannel");
69}
static G4NuclearLevelData * GetInstance()
static G4double GetNuclearMass(const G4double A, const G4double Z)
static G4int GetModelID(const G4int modelIndex)
static G4Pow * GetInstance()
Definition G4Pow.cc:41
G4VEvaporationChannel(const G4String &aName="")

Referenced by G4AlphaGEMChannel::G4AlphaGEMChannel(), G4B10GEMChannel::G4B10GEMChannel(), G4B11GEMChannel::G4B11GEMChannel(), G4B12GEMChannel::G4B12GEMChannel(), G4B13GEMChannel::G4B13GEMChannel(), G4B8GEMChannel::G4B8GEMChannel(), G4Be10GEMChannel::G4Be10GEMChannel(), G4Be11GEMChannel::G4Be11GEMChannel(), G4Be12GEMChannel::G4Be12GEMChannel(), G4Be7GEMChannel::G4Be7GEMChannel(), G4Be9GEMChannel::G4Be9GEMChannel(), G4C10GEMChannel::G4C10GEMChannel(), G4C11GEMChannel::G4C11GEMChannel(), G4C12GEMChannel::G4C12GEMChannel(), G4C13GEMChannel::G4C13GEMChannel(), G4C14GEMChannel::G4C14GEMChannel(), G4C15GEMChannel::G4C15GEMChannel(), G4C16GEMChannel::G4C16GEMChannel(), G4DeuteronGEMChannel::G4DeuteronGEMChannel(), G4F17GEMChannel::G4F17GEMChannel(), G4F18GEMChannel::G4F18GEMChannel(), G4F19GEMChannel::G4F19GEMChannel(), G4F20GEMChannel::G4F20GEMChannel(), G4F21GEMChannel::G4F21GEMChannel(), G4He3GEMChannel::G4He3GEMChannel(), G4He6GEMChannel::G4He6GEMChannel(), G4He8GEMChannel::G4He8GEMChannel(), G4Li6GEMChannel::G4Li6GEMChannel(), G4Li7GEMChannel::G4Li7GEMChannel(), G4Li8GEMChannel::G4Li8GEMChannel(), G4Li9GEMChannel::G4Li9GEMChannel(), G4Mg22GEMChannel::G4Mg22GEMChannel(), G4Mg23GEMChannel::G4Mg23GEMChannel(), G4Mg24GEMChannel::G4Mg24GEMChannel(), G4Mg25GEMChannel::G4Mg25GEMChannel(), G4Mg26GEMChannel::G4Mg26GEMChannel(), G4Mg27GEMChannel::G4Mg27GEMChannel(), G4Mg28GEMChannel::G4Mg28GEMChannel(), G4N12GEMChannel::G4N12GEMChannel(), G4N13GEMChannel::G4N13GEMChannel(), G4N14GEMChannel::G4N14GEMChannel(), G4N15GEMChannel::G4N15GEMChannel(), G4N16GEMChannel::G4N16GEMChannel(), G4N17GEMChannel::G4N17GEMChannel(), G4Na21GEMChannel::G4Na21GEMChannel(), G4Na22GEMChannel::G4Na22GEMChannel(), G4Na23GEMChannel::G4Na23GEMChannel(), G4Na24GEMChannel::G4Na24GEMChannel(), G4Na25GEMChannel::G4Na25GEMChannel(), G4Ne18GEMChannel::G4Ne18GEMChannel(), G4Ne19GEMChannel::G4Ne19GEMChannel(), G4Ne20GEMChannel::G4Ne20GEMChannel(), G4Ne21GEMChannel::G4Ne21GEMChannel(), G4Ne22GEMChannel::G4Ne22GEMChannel(), G4Ne23GEMChannel::G4Ne23GEMChannel(), G4Ne24GEMChannel::G4Ne24GEMChannel(), G4NeutronGEMChannel::G4NeutronGEMChannel(), G4O14GEMChannel::G4O14GEMChannel(), G4O15GEMChannel::G4O15GEMChannel(), G4O16GEMChannel::G4O16GEMChannel(), G4O17GEMChannel::G4O17GEMChannel(), G4O18GEMChannel::G4O18GEMChannel(), G4O19GEMChannel::G4O19GEMChannel(), G4O20GEMChannel::G4O20GEMChannel(), G4ProtonGEMChannel::G4ProtonGEMChannel(), and G4TritonGEMChannel::G4TritonGEMChannel().

◆ ~G4GEMChannel()

G4GEMChannel::~G4GEMChannel ( )
virtual

Definition at line 71 of file G4GEMChannel.cc.

72{
73 if (MyOwnLevelDensity) { delete theLevelDensityPtr; }
74 delete theCoulombBarrierPtr;
75}

Member Function Documentation

◆ Dump()

void G4GEMChannel::Dump ( ) const
virtual

Reimplemented from G4VEvaporationChannel.

Definition at line 254 of file G4GEMChannel.cc.

255{
256 theEvaporationProbabilityPtr->Dump();
257}

◆ EmittedFragment()

G4Fragment * G4GEMChannel::EmittedFragment ( G4Fragment * theNucleus)
virtual

Reimplemented from G4VEvaporationChannel.

Definition at line 130 of file G4GEMChannel.cc.

131{
132 G4Fragment* evFragment = 0;
133 G4double evEnergy = SampleKineticEnergy(*theNucleus) + EvaporatedMass;
134
135 G4ThreeVector momentum = G4RandomDirection()*
136 std::sqrt((evEnergy - EvaporatedMass)*(evEnergy + EvaporatedMass));
137
138 G4LorentzVector EvaporatedMomentum(momentum, evEnergy);
139 G4LorentzVector ResidualMomentum = theNucleus->GetMomentum();
140 EvaporatedMomentum.boost(ResidualMomentum.boostVector());
141
142 evFragment = new G4Fragment(A, Z, EvaporatedMomentum);
143 if ( evFragment != nullptr ) { evFragment->SetCreatorModelID(secID); }
144 ResidualMomentum -= EvaporatedMomentum;
145 theNucleus->SetZandA_asInt(ResidualZ, ResidualA);
146 theNucleus->SetMomentum(ResidualMomentum);
147 theNucleus->SetCreatorModelID(secID);
148
149 return evFragment;
150}
CLHEP::HepLorentzVector G4LorentzVector
G4ThreeVector G4RandomDirection()
CLHEP::Hep3Vector G4ThreeVector
double G4double
Definition G4Types.hh:83
Hep3Vector boostVector() const
HepLorentzVector & boost(double, double, double)
void SetZandA_asInt(G4int Znew, G4int Anew, G4int Lnew=0)
const G4LorentzVector & GetMomentum() const
void SetCreatorModelID(G4int value)
void SetMomentum(const G4LorentzVector &value)

◆ GetEmissionProbability()

G4double G4GEMChannel::GetEmissionProbability ( G4Fragment * theNucleus)
virtual

Implements G4VEvaporationChannel.

Definition at line 77 of file G4GEMChannel.cc.

78{
79 G4int anA = fragment->GetA_asInt();
80 G4int aZ = fragment->GetZ_asInt();
81 ResidualA = anA - A;
82 ResidualZ = aZ - Z;
83 /*
84 G4cout << "G4GEMChannel: Z= " << Z << " A= " << A
85 << " FragmentZ= " << aZ << " FragmentA= " << anA
86 << " Zres= " << ResidualZ << " Ares= " << ResidualA
87 << G4endl;
88 */
89 // We only take into account channels which are physically allowed
90 EmissionProbability = 0.0;
91
92 // Only channels which are physically allowed are taken into account
93 if (ResidualA >= ResidualZ && ResidualZ >= 0 && ResidualA >= A) {
94
95 //Effective excitation energy
96 G4double ExEnergy = fragment->GetExcitationEnergy()
97 - fNucData->GetPairingCorrection(aZ, anA);
98 if(ExEnergy > 0.0) {
99 ResidualMass = G4NucleiProperties::GetNuclearMass(ResidualA, ResidualZ);
100 G4double FragmentMass = fragment->GetGroundStateMass();
101 G4double Etot = FragmentMass + ExEnergy;
102 // Coulomb Barrier calculation
103 CoulombBarrier =
104 theCoulombBarrierPtr->GetCoulombBarrier(ResidualA,ResidualZ,ExEnergy);
105 /*
106 G4cout << "Eexc(MeV)= " << ExEnergy/MeV
107 << " CoulBarrier(MeV)= " << CoulombBarrier/MeV << G4endl;
108 */
109 if(Etot > ResidualMass + EvaporatedMass + CoulombBarrier) {
110
111 // Maximal Kinetic Energy
112 MaximalKineticEnergy = ((Etot-ResidualMass)*(Etot+ResidualMass)
113 + EvaporatedMass*EvaporatedMass)/(2.0*Etot)
114 - EvaporatedMass - CoulombBarrier;
115
116 //G4cout << "CBarrier(MeV)= " << CoulombBarrier/MeV << G4endl;
117
118 if (MaximalKineticEnergy > 0.0) {
119 // Total emission probability for this channel
120 EmissionProbability = theEvaporationProbabilityPtr->
121 EmissionProbability(*fragment, MaximalKineticEnergy);
122 }
123 }
124 }
125 }
126 //G4cout << "Prob= " << EmissionProbability << G4endl;
127 return EmissionProbability;
128}
int G4int
Definition G4Types.hh:85

◆ SetLevelDensityParameter()

void G4GEMChannel::SetLevelDensityParameter ( G4VLevelDensityParameter * aLevelDensity)
inline

Definition at line 63 of file G4GEMChannel.hh.

64 {
65 if (MyOwnLevelDensity) { delete theLevelDensityPtr; }
66 theLevelDensityPtr = aLevelDensity;
67 MyOwnLevelDensity = false;
68 }

The documentation for this class was generated from the following files: