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

#include <G4PhysicsModelCatalog.hh>

Public Member Functions

 ~G4PhysicsModelCatalog ()=default
 
 G4PhysicsModelCatalog (const G4PhysicsModelCatalog &)=delete
 
G4PhysicsModelCatalogoperator= (const G4PhysicsModelCatalog &)=delete
 

Static Public Member Functions

static void Initialize ()
 
static const G4String GetModelNameFromID (const G4int modelID)
 
static const G4String GetModelNameFromIndex (const G4int modelIndex)
 
static G4int GetModelID (const G4int modelIndex)
 
static G4int GetModelID (const G4String &modelName)
 
static G4int GetModelIndex (const G4int modelID)
 
static G4int GetModelIndex (const G4String &modelName)
 
static G4int Entries ()
 
static void PrintAllInformation ()
 
static G4int GetMinAllowedModelIDValue ()
 
static G4int GetMaxAllowedModelIDValue ()
 

Detailed Description

Definition at line 45 of file G4PhysicsModelCatalog.hh.

Constructor & Destructor Documentation

◆ ~G4PhysicsModelCatalog()

G4PhysicsModelCatalog::~G4PhysicsModelCatalog ( )
default

◆ G4PhysicsModelCatalog()

G4PhysicsModelCatalog::G4PhysicsModelCatalog ( const G4PhysicsModelCatalog & )
delete

Referenced by G4PhysicsModelCatalog(), and operator=().

Member Function Documentation

◆ Entries()

G4int G4PhysicsModelCatalog::Entries ( )
static

Definition at line 743 of file G4PhysicsModelCatalog.cc.

743 {
744 // It is enough to check the size of one of the two vectors, because they have the same size.
745 return ( theVectorOfModelIDs != nullptr ) ? G4int( theVectorOfModelIDs->size() ) : -1;
746}
int G4int
Definition G4Types.hh:85

Referenced by GetModelID(), GetModelID(), GetModelIndex(), GetModelIndex(), GetModelNameFromID(), GetModelNameFromIndex(), and PrintAllInformation().

◆ GetMaxAllowedModelIDValue()

G4int G4PhysicsModelCatalog::GetMaxAllowedModelIDValue ( )
inlinestatic

Definition at line 109 of file G4PhysicsModelCatalog.hh.

109 {
110 return theMaxAllowedModelIDValue;
111}

Referenced by GetModelIndex(), and GetModelNameFromID().

◆ GetMinAllowedModelIDValue()

G4int G4PhysicsModelCatalog::GetMinAllowedModelIDValue ( )
inlinestatic

Definition at line 105 of file G4PhysicsModelCatalog.hh.

105 {
106 return theMinAllowedModelIDValue;
107}

Referenced by GetModelIndex(), and GetModelNameFromID().

◆ GetModelID() [1/2]

G4int G4PhysicsModelCatalog::GetModelID ( const G4int modelIndex)
static

Definition at line 695 of file G4PhysicsModelCatalog.cc.

695 {
696 return ( modelIndex >= 0 && modelIndex < Entries() )
697 ? (*theVectorOfModelIDs)[ modelIndex ] : -1;
698}

