56 if(!IsLocked()) { Initialise(); }
59void G4DeexPrecoParameters::Initialise()
63 fLevelDensity = 0.075/CLHEP::MeV;
64 fR0 = 1.5*CLHEP::fermi;
65 fTransitionsR0 = 0.6*CLHEP::fermi;
68 fPrecoLowEnergy = 0.1*CLHEP::MeV;
69 fPrecoHighEnergy = 30*CLHEP::MeV;
77 fUseSoftCutoff =
false;
81 fUseAngularGen =
true;
85 fMinExcitation = 10*CLHEP::eV;
86 fNuclearLevelWidth = 0.2*CLHEP::MeV;
87 fFBUEnergyLimit = 20.0*CLHEP::MeV;
88 fFermiEnergy = 35.0*CLHEP::MeV;
89 fMaxLifeTime = 1*CLHEP::nanosecond;
90 fMinExPerNucleounForMF = 200*CLHEP::GeV;
96 fCorrelatedGamma =
false;
97 fStoreAllLevels =
true;
98 fInternalConversion =
true;
106 if(IsLocked() || val <= 0.0) {
return; }
107 fLevelDensity = val/CLHEP::MeV;
112 if(IsLocked() || val <= 0.0) {
return; }
118 if(IsLocked() || val <= 0.0) {
return; }
119 fTransitionsR0 = val;
124 if(IsLocked() || val <= 0.0) {
return; }
125 fFBUEnergyLimit = val;
130 if(IsLocked() || val <= 0.0) {
return; }
136 if(IsLocked() || val < 0.0) {
return; }
137 fPrecoLowEnergy = val;
142 if(IsLocked() || val < 0.0) {
return; }
143 fPrecoHighEnergy = val;
148 if(IsLocked() || val <= 0.0) {
return; }
154 if(IsLocked() || val < 0.0) {
return; }
155 fMinExcitation = val;
160 if(IsLocked() || val < 0.0) {
return; }
161 fNuclearLevelWidth = val;
166 if(IsLocked() || val < 0.0) {
return; }
172 if(IsLocked() || val < 0.0) {
return; }
173 fMinExPerNucleounForMF = val;
178 if(IsLocked() || n < 2) {
return; }
184 if(IsLocked() || n < 0) {
return; }
190 if(IsLocked() || n < 0 || n > 3) {
return; }
196 if(IsLocked() || n < 0 || n > 3) {
return; }
202 if(IsLocked() || n < 0) {
return; }
208 if(IsLocked()) {
return; }
214 if(IsLocked()) {
return; }
220 if(IsLocked()) {
return; }
221 fUseSoftCutoff = val;
226 if(IsLocked()) {
return; }
232 if(IsLocked()) {
return; }
238 if(IsLocked()) {
return; }
244 if(IsLocked()) {
return; }
245 fUseAngularGen = val;
250 if(IsLocked()) {
return; }
252 fDeexChannelType =
fDummy;
257 if(IsLocked()) {
return; }
258 fCorrelatedGamma = val;
263 if(IsLocked()) {
return; }
264 fStoreAllLevels = val;
274 if(IsLocked()) {
return; }
275 fInternalConversion = val;
280 if(IsLocked()) {
return; }
286 if(IsLocked()) {
return; }
292 if(IsLocked()) {
return; }
298 if(IsLocked()) {
return; }
299 fDeexChannelType = val;
304 static const G4String namm[5] = {
"Evaporation",
"GEM",
"Evaporation+GEM",
"GEMVI",
"Dummy"};
305 static const G4int nmm[5] = {8, 68, 68, 31, 0};
306 G4int idx = fDeexChannelType;
308 G4long prec = os.precision(5);
309 os <<
"=======================================================================" <<
"\n";
310 os <<
"====== Geant4 Native Pre-compound Model Parameters ========" <<
"\n";
311 os <<
"=======================================================================" <<
"\n";
312 os <<
"Type of pre-compound inverse x-section " << fPrecoType <<
"\n";
313 os <<
"Pre-compound model active " << (!fPrecoDummy) <<
"\n";
314 os <<
"Pre-compound excitation low energy "
315 <<
G4BestUnit(fPrecoLowEnergy,
"Energy") <<
"\n";
316 os <<
"Pre-compound excitation high energy "
317 <<
G4BestUnit(fPrecoHighEnergy,
"Energy") <<
"\n";
318 os <<
"Angular generator for pre-compound model " << fUseAngularGen <<
"\n";
319 os <<
"Use NeverGoBack option for pre-compound model " << fNeverGoBack <<
"\n";
320 os <<
"Use SoftCutOff option for pre-compound model " << fUseSoftCutoff <<
"\n";
321 os <<
"Use CEM transitions for pre-compound model " << fUseCEM <<
"\n";
322 os <<
"Use GNASH transitions for pre-compound model " << fUseGNASH <<
"\n";
323 os <<
"Use HETC submodel for pre-compound model " << fUseHETC <<
"\n";
324 os <<
"=======================================================================" <<
"\n";
325 os <<
"====== Nuclear De-excitation Module Parameters ========" <<
"\n";
326 os <<
"=======================================================================" <<
"\n";
327 os <<
"Type of de-excitation inverse x-section " << fDeexType <<
"\n";
328 os <<
"Type of de-excitation factory " << namm[idx] <<
"\n";
329 os <<
"Number of de-excitation channels " << nmm[idx] <<
"\n";
330 os <<
"Min excitation energy "
331 <<
G4BestUnit(fMinExcitation,
"Energy") <<
"\n";
332 os <<
"Min energy per nucleon for multifragmentation "
333 <<
G4BestUnit(fMinExPerNucleounForMF,
"Energy") <<
"\n";
334 os <<
"Limit excitation energy for Fermi BreakUp "
335 <<
G4BestUnit(fFBUEnergyLimit,
"Energy") <<
"\n";
336 os <<
"Level density (1/MeV) "
337 << fLevelDensity*CLHEP::MeV <<
"\n";
338 os <<
"Use simple level density model " << fLD <<
"\n";
339 os <<
"Use discrete excitation energy of the residual " << fFD <<
"\n";
340 os <<
"Time limit for long lived isomeres "
342 os <<
"Isomer production flag " << fIsomerFlag <<
"\n";
343 os <<
"Internal e- conversion flag "
344 << fInternalConversion <<
"\n";
345 os <<
"Store e- internal conversion data " << fStoreAllLevels <<
"\n";
346 os <<
"Correlated gamma emission flag " << fCorrelatedGamma <<
"\n";
347 os <<
"Max 2J for sampling of angular correlations " << fTwoJMAX <<
"\n";
348 os <<
"=======================================================================" <<
G4endl;
356 return (verb > 0) ? std::max(fVerbose, verb) : verb;
372G4bool G4DeexPrecoParameters::IsLocked()
const
std::ostream & operator<<(std::ostream &os, const G4DeexPrecoParameters &par)
G4GLOB_DLL std::ostream G4cout
void SetPrecoDummy(G4bool)
void SetIsomerProduction(G4bool)
void SetMinExPerNucleounForMF(G4double)
void SetCorrelatedGamma(G4bool)
void SetDeexModelType(G4int)
void SetLevelDensity(G4double)
void SetTransitionsR0(G4double)
void SetMaxLifeTime(G4double)
void SetStoreICLevelData(G4bool)
void SetMinAForPreco(G4int)
void SetNeverGoBack(G4bool)
void SetMinZForPreco(G4int)
std::ostream & StreamInfo(std::ostream &os) const
void SetPhenoFactor(G4double)
void SetPrecoLowEnergy(G4double)
void SetStoreAllLevels(G4bool)
void SetUseAngularGen(G4bool)
void SetNuclearLevelWidth(G4double)
void SetPrecoModelType(G4int)
void SetFermiEnergy(G4double)
void SetUseSoftCutoff(G4bool)
void SetDiscreteExcitationFlag(G4bool)
void SetLevelDensityFlag(G4bool)
void SetMinExcitation(G4double)
void SetFBUEnergyLimit(G4double)
void SetInternalConversionFlag(G4bool)
void SetDeexChannelsType(G4DeexChannelType)
void SetPrecoHighEnergy(G4double)
static G4HadronicParameters * Instance()
G4int GetVerboseLevel() const
const G4ApplicationState & GetCurrentState() const
static G4StateManager * GetStateManager()