Referenced by G4NeutronRadCaptureHP::BuildPhysicsTable(), G4VRadioactiveDecay::DecayAnalog(), G4AblaInterface::G4AblaInterface(), G4BinaryCascade::G4BinaryCascade(), G4BinaryLightIonReaction::G4BinaryLightIonReaction(), G4CascadeInterface::G4CascadeInterface(), G4Cerenkov::G4Cerenkov(), G4ChargeExchange::G4ChargeExchange(), G4CompetitiveFission::G4CompetitiveFission(), G4CRCoalescence::G4CRCoalescence(), G4ElectroVDNuclearModel::G4ElectroVDNuclearModel(), G4EMDissociation::G4EMDissociation(), G4EMDissociation::G4EMDissociation(), G4eplusAnnihilation::G4eplusAnnihilation(), G4EvaporationChannel::G4EvaporationChannel(), G4FermiBreakUpVI::G4FermiBreakUpVI(), G4FissionLibrary::G4FissionLibrary(), G4ForwardXrayTR::G4ForwardXrayTR(), G4GEMChannel::G4GEMChannel(), G4GEMChannelVI::G4GEMChannelVI(), G4GeneratorPrecompoundInterface::G4GeneratorPrecompoundInterface(), G4HadronElastic::G4HadronElastic(), G4INCLXXInterface::G4INCLXXInterface(), G4LEHadronProtonElastic::G4LEHadronProtonElastic(), G4LENDModel::G4LENDModel(), G4LENDorBERTModel::G4LENDorBERTModel(), G4LEnp::G4LEnp(), G4LEpp::G4LEpp(), G4LFission::G4LFission(), G4LightIonQMDReaction::G4LightIonQMDReaction(), G4LivermorePolarizedComptonModel::G4LivermorePolarizedComptonModel(), G4LMsdGenerator::G4LMsdGenerator(), G4LowEGammaNuclearModel::G4LowEGammaNuclearModel(), G4LowEIonFragmentation::G4LowEIonFragmentation(), G4MuonVDNuclearModel::G4MuonVDNuclearModel(), G4NeutrinoElectronCcModel::G4NeutrinoElectronCcModel(), G4NeutrinoElectronNcModel::G4NeutrinoElectronNcModel(), G4NeutrinoNucleusModel::G4NeutrinoNucleusModel(), G4NeutronElectronElModel::G4NeutronElectronElModel(), G4NeutronHPCaptureFS::G4NeutronHPCaptureFS(), G4ParticleHP2AInelasticFS::G4ParticleHP2AInelasticFS(), G4ParticleHP2N2AInelasticFS::G4ParticleHP2N2AInelasticFS(), G4ParticleHP2NAInelasticFS::G4ParticleHP2NAInelasticFS(), G4ParticleHP2NDInelasticFS::G4ParticleHP2NDInelasticFS(), G4ParticleHP2NInelasticFS::G4ParticleHP2NInelasticFS(), G4ParticleHP2NPInelasticFS::G4ParticleHP2NPInelasticFS(), G4ParticleHP2PInelasticFS::G4ParticleHP2PInelasticFS(), G4ParticleHP3AInelasticFS::G4ParticleHP3AInelasticFS(), G4ParticleHP3NAInelasticFS::G4ParticleHP3NAInelasticFS(), G4ParticleHP3NInelasticFS::G4ParticleHP3NInelasticFS(), G4ParticleHP3NPInelasticFS::G4ParticleHP3NPInelasticFS(), G4ParticleHP4NInelasticFS::G4ParticleHP4NInelasticFS(), G4ParticleHPAInelasticFS::G4ParticleHPAInelasticFS(), G4ParticleHPD2AInelasticFS::G4ParticleHPD2AInelasticFS(), G4ParticleHPDAInelasticFS::G4ParticleHPDAInelasticFS(), G4ParticleHPDInelasticFS::G4ParticleHPDInelasticFS(), G4ParticleHPElasticFS::G4ParticleHPElasticFS(), G4ParticleHPFissionFS::G4ParticleHPFissionFS(), G4ParticleHPHe3InelasticFS::G4ParticleHPHe3InelasticFS(), G4ParticleHPN2AInelasticFS::G4ParticleHPN2AInelasticFS(), G4ParticleHPN2PInelasticFS::G4ParticleHPN2PInelasticFS(), G4ParticleHPN3AInelasticFS::G4ParticleHPN3AInelasticFS(), G4ParticleHPNAInelasticFS::G4ParticleHPNAInelasticFS(), G4ParticleHPND2AInelasticFS::G4ParticleHPND2AInelasticFS(), G4ParticleHPNDInelasticFS::G4ParticleHPNDInelasticFS(), G4ParticleHPNHe3InelasticFS::G4ParticleHPNHe3InelasticFS(), G4ParticleHPNInelasticFS::G4ParticleHPNInelasticFS(), G4ParticleHPNPAInelasticFS::G4ParticleHPNPAInelasticFS(), G4ParticleHPNPInelasticFS::G4ParticleHPNPInelasticFS(), G4ParticleHPNT2AInelasticFS::G4ParticleHPNT2AInelasticFS(), G4ParticleHPNTInelasticFS::G4ParticleHPNTInelasticFS(), G4ParticleHPNXInelasticFS::G4ParticleHPNXInelasticFS(), G4ParticleHPPAInelasticFS::G4ParticleHPPAInelasticFS(), G4ParticleHPPDInelasticFS::G4ParticleHPPDInelasticFS(), G4ParticleHPPInelasticFS::G4ParticleHPPInelasticFS(), G4ParticleHPPTInelasticFS::G4ParticleHPPTInelasticFS(), G4ParticleHPT2AInelasticFS::G4ParticleHPT2AInelasticFS(), G4ParticleHPTInelasticFS::G4ParticleHPTInelasticFS(), G4PhotonEvaporation::G4PhotonEvaporation(), G4PreCompoundEmission::G4PreCompoundEmission(), G4PreCompoundModel::G4PreCompoundModel(), G4QMDReaction::G4QMDReaction(), G4QuasiElasticChannel::G4QuasiElasticChannel(), G4Scintillation::G4Scintillation(), G4StatMF::G4StatMF(), G4SynchrotronRadiation::G4SynchrotronRadiation(), G4SynchrotronRadiationInMat::G4SynchrotronRadiationInMat(), G4TheoFSGenerator::G4TheoFSGenerator(), G4UnstableFragmentBreakUp::G4UnstableFragmentBreakUp(), G4VXTRenergyLoss::G4VXTRenergyLoss(), G4WilsonAblationModel::G4WilsonAblationModel(), G4WilsonAbrasionModel::G4WilsonAbrasionModel(), G4WilsonAbrasionModel::G4WilsonAbrasionModel(), G4NeutronFissionVI::InitialiseModel(), G4NeutronRadCapture::InitialiseModel(), G4NuDEXNeutronCaptureModel::InitialiseModel(), G4HadronElasticProcess::PostStepDoIt(), G4HadronStoppingProcess::PreparePhysicsTable(), and G4Track::RemoveAuxiliaryTrackInformation().

◆ GetModelID() [2/2]

G4int G4PhysicsModelCatalog::GetModelID ( const G4String & modelName)
static

Definition at line 701 of file G4PhysicsModelCatalog.cc.

701 {
702 if(!isInitialized)
703 {
704 Initialize();
705 }
706 G4int modelID = -1;
707 for ( G4int idx = 0; idx < Entries(); ++idx ) {
708 if ( (*theVectorOfModelNames)[ idx ] == modelName ) {
709 modelID = (*theVectorOfModelIDs)[ idx ];
710 break;
711 }
712 }
713 return modelID;
714}

◆ GetModelIndex() [1/2]

G4int G4PhysicsModelCatalog::GetModelIndex ( const G4int modelID)
static

Definition at line 717 of file G4PhysicsModelCatalog.cc.

717 {
718 G4int modelIndex = -1;
719 if ( modelID >= GetMinAllowedModelIDValue() && modelID <= GetMaxAllowedModelIDValue() ) {
720 for ( G4int idx = 0; idx < Entries(); ++idx ) {
721 if ( (*theVectorOfModelIDs)[ idx ] == modelID ) {
722 modelIndex = idx;
723 break;
724 }
725 }
726 }
727 return modelIndex;
728}
static G4int GetMaxAllowedModelIDValue()
static G4int GetMinAllowedModelIDValue()

Referenced by G4Track::SetAuxiliaryTrackInformation().

◆ GetModelIndex() [2/2]

G4int G4PhysicsModelCatalog::GetModelIndex ( const G4String & modelName)
static

Definition at line 731 of file G4PhysicsModelCatalog.cc.

731 {
732 G4int modelIndex = -1;
733 for ( G4int idx = 0; idx < Entries(); ++idx ) {
734 if ( (*theVectorOfModelNames)[ idx ] == modelName ) {
735 modelIndex = idx;
736 break;
737 }
738 }
739 return modelIndex;
740}

◆ GetModelNameFromID()

const G4String G4PhysicsModelCatalog::GetModelNameFromID ( const G4int modelID)
static

Definition at line 675 of file G4PhysicsModelCatalog.cc.

675 {
676 G4String modelName = "Undefined";
677 if ( modelID >= GetMinAllowedModelIDValue() && modelID <= GetMaxAllowedModelIDValue() ) {
678 for ( int idx = 0; idx < Entries(); ++idx ) {
679 if ( (*theVectorOfModelIDs)[ idx ] == modelID ) {
680 modelName = (*theVectorOfModelNames)[ idx ];
681 break;
682 }
683 }
684 }
685 return modelName;
686}

Referenced by G4ClonedRichTrajectory::CreateAttValues(), and G4RichTrajectory::CreateAttValues().

◆ GetModelNameFromIndex()

const G4String G4PhysicsModelCatalog::GetModelNameFromIndex ( const G4int modelIndex)
static

Definition at line 689 of file G4PhysicsModelCatalog.cc.

689 {
690 return ( modelIndex >= 0 && modelIndex < Entries() )
691 ? (*theVectorOfModelNames)[ modelIndex ] : G4String("Undefined");
692}

◆ Initialize()

void G4PhysicsModelCatalog::Initialize ( )
static

Definition at line 41 of file G4PhysicsModelCatalog.cc.

41 {
42 if(isInitialized)
43 {
44 return;
45 }
46 if ( theVectorOfModelIDs == nullptr && theVectorOfModelNames == nullptr ) {
47 static std::vector< G4int > aVectorOfInts;
48 theVectorOfModelIDs = &aVectorOfInts;
49 static std::vector< G4String > aVectorOfStrings;
50 theVectorOfModelNames = &aVectorOfStrings;
51
52 // NOTE:
53 // The goal is that, starting from Geant4 version 11.0, all the three
54 // identifiers (modelID, index, name) remain the same regardless of the
55 // physics list, application, and version of Geant4.
56 // Therefore, after Geant4 11.0, you can only add an entry - e.g. when
57 // a new model is added, or when a pre-existing model not yet present
58 // in this catalogue is included - at the bottom of this method
59 // (rather than inserting it in the middle), and do NOT delete anything.
60 //
61 // For the modelID values, these are the considerations and choices made:
62 // - Values below 1000 are excluded because reserved to process and
63 // sub-process ID values.
64 // - Whenever resonable, modelID values should have free spaces between
65 // them, to allow for eventual, future variants - e.g. different
66 // tunings of the same model - to keep modelID values close to the
67 // original model.
68 // - modelID values are between 10'000 and 39'999, with the following
69 // subdivision in 3 categories (identified by the most significant
70 // digit):
71 // * Values between 10'000 and 19'999 are for EM models
72 // * Values between 20'000 and 29'999 are for HAD models
73 // * Values between 30'000 and 39'999 are for all the other models
74 // (i.e. included neither in EM models nor in HAD models).
75 // Note that larger values of modelID are neither more difficult to
76 // handle nor less computing performant with respect to smaller values
77 // (we remind that, for plotting, the index of the model, rather than
78 // its modelID, should be conveniently used, whereas for all the rest
79 // the modelID is recommended).
80
81 // =======================================================================
82 // ================= 1st EM MODELS : from 10'000 to 19'999 ===============
83 // =======================================================================
84
85 InsertModel( 10000, "model_EM" );
86
87 // e- production
88 InsertModel( 10010, "model_DeltaElectron" );
89 InsertModel( 10011, "model_DeltaEBelowCut" );
90 InsertModel( 10012, "model_PhotoElectron" );
91 InsertModel( 10013, "model_ComptonElectron" );
92 InsertModel( 10014, "model_TripletElectron" );
93
94 // gamma production
95 InsertModel( 10020, "model_Bremsstrahlung" );
96 InsertModel( 10021, "model_SplitBremsstrahlung" );
97 InsertModel( 10022, "model_ComptonGamma" );
98 InsertModel( 10023, "model_Annihilation" );
99 InsertModel( 10024, "model_TripletGamma" );
100 InsertModel( 10025, "model_GammaGammaEntanglement" );
101
102 // e+e- pair production
103 InsertModel( 10030, "model_EplusEminisPair" );
104
105 // atomic de-excitation
106 InsertModel( 10040, "model_Fluorescence" );
107 InsertModel( 10041, "model_gammaPIXE" );
108 InsertModel( 10050, "model_AugerElectron" );
109 InsertModel( 10051, "model_ePIXE" );
110
111 // recoil ions
112 InsertModel( 10060, "model_IonRecoil" );
113
114 // DNA models
115 InsertModel( 11000, "model_DNA" );
116 InsertModel( 11001, "model_Ritchie1994eSolvation" );
117 InsertModel( 11002, "model_Terrisol1990eSolvation" );
118 InsertModel( 11003, "model_Meesungnoen2002eSolvation" );
119 InsertModel( 11004, "model_Kreipl2009eSolvation" );
120 InsertModel( 11005, "model_MeesungnoenSolid2002eSolvation" );
121
122 // =======================================================================
123 // ============= 2nd HADRONIC MODELS : from 20'000 to 29'999 =============
124 // =======================================================================
125
126 // ----------------------------------------------------------
127 // --- Gamma- , Lepto- , Neutrino-nuclear : 20'000-20'999 ---
128 // ----------------------------------------------------------
129 // - 20'000 - 20'099 : Electromagnetic dissociation models
130 // - 20'100 - 20'199 : Gamma-nuclear models
131 // - 20'200 - 20-299 : Electron/positron-nuclear models
132 // - 20'300 - 20'399 : Muon-nuclear models
133 // - 20'400 - 20'499 : Tau-nuclear models
134 // - 20'500 - 20'999 : Neutrino models...
135 // ...
136
137 // --- EM dissociation models: 20'000 - 20'099 ---
138
139 // Class G4EMDissociation
140 InsertModel( 20000, "model_projectileEMDissociation" );
141 InsertModel( 20001, "model_targetEMDissociation" );
142
143 // --- Gamma-nuclear models: 20'100 - 20'199 ---
144
145 // Class G4LENDorBERTModel
146 InsertModel( 20100, "model_LENDorBERTModel" );
147
148 // Class G4LowEGammaNuclearModel
149 InsertModel( 20150, "model_GammaNPreco" );
150
151 // --- Charged-lepton - nuclear models: 20'200 - 20'499 ---
152
153 // Class G4ElectroVDNuclearModel
154 InsertModel( 20200, "model_G4ElectroVDNuclearModel" );
155
156 // Class G4MuonVDNuclearModel
157 InsertModel( 20300, "model_G4MuonVDNuclearModel" );
158
159 // --- Neutrino models: 20'500 - 20'999 ---
160
161 // Class G4NeutrinoElectronCcModel
162 InsertModel( 20510, "model_nu-e-inelastic" );
163
164 // Class G4NeutrinoNucleusModel
165 InsertModel( 20520, "model_neutrino-nucleus" );
166
167 // The following classes derives from G4NeutrinoNucleusModel
168 // Class G4ANuElNucleusCcModel
169 InsertModel( 20530, "model_ANuElNuclCcModel" );
170 // Class G4ANuElNucleusNcModel
171 InsertModel( 20540, "model_ANuElNuclNcModel" );
172 // Class G4ANuMuNucleusCcModel
173 InsertModel( 20550, "model_ANuMuNuclCcModel" );
174 // Class G4ANuMuNucleusNcModel
175 InsertModel( 20560, "model_ANuMuNuclNcModel" );
176 // Class G4NuElNucleusCcModel
177 InsertModel( 20570, "model_NuElNuclCcModel" );
178 // Class G4NuElNucleusNcModel
179 InsertModel( 20580, "model_NuElNuclNcModel" );
180 // Class G4NuMuNucleusCcModel
181 InsertModel( 20590, "model_NuMuNuclCcModel" );
182 // Class G4NuMuNucleusNcModel
183 InsertModel( 20600, "model_NuMuNuclNcModel" );
184
185 // ------------------------------------------------------------------------------------------
186 // --- Elastic, Charge-Exchange, Quasi-Elastic, specialized Diffraction : 21'000 - 21'999 ---
187 // ------------------------------------------------------------------------------------------
188 // - 21'000 - 21'199 : Elastic
189 // - 21'200 - 21'299 : Charge-Exchange
190 // - 21'300 - 21'499 : Quasi-Elastic
191 // - 21'500 - 21'999 : specialized Diffraction generators
192 // -----------------------------------------------------------
193
194 // --- Elastic models: 21'000 - 21'199 ---
195
196 // Class G4HadronElastic
197 InsertModel( 21000, "model_hElasticLHEP" );
198 // Class G4AntiNuclElastic
199 InsertModel( 21010, "model_AntiAElastic" );
200 // Class G4ChipsElasticModel
201 InsertModel( 21020, "model_hElasticCHIPS" );
202 // Class G4DiffuseElastic
203 InsertModel( 21030, "model_DiffuseElastic" );
204 // Class G4DiffuseElasticV2
205 InsertModel( 21040, "model_DiffuseElasticV2" );
206 // Class G4NuclNuclDiffuseElastic
207 InsertModel( 21050, "model_NNDiffuseElastic" );
208 // Class G4ElasticHadrNucleusHE
209 InsertModel( 21060, "model_hElasticGlauber" );
210 // Class G4hhElastic
211 InsertModel( 21070, "model_HadrHadrElastic" );
212 // Class G4LowEHadronElastic
213 InsertModel( 21080, "model_hLowEElastic" );
214 // Class G4LEHadronProtonElastic
215 InsertModel( 21090, "model_G4LEHadronProtonElastic" );
216 // Class G4LEnp
217 InsertModel( 21100, "model_G4LEnp" );
218 // Class G4LEpp
219 InsertModel( 21110, "model_G4LEpp" );
220 // Class G4NeutronElectronElModel
221 InsertModel( 21120, "model_n-e-elastic" );
222 // Class G4NeutrinoElectronNcModel
223 InsertModel( 21130, "model_nu-e-elastic" );
224
225 // --- Charge exchange : 21'200 - 21'299 ---
226
227 // Class: G4ChargeExchange
228 InsertModel( 21200, "model_ChargeExchange" );
229
230 // --- Quasi-Elastic : 21'300 - 21'499 ---
231
232 // Class: G4QuasiElasticChannel (which uses Chips's model G4QuasiElRatios)
233 InsertModel( 21300, "model_QuasiElastic" );
234
235 // --- Special diffraction generators : 21'500 - 21'999 ---
236
237 // Class: G4LMsdGenerator
238 InsertModel( 21500, "model_LMsdGenerator" );
239
240 // -----------------------------------------------------------------
241 // --- High energy-models (e.g. string models) : 22'000 - 22'999 ---
242 // -----------------------------------------------------------------
243 // - 22'000 - 22'099 : G4TheoFSGenerator
244 // - 22'100 - 22'199 : FTF
245 // - 22'200 - 22'299 : QGS
246 // - ...
247 // For gamma - nuclear : QGS string formation + QGS string fragmentation + Precompound
248 // For e-/e+/mu-/mu+ - nuclear : FTF string formation + Lund string fragmentation + Precompound
249 InsertModel( 22000, "model_TheoFSGenerator" );
250 // FTF string formation + Lund string fragmentation + Precompound
251 InsertModel( 22100, "model_FTFP" );
252 // FTF string formation + Lund string fragmentation + Binary Cascade
253 InsertModel( 22150, "model_FTFB" );
254 // FTF string formation + QGS string fragmentation + Precompound
255 InsertModel( 22175, "model_FTFQGSP" );
256 // QGS string formation + QGS string fragmentation + Precompound
257 InsertModel( 22200, "model_QGSP" );
258 // QGS string formation + QGS string fragmentation + Binary Cascade
259 InsertModel( 22250, "model_QGSB" );
260
261 // ----------------------------------------------------
262 // --- Intermediate energy models : 23'000 - 23'999 ---
263 // ----------------------------------------------------
264 // - 23'000 - 23'099 : BERT
265 // - 23'100 - 23'199 : BIC
266 // - 23'200 - 23'299 : INCL
267 // - 23'300 - 23'399 : QMD
268 // ...
269 // Class: G4CascadeInterface
270 InsertModel( 23000, "model_BertiniCascade" );
271
272 // The names are similar, but not identical, to those before Geant4 11.
273 // Class: G4BinaryCascade
274 InsertModel( 23100, "model_G4BinaryCascade" );
275 // Class: G4BinaryLightIonReaction
276 InsertModel( 23110, "model_G4BinaryLightIonReaction" );
277
278 // Class: G4INCLXXInterface
279 InsertModel( 23200, "model_INCLXXCascade" );
280
281 // Class: G4QMDReaction
282 InsertModel( 23300, "model_QMDModel" );
283
284 // --------------------------------------------------------------
285 // --- Pre-equilibrium/De-excitation models : 24'000 - 24'999 ---
286 // --------------------------------------------------------------
287 // - Pre-equilibrium : 24'000 - 24'099
288 // * 24'000 - 24'049 : precompound
289 // * 24'050 - 24'099 : internal BERT pre-equilibrium
290 // - de-excitation : 24'100 - 24'999
291 // * 24'100 - 24'149 : Evaporation
292 // * 24'150 - 24'199 : Photon evaporation
293 // * 24'200 - 24'299 : GEM evaporation
294 // * 24'300 - 24'349 : Fermi BreakUp
295 // * 24'350 - 24'399 : Multifragmentation
296 // * 24'400 - 24'449 : Ablation
297 // * 24'450 - 24'499 : Fission
298 // * 24'500 - 24'599 : ABLA
299 // * 24'600 - 24'699 : internal BERT de-excitation
300 // ...
301
302 // --- Pre-equilibrium: 24'000 - 24'099 ---
303
304 // Class: G4PreCompoundModel
305 InsertModel( 24000, "model_PRECO" );
306
307 // Class: G4LowEIonFragmentation
308 InsertModel( 24010, "model_LowEIonPreco" );
309
310 // Class: G4NonEquilibriumEvaporator (i.e. BERT pre-equilibrium)
311 InsertModel( 24050, "model_G4NonEquilibriumEvaporator" );
312
313 // --- De-excitation: 24'100 - 24'999 ---
314
315 // --- Evaporation: 24'100- 24'149 ---
316
317 // Class: G4EvaporationChannel
318 InsertModel( 24100, "model_G4EvaporationChannel" );
319
320 // Class: G4UnstableFragmentBreakUp
321 InsertModel( 24120, "model_G4UnstableFragmentBreakUp" );
322
323 // --- Photon-Evaporation: 24'150 - 24'199 ---
324
325 // Class: G4PhotonEvaporation
326 InsertModel( 24150, "model_G4PhotonEvaporation" );
327
328 // Class: G4NeutronRadCapture
329 InsertModel( 24160, "model_nRadCapture" );
330
331 // --- GEM evaporation : 24'200 - 24'299 ---
332
333 // Class: G4GEMChannel
334 InsertModel( 24200, "model_G4GEMChannel" );
335
336 // Class: G4GEMChannelVI
337 InsertModel( 24210, "model_G4GEMChannelVI" );
338
339 // --- Fermi BreakUp : 24'300 - 24'349 ---
340
341 // Class: G4FermiBreakUpVI
342 InsertModel( 24300, "model_G4FermiBreakUpVI" );
343
344 // --- Multifragmentation : 24'350 - 24'399 ---
345
346 // Class: G4StatMF
347 InsertModel( 24350, "model_G4StatMF" );
348
349 // --- Ablation : 24'400 - 24'449 ---
350
351 // Class: G4WilsonAblationModel
352 InsertModel( 24400, "model_G4WilsonAblationModel" );
353
354 // --- Fission : 24'450 - 24'499 ---
355
356 // Class: G4CompetitiveFission
357 InsertModel( 24450, "model_G4CompetitiveFission" );
358
359 // --- ABLA : 24'500 - 24'599 ---
360
361 // Class: G4AblaInterface
362 InsertModel( 24500, "model_ABLA" );
363
364 // --- internal BERT de-excitation : 24'600 - 24'699 ---
365
366 // Class: G4EquilibriumEvaporator
367 InsertModel( 24600, "model_G4EquilibriumEvaporator" );
368
369 // --- Other types of de-excitation : 24'700 - 24'999 ---
370
371 // ...
372
373 // ------------------------------------------------
374 // --- Low-energy data-driven : 25'000 - 25'999 ---
375 // ------------------------------------------------
376 // - 25'000 - 25'199 : ParticleHP
377 // - 25'200 - 25'299 : LEND
378 // ...
379 // - 25'500 - 25'999 : RadioactiveDecay
380
381 // --- ParticleHP : 25'000 - 25'199 ---
382
383 // Classes: G4ParticleHPCapture , G4ParticleHPCaptureFS
384 InsertModel( 25000, "model_NeutronHPCapture" );
385
386 // Classes: G4ParticleHPElastic , G4ParticleHPElasticFS
387 InsertModel( 25010, "model_NeutronHPElastic" );
388
389 // Classes: G4ParticleHPFission , G4ParticleHPFissionFS , G4WendtFissionFragmentGenerator
390 InsertModel( 25020, "model_NeutronHPFission" );
391
392 // Inelastic: the following classes inherit from either G4ParticleHPInelasticBaseFS or
393 // G4ParticleHPInelasticCompFS, which in turn inherit from G4ParticleHPFinalState
394
395 // Class G4ParticleHPNInelasticFS
396 InsertModel( 25030, "model_G4ParticleHPNInelasticFS_F01" );
397 // Class model_G4ParticleHPNXInelasticFS
398 InsertModel( 25031, "model_G4ParticleHPNXInelasticFS_F02" );
399 // Class G4ParticleHP2NDInelasticFS
400 InsertModel( 25032, "model_G4ParticleHP2NDInelasticFS_F03" );
401 // Class G4ParticleHP2NInelasticFS
402 InsertModel( 25033, "model_G4ParticleHP2NInelasticFS_F04" );
403 // Class G4ParticleHP3NInelasticFS
404 InsertModel( 25034, "model_G4ParticleHP3NInelasticFS_F05" );
405 // Class G4ParticleHPNAInelasticFS
406 InsertModel( 25035, "model_G4ParticleHPNAInelasticFS_F06" );
407 // Class G4ParticleHPN3AInelasticFS
408 InsertModel( 25036, "model_G4ParticleHPN3AInelasticFS_F07" );
409 // Class G4ParticleHP2NAInelasticFS
410 InsertModel( 25037, "model_G4ParticleHP2NAInelasticFS_F08" );
411 // Class G4ParticleHP3NAInelasticFS
412 InsertModel( 25038, "model_G4ParticleHP3NAInelasticFS_F09" );
413 // Class G4ParticleHPNPInelasticFS
414 InsertModel( 25039, "model_G4ParticleHPNPInelasticFS_F10" );
415 // Class G4ParticleHPN2AInelasticFS
416 InsertModel( 25040, "model_G4ParticleHPN2AInelasticFS_F11" );
417 // Clas G4ParticleHP2N2AInelasticFS
418 InsertModel( 25041, "model_G4ParticleHP2N2AInelasticFS_F12" );
419 // Class G4ParticleHPNDInelasticFS
420 InsertModel( 25042, "model_G4ParticleHPNDInelasticFS_F13" );
421 // Class G4ParticleHPNTInelasticFS
422 InsertModel( 25043, "model_G4ParticleHPNTInelasticFS_F14" );
423 // Class G4ParticleHPNHe3InelasticFS
424 InsertModel( 25044, "model_G4ParticleHPNHe3InelasticFS_F15" );
425 // Class G4ParticleHPND2AInelasticFS
426 InsertModel( 25045, "model_G4ParticleHPND2AInelasticFS_F16" );
427 // Class G4ParticleHPNT2AInelasticFS
428 InsertModel( 25046, "model_G4ParticleHPNT2AInelasticFS_F17" );
429 // Class G4ParticleHP4NInelasticFS
430 InsertModel( 25047, "model_G4ParticleHP4NInelasticFS_F18" );
431 // Class G4ParticleHP2NPInelasticFS
432 InsertModel( 25048, "model_G4ParticleHP2NPInelasticFS_F19" );
433 // Class G4ParticleHP3NPInelasticFS
434 InsertModel( 25049, "model_G4ParticleHP3NPInelasticFS_F20" );
435 // Class G4ParticleHPN2PInelasticFS
436 InsertModel( 25050, "model_G4ParticleHPN2PInelasticFS_F21" );
437 // Class G4ParticleHPNPAInelasticFS
438 InsertModel( 25051, "model_G4ParticleHPNPAInelasticFS_F22" );
439 // Class G4ParticleHPPInelasticFS
440 InsertModel( 25052, "model_G4ParticleHPPInelasticFS_F23" );
441 // Class G4ParticleHPDInelasticFS
442 InsertModel( 25053, "model_G4ParticleHPDInelasticFS_F24" );
443 // Class G4ParticleHPTInelasticFS
444 InsertModel( 25054, "model_G4ParticleHPTInelasticFS_F25" );
445 // Class G4ParticleHPHe3InelasticFS
446 InsertModel( 25055, "model_G4ParticleHPHe3InelasticFS_F26" );
447 // Class G4ParticleHPAInelasticFS
448 InsertModel( 25056, "model_G4ParticleHPAInelasticFS_F27" );
449 // Class G4ParticleHP2AInelasticFS
450 InsertModel( 25057, "model_G4ParticleHP2AInelasticFS_F28" );
451 // Class G4ParticleHP3AInelasticFS
452 InsertModel( 25058, "model_G4ParticleHP3AInelasticFS_F29" );
453 // Class G4ParticleHP2PInelasticFS
454 InsertModel( 25059, "model_G4ParticleHP2PInelasticFS_F30" );
455 // Class G4ParticleHPPAInelasticFS
456 InsertModel( 25060, "model_G4ParticleHPPAInelasticFS_F31" );
457 // Class G4ParticleHPD2AInelasticFS
458 InsertModel( 25061, "model_G4ParticleHPD2AInelasticFS_F32" );
459 // Class G4ParticleHPT2AInelasticFS
460 InsertModel( 25062, "model_G4ParticleHPT2AInelasticFS_F33" );
461 // Class G4ParticleHPPDInelasticFS
462 InsertModel( 25063, "model_G4ParticleHPPDInelasticFS_F34" );
463 // Class G4ParticleHPPTInelasticFS
464 InsertModel( 25064, "model_G4ParticleHPPTInelasticFS_F35" );
465 // Class G4ParticleHPDAInelasticFS
466 InsertModel( 25065, "model_G4ParticleHPDAInelasticFS_F36" );
467
468 // --- LEND : 25'200 - 25'299 ---
469
470 // Class: G4LENDModel
471 InsertModel( 25200, "model_LENDModel" );
472
473 // The following classes inherit from G4LENDModel
474
475 // Class: G4LENDCapture
476 InsertModel( 25210, "model_LENDCapture" );
477 // Class: G4LENDElastic
478 InsertModel( 25220, "model_LENDElastic" );
479 // Class: G4LENDFission
480 InsertModel( 25230, "model_LENDFission" );
481 // Class: G4LENDInelastic
482 InsertModel( 25240, "model_LENDInelastic" );
483 // Class: G4LENDCombinedModel
484 InsertModel( 25250, "model_LENDCombinedModel" );
485 // Class: G4LENDGammaModel
486 InsertModel( 25260, "model_LENDGammaModel" );
487
488 // --- Radioactive Decay : 25'500 - 25'999 ---
489
490 // 25'510 + 10*G4RadioactiveDecayMode
491 InsertModel( 25510, "model_RDM_IT" );
492 InsertModel( 25520, "model_RDM_BetaMinus" );
493 InsertModel( 25530, "model_RDM_BetaPlus" );
494 InsertModel( 25540, "model_RDM_KshellEC" );
495 InsertModel( 25550, "model_RDM_LshellEC" );
496 InsertModel( 25560, "model_RDM_MshellEC" );
497 InsertModel( 25570, "model_RDM_NshellEC" );
498 InsertModel( 25580, "model_RDM_Alpha" );
499 InsertModel( 25590, "model_RDM_Proton" );
500 InsertModel( 25600, "model_RDM_Neutron" );
501 InsertModel( 25610, "model_RDM_SpFission" );
502 InsertModel( 25620, "model_RDM_BDProton" );
503 InsertModel( 25630, "model_RDM_BDNeutron" );
504 InsertModel( 25640, "model_RDM_Beta2Minus" );
505 InsertModel( 25650, "model_RDM_Beta2Plus" );
506 InsertModel( 25660, "model_RDM_Proton2" );
507 InsertModel( 25670, "model_RDM_Neutron2" );
508 InsertModel( 25680, "model_RDM_Triton" );
509
510 InsertModel( 25810, "model_RDM_AtomicRelaxation" );
511
512 // -------------------------------------------------------------------
513 // --- Others HAD (everything not include above) : 26'000 - 26'999 ---
514 // -------------------------------------------------------------------
515 // - 26'000 - 26'099 : Stopping
516 // - 26'100 - 26'199 : Fission
517 // - 26'200 - 26'299 : Abration
518 // - 26'300 - 26'399 : Coalescence
519 // ...
520
521 // --- Stopping : 26'000 - 26'099 ---
522
523 // Below are classes that derives from G4HadronStoppingProcess .
524 // The names are the same as before Geant4 11, except for the "model_" prefix.
525 // Classes that use it: G4HadronStoppingProcess .
526
527 // Class: G4HadronicAbsorptionBertini
528 InsertModel( 26000, "model_hBertiniCaptureAtRest_EMCascade" );
529 InsertModel( 26001, "model_hBertiniCaptureAtRest_NuclearCapture" );
530 InsertModel( 26002, "model_hBertiniCaptureAtRest_DIO" );
531 // Class: G4HadronicAbsorptionFritiof
532 InsertModel( 26010, "model_hFritiofCaptureAtRest_EMCascade" );
533 InsertModel( 26011, "model_hFritiofCaptureAtRest_NuclearCapture" );
534 InsertModel( 26012, "model_hFritiofCaptureAtRest_DIO" );
535 // Class: G4HadronicAbsorptionFritiofWithBinaryCascade
536 InsertModel( 26020, "model_hFritiofWithBinaryCascadeCaptureAtRest_EMCascade" );
537 InsertModel( 26021, "model_hFritiofWithBinaryCascadeCaptureAtRest_NuclearCapture" );
538 InsertModel( 26022, "model_hFritiofWithBinaryCascadeCaptureAtRest_DIO" );
539 // Class: G4MuonMinusCapture
540 InsertModel( 26030, "model_muMinusCaptureAtRest_EMCascade" );
541 InsertModel( 26031, "model_muMinusCaptureAtRest_NuclearCapture" );
542 InsertModel( 26032, "model_muMinusCaptureAtRest_DIO" );
543
544 // --- Fission : 26'100 - 26'199 ---
545
546 // Class G4LFission
547 InsertModel( 26100, "model_G4LFission" );
548
549 // LLNL fission (related classes: G4FissionLibrary, G4LLNLFission, G4FissLib, G4fissionEvent)
550 InsertModel( 26110, "model_G4LLNLFission" );
551
552 // --- Abration : 26'200 - 26'299 ---
553
554 // Class G4WilsonAbrasionModel
555 InsertModel( 26200, "model_G4WilsonAbrasion" );
556
557 // --- Coalescence : 26'300 - 26'399 ---
558
559 // Class G4CRCoalescence
560 InsertModel( 26300, "model_G4CRCoalescence" );
561
562 // ==========================================================================
563 // === 3rd OTHER (i.e. non-EM and non-HAD) MODELS : from 30'000 to 39'999 ===
564 // ==========================================================================
565
566 // -------------------------------
567 // --- Biasing : 30'000-30'999 ---
568 // -------------------------------
569
570 // The name is the same as before Geant4 11, except for the "model_" prefix.
571 // Classes that use it: G4BOptrForceCollision
572 InsertModel( 30010, "model_GenBiasForceCollision" );
573
574 // ----------------------------------
575 // --- Channeling : 31'000-31'999 ---
576 // ----------------------------------
577
578 // The name is the same as before Geant4 11, except for the "model_" prefix.
579 // Classes that use it: G4Channeling , G4ChannelingOptrChangeCrossSection
580 InsertModel( 31010, "model_channeling" );
581
582 // --- Others ... ---
583
584 // ======================================================================
585 // ================== 4th MODELS ADDED AFTER Geant4 11.0 ================
586 // ======================================================================
587 // PLEASE ADD MODELS ONLY BELOW HERE, WITH PROPER modelID .
588 // IF YOU ARE NOT SURE, PLEASE CONTACT ONE OF THE COORDINATORS OF THE
589 // GEANT4 PHYSICS WORKING GROUPS.
590
591 // Class: G4HadronicAbsorptionINCLXX
592 InsertModel( 26040, "model_hINCLXXCaptureAtRest_EMCascade" );
593 InsertModel( 26041, "model_hINCLXXCaptureAtRest_NuclearCapture" );
594 InsertModel( 26042, "model_hINCLXXCaptureAtRest_DIO" );
595
596 // Class: G4LightIonQMDReaction
597 InsertModel( 23310, "model_LightIonQMDModel" );
598
599 // Class: G4NuDEXEvaporation (to be added in the future)
600 // InsertModel( 24700, "model_nuDEX_evaporation" );
601
602 // Class: G4NuDEXNeutronCapture
603 InsertModel( 25300, "model_nuDEX_neutronCapture" );
604
605 // ...
606
607 SanityCheck();
608 isInitialized = true;
609
610 // The following call is commented out because it should be protected by
611 // the verbosity level, but this would imply a dependency of the global
612 // category to other categories which is not allowed.
613 // Anyhow, the call G4PhysicsModelCatalog::PrintAllInformation()
614 // can be easily placed elsewhere (in either user code, or even in other
615 // Geant4 classes).
616 //PrintAllInformation();
617 }
618}

Referenced by G4VUserPhysicsList::Construct(), and GetModelID().

◆ operator=()

G4PhysicsModelCatalog & G4PhysicsModelCatalog::operator= ( const G4PhysicsModelCatalog & )
delete

◆ PrintAllInformation()

void G4PhysicsModelCatalog::PrintAllInformation ( )
static

Definition at line 749 of file G4PhysicsModelCatalog.cc.

749 {
750 G4cout << G4endl
751 << " ==================================================== " << G4endl
752 << " === G4PhysicsModelCatalog::PrintAllInformation() === " << G4endl
753 << " ==================================================== " << G4endl
754 << " SIZE (i.e. number of models in the catalog)=" << Entries() << G4endl;
755 for ( int idx = 0; idx < Entries(); ++idx ) {
756 G4int modelID = (*theVectorOfModelIDs)[ idx ];
757 G4String modelName = (*theVectorOfModelNames)[ idx ];
758 G4cout << "\t index=" << idx << "\t modelName=" << modelName
759 << "\t modelID=" << modelID << G4endl;
760 }
761 G4cout << " ==================================================== " << G4endl
762 << " ==================================================== " << G4endl
763 << " ==================================================== " << G4endl
764 << G4endl;
765}
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout

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