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

#include <G4NuDEXStatisticalNucleus.hh>

Public Member Functions

 G4NuDEXStatisticalNucleus (G4int Z, G4int A)
 
 ~G4NuDEXStatisticalNucleus ()
 
G4int Init (const char *dirname, const char *inputfname=0)
 
G4int GenerateCascade (G4int InitialLevel, G4double ExcitationEnergy, std::vector< char > &pType, std::vector< double > &pEnergy, std::vector< double > &pTime)
 
G4int GetClosestLevel (G4double Energy, G4int spinx2, G4bool parity)
 
G4double GetLevelEnergy (G4int i_level)
 
void GetSnAndI0 (G4double &sn, G4double &i0)
 
LevelGetLevel (G4int i_level)
 
void ChangeLevelSpinParityAndBR (G4int i_level, G4int newspinx2, G4bool newParity, G4int nlevels, G4double width, unsigned int seed=0)
 
void ChangeThermalCaptureLevelBR (G4double LevelEnergy, G4double absoluteIntensity)
 
void SetSomeInitalParameters (G4int LDtype=-1, G4int PSFFlag=-1, G4double MaxSpin=-1, G4int minlevelsperband=-1, G4double BandWidth_MeV=0, G4double maxExcEnergy=0, G4int BrOption=-1, G4int sampleGammaWidths=-1, unsigned int aseed1=0, unsigned int aseed2=0, unsigned int aseed3=0)
 
void SetInitialParameters02 (G4int knownLevelsFlag=-1, G4int electronConversionFlag=-1, G4double primGamNormFactor=-1, G4double primGamEcut=-1, G4double ecrit=-1)
 
void SetBandWidth (G4double bandWidth)
 
void SetBrOption (G4int BrOption)
 
void SetRandom1Seed (unsigned int seed)
 
void SetRandom2Seed (unsigned int seed)
 
void SetRandom3Seed (unsigned int seed)
 
G4NuDEXRandomGetRandom3 ()
 
G4bool HasBeenInitialized ()
 
void PrintAll (std::ostream &out)
 
void PrintParameters (std::ostream &out)
 
void PrintKnownLevels (std::ostream &out)
 
void PrintLevelDensity (std::ostream &out)
 
void PrintLevelScheme (std::ostream &out)
 
void PrintThermalPrimaryTransitions (std::ostream &out)
 
void PrintPSF (std::ostream &out)
 
void PrintICC (std::ostream &out)
 
void PrintTotalCumulBR (G4int i_level, std::ostream &out)
 
void PrintBR (G4int i_level, G4double MaxExcEneToPrint_MeV, std::ostream &out)
 
void PrintInput01 (std::ostream &out)
 
void PrintKnownLevelsInDEGENformat (std::ostream &out)
 
void PrintLevelSchemeInDEGENformat (const char *fname, G4int MaxLevelID=-1)
 

Detailed Description

Definition at line 100 of file G4NuDEXStatisticalNucleus.hh.

Constructor & Destructor Documentation

◆ G4NuDEXStatisticalNucleus()

G4NuDEXStatisticalNucleus::G4NuDEXStatisticalNucleus ( G4int Z,
G4int A )

Definition at line 50 of file G4NuDEXStatisticalNucleus.cc.

50 {
51
52 //The default values for these flags are in "GeneralStatNuclParameters.dat"
53 //Can be changed with G4NuDEXStatisticalNucleus::SetSomeInitalParameters(...)
54 LevelDensityType=-1;
55 PSFflag=-1;
56 maxspinx2=-1;
57 MinLevelsPerBand=-1;
58 BandWidth=0;
59 MaxExcEnergy=0;
60 BROpt=-1;
61 SampleGammaWidths=-1;
62
63 //The default values for these flags are in G4NuDEXStatisticalNucleus::Init(...)
64 //Can be changed via G4NuDEXStatisticalNucleus::SetInitialParameters02(...):
65 ElectronConversionFlag=-1; // All EC
66 KnownLevelsFlag=-1; //Use all known levels
67 PrimaryGammasIntensityNormFactor=-1;
68 PrimaryGammasEcut=-1; //If primary gammas, do not create new primary gammas going to the "Primary gammas" region.
69 Ecrit=-1;
70
71 hasBeenInitialized=false;
72 NBands=-1;
73 theLevels=0;
74 theKnownLevels=0;
75 NKnownLevels=0; NUnknownLevels=0; NLevels=0; KnownLevelsVectorSize=0;
76 theRandom1=0;
77 theRandom2=0;
78 theRandom3=0;
79 theLD=0;
80 theICC=0;
81 thePSF=0;
82 TotalGammaRho=0;
83 theThermalCaptureLevelCumulBR=0;
84 TotalCumulBR=0;
85
86 Z_Int=Z;
87 A_Int=A;
88
89 //Random generators:
90 seed1=1234567;
91 seed2=1234567;
92 seed3=1234567;
93 theRandom1= new G4NuDEXRandom(seed1);
94 theRandom2= new G4NuDEXRandom(seed2);
95 theRandom3= new G4NuDEXRandom(seed3);
96 Rand1seedProvided=false; Rand2seedProvided=false; Rand3seedProvided=false;
97}
const G4double A[17]

◆ ~G4NuDEXStatisticalNucleus()

G4NuDEXStatisticalNucleus::~G4NuDEXStatisticalNucleus ( )

Definition at line 135 of file G4NuDEXStatisticalNucleus.cc.

135 {
136
137 if(theLevels!=0){delete [] theLevels;}
138 for(G4int i=0;i<KnownLevelsVectorSize;i++){
139 if(theKnownLevels[i].Ndecays>0){
140 delete [] theKnownLevels[i].decayFraction;
141 delete [] theKnownLevels[i].decayMode;
142 }
143 if(theKnownLevels[i].NGammas>0){
144 delete [] theKnownLevels[i].FinalLevelID;
145 delete [] theKnownLevels[i].multipolarity;
146 delete [] theKnownLevels[i].Eg;
147 delete [] theKnownLevels[i].cumulPtot;
148 delete [] theKnownLevels[i].Pg;
149 delete [] theKnownLevels[i].Pe;
150 delete [] theKnownLevels[i].Icc;
151 }
152 }
153 if(theKnownLevels!=0){delete [] theKnownLevels;}
154 if(theRandom1!=0){delete theRandom1;}
155 if(theRandom2!=0){delete theRandom2;}
156 if(theRandom3!=0){delete theRandom3;}
157 if(theLD!=0){delete theLD;}
158 if(theICC!=0){delete theICC;}
159 if(thePSF!=0){delete thePSF;}
160 if(TotalGammaRho!=0){delete [] TotalGammaRho;}
161 if(theThermalCaptureLevelCumulBR!=0){delete [] theThermalCaptureLevelCumulBR;}
162 if(TotalCumulBR!=0){
163 for(G4int i=0;i<NLevels;i++){
164 if(TotalCumulBR[i]!=0){delete [] TotalCumulBR[i];}
165 }
166 delete [] TotalCumulBR;
167 }
168}
int G4int
Definition G4Types.hh:85

Member Function Documentation

◆ ChangeLevelSpinParityAndBR()

void G4NuDEXStatisticalNucleus::ChangeLevelSpinParityAndBR ( G4int i_level,
G4int newspinx2,
G4bool newParity,
G4int nlevels,
G4double width,
unsigned int seed = 0 )

Definition at line 571 of file G4NuDEXStatisticalNucleus.cc.

571 {
572
573 if(i_level==-1){ //change BR of thermal, ignore arguments
574 if(Sn>0 && NLevels>1){
575 CreateThermalCaptureLevel(seed);
576 GenerateThermalCaptureLevelBR(theLibDir.c_str());
577 }
578 return;
579 }
580
581 if(i_level<0 || i_level>=NLevels){
582 std::cout<<" i_level = "<<i_level<<" ------ NLevels = "<<NLevels<<std::endl;
583 NuDEXException(__FILE__,std::to_string(__LINE__).c_str(),"##### Error in NuDEX #####");
584 }
585
586 //Do not apply to known levels:
587 if(i_level<NKnownLevels || theLevels[i_level].KnownLevelID>0){
588 std::cout<<" ####### WARNING: you are trying to change the BR, spin, parity, etc. of a known level --> nothing is done ############"<<std::endl;
589 return;
590 //NuDEXException(__FILE__,std::to_string(__LINE__).c_str(),"##### Error in NuDEX #####");
591 }
592
593 theLevels[i_level].spinx2=newspinx2;
594 theLevels[i_level].parity=newParity;
595 if(seed>0){
596 theLevels[i_level].seed=seed;
597 }
598 else{
599 theLevels[i_level].seed=theRandom2->Integer(4294967295)+1;
600 }
601 if(nlevels>=0){
602 theLevels[i_level].NLevels=nlevels;
603 }
604 if(width>=0){
605 theLevels[i_level].Width=width;
606 }
607
608 if(TotalGammaRho[i_level]>=0){ //then we have to change TotalGammaRho[i_level]
609 G4double* br_vector=0;
610 if(TotalCumulBR!=0){
611 br_vector=TotalCumulBR[i_level];
612 }
613 TotalGammaRho[i_level]=ComputeDecayIntensities(i_level,br_vector);
614 }
615
616}
void NuDEXException(const char *originOfException, const char *exceptionCode, const char *description)
double G4double
Definition G4Types.hh:83

◆ ChangeThermalCaptureLevelBR()

void G4NuDEXStatisticalNucleus::ChangeThermalCaptureLevelBR ( G4double LevelEnergy,
G4double absoluteIntensity )

Definition at line 2019 of file G4NuDEXStatisticalNucleus.cc.

2019 {
2020
2021 if(!theThermalCaptureLevelCumulBR){return;}
2022 G4int level_id=GetClosestLevel(LevelEnergy,-1,true);
2023 if(level_id<0 || level_id>=NLevelsBelowThermalCaptureLevel){
2024 std::cout<<" ############## WARNING in "<<__FILE__<<", line "<<__LINE__<<" ##############"<<std::endl;
2025 std::cout<<" ---> "<<level_id<<" "<<LevelEnergy<<std::endl;
2026 }
2027
2028 for(G4int i=NLevelsBelowThermalCaptureLevel-1;i>0;i--){
2029 theThermalCaptureLevelCumulBR[i]-=theThermalCaptureLevelCumulBR[i-1];
2030 }
2031 G4double OldIntensity=theThermalCaptureLevelCumulBR[level_id];
2032 theThermalCaptureLevelCumulBR[level_id]=absoluteIntensity*(1.-OldIntensity)/(1.-absoluteIntensity);
2033
2034 for(G4int i=1;i<NLevelsBelowThermalCaptureLevel;i++){
2035 theThermalCaptureLevelCumulBR[i]+=theThermalCaptureLevelCumulBR[i-1];
2036 }
2037 for(G4int i=0;i<NLevelsBelowThermalCaptureLevel;i++){
2038 theThermalCaptureLevelCumulBR[i]/=theThermalCaptureLevelCumulBR[NLevelsBelowThermalCaptureLevel-1];
2039 }
2040 if(level_id==0){
2041 std::cout<<" Thermal primary gammas to level "<<level_id<<", with E="<<theLevels[level_id].Energy<<" MeV changed from "<<OldIntensity<<" to "<<theThermalCaptureLevelCumulBR[level_id]<<std::endl;
2042 }
2043 else{
2044 std::cout<<" Thermal primary gammas to level "<<level_id<<", with E="<<theLevels[level_id].Energy<<" MeV changed from "<<OldIntensity<<" to "<<theThermalCaptureLevelCumulBR[level_id]-theThermalCaptureLevelCumulBR[level_id-1]<<std::endl;
2045 }
2046}
G4int GetClosestLevel(G4double Energy, G4int spinx2, G4bool parity)

◆ GenerateCascade()

G4int G4NuDEXStatisticalNucleus::GenerateCascade ( G4int InitialLevel,
G4double ExcitationEnergy,
std::vector< char > & pType,
std::vector< double > & pEnergy,
std::vector< double > & pTime )

Definition at line 356 of file G4NuDEXStatisticalNucleus.cc.

356 {
357
358 pType.clear();
359 pEnergy.clear();
360 pTime.clear();
361
362 if(ExcitationEnergy<0){
363 ExcitationEnergy=Sn-(A_Int-1.)/(G4double)A_Int*ExcitationEnergy;
364 }
365 if(ExcitationEnergy<=0){
366 return 0;
367 }
368
369 G4int Npar=0;
370 G4int f_level=0,multipol=0;
371 G4double alpha,E_trans,Exc_ene_i,Exc_ene_f; //icc factor, energy of the transition, initial/final excitation energy
372 G4double EmissionTime=0; //in seconds
373 G4int NTransition=0;
374 //G4double TotalCascadeEnergy1=0,TotalCascadeEnergy2=0;
375
376 //Start:
377 G4int i_level=InitialLevel;
378 Exc_ene_i=ExcitationEnergy;
379
380
381 if(i_level==0){ //could happen
382 pType.push_back('g');
383 pEnergy.push_back(Exc_ene_i);
384 pTime.push_back(0);
385 Npar++;
386 }
387
388 //Loop:
389 while(i_level!=0){
390
391 NTransition++;
392 //--------------------------------------------
393 //Sample final level:
394 if(i_level==-1){ //thermal level
395 if(!theThermalCaptureLevelCumulBR){
396 f_level=0;
397 std::cout<<" ############## NuDEX: WARNING, there are no thermal capture for ZA="<<A_Int+1000*Z_Int-1<<" , with Sn = "<<Sn<<" ##############"<<std::endl;
398 }
399 else{
400 //Sample final level:
401 G4double randnumber=theRandom3->Uniform();
402 f_level=-1;
403 for(G4int i=0;i<NLevelsBelowThermalCaptureLevel;i++){
404 if(theThermalCaptureLevelCumulBR[i]>randnumber){
405 multipol=GetMultipolarity(&theThermalCaptureLevel,&theLevels[i]);
406 f_level=i;
407 break;
408 }
409 }
410 }
411 if(f_level<0){
412 NuDEXException(__FILE__,std::to_string(__LINE__).c_str(),"##### Error in NuDEX #####");
413 }
414 Exc_ene_f=theLevels[f_level].Energy;
415 }
416 else if(i_level>0){
417 f_level=SampleFinalLevel(i_level,multipol,alpha,NTransition);
418 }
419 else{
420 NuDEXException(__FILE__,std::to_string(__LINE__).c_str(),"##### Error in NuDEX #####");
421 }
422 //--------------------------------------------
423
424 //Energy of the transition:
425 Exc_ene_f=theLevels[f_level].Energy;
426
427 //We sample the final energy if it is a band of levels:
428 if(theLevels[f_level].Width!=0){
429 Exc_ene_f+=theRandom3->Uniform(-theLevels[f_level].Width,+theLevels[f_level].Width);
430 }
431 E_trans=Exc_ene_i-Exc_ene_f;
432 if(E_trans<=0){
433 //std::cout<<"Exc_ene_i = "<<Exc_ene_i<<" Exc_ene_f = "<<Exc_ene_f<<std::endl;
434 //std::cout<<" ####### WARNING: E_trans = "<<E_trans<<" for i="<<i_level<<" with E = "<<theLevels[std::max(i_level,0)].Energy<<" to f="<<f_level<<" with E = "<<theLevels[f_level].Energy<<" ########"<<std::endl;
435 return -1;
436 }
437 //------------------------------------------------------------
438 //Emission time:
439 if(i_level<NKnownLevels && i_level>0){
440 if(theKnownLevels[i_level].T12>0){
441 EmissionTime+=theRandom3->Exp(theKnownLevels[i_level].T12/std::log(2));
442 }
443 }
444 //------------------------------------------------------------
445
446 //------------------------------------------------------------
447 //calculate electron conversion:
448 G4bool ele_conv=false;
449 if(ElectronConversionFlag>0){
450 if(i_level<NKnownLevels && i_level>0){ //ElectronConversionFlag=1,2
451 ele_conv=theICC->SampleInternalConversion(E_trans,multipol,alpha); //use the alpha value from the know level value
452 }
453 else if(ElectronConversionFlag==2){
454 ele_conv=theICC->SampleInternalConversion(E_trans,multipol); //calculate alpha (icc factor)
455 }
456 }
457 //------------------------------------------------------------
458 //std::cout<<" ---- "<<Exc_ene_i<<" "<<Exc_ene_f<<" "<<E_trans<<" "<<multipol<<" "<<ele_conv<<std::endl;
459 //TotalCascadeEnergy1+=E_trans;
460
461 //------------------------------------------------------------
462 //Fill result:
463 if(ele_conv){
464 for(G4int i=0;i<theICC->Ne;i++){
465 pType.push_back('e');
466 pEnergy.push_back(theICC->Eele[i]);
467 pTime.push_back(EmissionTime);
468 Npar++;
469 }
470 for(G4int i=0;i<theICC->Ng;i++){
471 pType.push_back('g');
472 pEnergy.push_back(theICC->Egam[i]);
473 pTime.push_back(EmissionTime);
474 Npar++;
475 }
476 }
477 else{
478 pType.push_back('g');
479 pEnergy.push_back(E_trans);
480 pTime.push_back(EmissionTime);
481 Npar++;
482 }
483 //------------------------------------------------------------
484 i_level=f_level;
485 Exc_ene_i=Exc_ene_f;
486 }
487
488 //for(G4int i=0;i<Npar;i++){TotalCascadeEnergy2+=pEnergy[i];}
489 //std::cout<<" Total energy: "<<TotalCascadeEnergy1<<" "<<TotalCascadeEnergy2<<std::endl; getchar();
490
491
492 if(i_level!=0){
493 NuDEXException(__FILE__,std::to_string(__LINE__).c_str(),"##### Error in NuDEX #####");
494 }
495 return Npar;
496}
bool G4bool
Definition G4Types.hh:86

◆ GetClosestLevel()

G4int G4NuDEXStatisticalNucleus::GetClosestLevel ( G4double Energy,
G4int spinx2,
G4bool parity )

Definition at line 832 of file G4NuDEXStatisticalNucleus.cc.

832 {
833
834 //std::cout<<" XXX finding closest level of spin "<<spinx2/2.<<" and parity "<<parity<<" to "<<Energy<<" MeV"<<std::endl;
835
836 //------------------------------------------------------------------------------
837 // We try to go closer to the solution, otherwise it takes too much time:
838 G4int i_down=0,i_up=NLevels-1;
839 G4int i_close_down=0,i_close_up=NLevels-1;
840 G4int i_close=0;
841 while(i_close_up-i_close_down>10){
842 i_close=(i_close_up+i_close_down)/2;
843 if(theLevels[i_close].Energy>Energy){
844 i_close_up=i_close;
845 }
846 else{
847 i_close_down=i_close;
848 }
849 }
850
851 for(G4int i=i_close_up;i<NLevels;i++){
852 i_up=i;
853 if((theLevels[i].spinx2==spinx2 && theLevels[i].parity==parity) || spinx2<0){
854 break;
855 }
856 }
857 for(G4int i=i_close_down;i>=0;i--){
858 i_down=i;
859 if((theLevels[i].spinx2==spinx2 && theLevels[i].parity==parity) || spinx2<0){
860 break;
861 }
862 }
863 //------------------------------------------------------------------------------
864
865 G4double MinEnergyDistance=-1,EnergyDistance;
866 G4int result=-1;
867 for(G4int i=i_down;i<=i_up;i++){
868 EnergyDistance=std::fabs(theLevels[i].Energy-Energy);
869 if((theLevels[i].spinx2==spinx2 && theLevels[i].parity==parity) || spinx2<0){ //then this is a candidate
870 if(EnergyDistance<MinEnergyDistance || MinEnergyDistance<0){
871 MinEnergyDistance=EnergyDistance;
872 result=i;
873 }
874 }
875 }
876 //std::cout<<" XXX found --> "<<result<<std::endl;
877
878
879 return result;
880}

Referenced by ChangeThermalCaptureLevelBR().

◆ GetLevel()

Level * G4NuDEXStatisticalNucleus::GetLevel ( G4int i_level)

Definition at line 883 of file G4NuDEXStatisticalNucleus.cc.

883 {
884
885 if(i_level>=0 && i_level<NLevels){
886 return &theLevels[i_level];
887 }
888 if(i_level==-1){
889 return &theThermalCaptureLevel;
890 }
891
892 std::cout<<" ############ WARNING: for ZA="<<A_Int+1000*Z_Int<<" , requested level i_level="<<i_level<<" does not exist ############"<<std::endl;
893
894 return 0;
895}

◆ GetLevelEnergy()

G4double G4NuDEXStatisticalNucleus::GetLevelEnergy ( G4int i_level)

Definition at line 897 of file G4NuDEXStatisticalNucleus.cc.

897 {
898
899 if(i_level>=0 && i_level<NLevels){
900 return theLevels[i_level].Energy;
901 }
902
903 return -1;
904}

◆ GetRandom3()

G4NuDEXRandom * G4NuDEXStatisticalNucleus::GetRandom3 ( )
inline

Definition at line 131 of file G4NuDEXStatisticalNucleus.hh.

131{return theRandom3;}

◆ GetSnAndI0()

void G4NuDEXStatisticalNucleus::GetSnAndI0 ( G4double & sn,
G4double & i0 )
inline

Definition at line 118 of file G4NuDEXStatisticalNucleus.hh.

118{sn=Sn; i0=I0;}

◆ HasBeenInitialized()

G4bool G4NuDEXStatisticalNucleus::HasBeenInitialized ( )
inline

Definition at line 132 of file G4NuDEXStatisticalNucleus.hh.

132{return hasBeenInitialized;}

◆ Init()

G4int G4NuDEXStatisticalNucleus::Init ( const char * dirname,
const char * inputfname = 0 )

Definition at line 171 of file G4NuDEXStatisticalNucleus.cc.

171 {
172
173 hasBeenInitialized=true;
174 //-------------------------------------------------------------------
175 //First, we read data from files:
176 G4int check=0;
177 char fname[1000],defaultinputfname[1000];
178 theLibDir=std::string(dirname);
179
180 //Special (default) input file:
181 snprintf(defaultinputfname,1000,"%s/SpecialInputs/ZA_%d.dat",dirname,Z_Int*1000+A_Int);
182 G4int HasDefaultInput=ReadSpecialInputFile(defaultinputfname);
183 char* definputfn=0;
184 if(HasDefaultInput>0){definputfn=defaultinputfname;}
185
186 //General statistical parameters:
187 snprintf(fname,1000,"%s/GeneralStatNuclParameters.dat",dirname);
188 check=ReadGeneralStatNuclParameters(fname); if(check<0){return -1;}
189
190 //Some default, if not initialized yet:
191 if(ElectronConversionFlag<0){ElectronConversionFlag=2;} // All EC
192 if(KnownLevelsFlag<0){KnownLevelsFlag=1;} //Use all known levels
193 if(PrimaryGammasIntensityNormFactor<0){PrimaryGammasIntensityNormFactor=1;}
194 if(PrimaryGammasEcut<0){PrimaryGammasEcut=0;}
195 if(Ecrit<0){
196 snprintf(fname,1000,"%s/KnownLevels/levels-param.data",dirname);
197 check=ReadEcrit(fname); if(check<0){return -1;}
198 }
199
200
201 //Level density:
202 theLD=new G4NuDEXLevelDensity(Z_Int,A_Int,LevelDensityType);
203 check=theLD->ReadLDParameters(dirname,inputfname,definputfn); //if(check<0){return -1;}
204 LevelDensityType=theLD->GetLDType(); //because it can be changed by inputfname or due to lack of data
205 if(check<0){
206 delete theLD; theLD=0;
207 Sn=-1; D0=-1; I0=-1000;
208 }
209 else{
210 theLD->GetSnD0I0Vals(Sn,D0,I0);
211 }
212
213 //Known level sheme:
214 snprintf(fname,1000,"%s/KnownLevels/z%03d.dat",dirname,Z_Int);
215 check=ReadKnownLevels(fname); if(check<0){return -1;} //here we get/crosscheck Sn
216 I0=TakeTargetNucleiI0(fname,check); if(check<0){return -1;} //if no I0 --> out
217
218 if(MaxExcEnergy<=0){
219 if(Sn>0){
220 MaxExcEnergy=Sn-MaxExcEnergy;
221 }
222 else{
223 MaxExcEnergy=1-MaxExcEnergy;
224 }
225 }
226
227 //If we don't have level density and the known level scheme is not complete, then we can do nothing ...
228 if(theLD==0 && Ecrit<MaxExcEnergy){
229 std::cout<<" ###### WARNING: No level density and level scheme not complete for ZA="<<1000*Z_Int+A_Int<<" --> Ecrit="<<Ecrit<<" MeV and MaxExcEnergy = "<<MaxExcEnergy<<" MeV ######"<<std::endl;
230 return -1;
231 }
232 //-------------------------------------------------------------------
233
234 //-------------------------------------------------------------------
235 //Init some variables:
236 E_unk_min=Ecrit;
237 E_unk_max=MaxExcEnergy;
238
239 NBands=0;
240 if(BandWidth>0){//then we have to create some bands
241 NBands=0;
242 while(E_unk_min+BandWidth*NBands<MaxExcEnergy){
243 NBands++;
244 }
245 E_unk_max=E_unk_min+BandWidth*NBands;
246 }
247
248 Emin_bands=E_unk_min;
249 Emax_bands=E_unk_max;
250 //-------------------------------------------------------------------
251
252
253 //Make some checks:
254 MakeSomeParameterChecks01();
255
256 //Level scheme:
257 //std::cout<<" creating level scheme ..."<<std::endl;
258 CreateLevelScheme();
259 //std::cout<<" ............. done"<<std::endl;
260
261 if(KnownLevelsFlag==1){
262 InsertHighEnergyKnownLevels();
263 }
264
265 //We set the precursors for each level:
266 for(G4int i=0;i<NLevels;i++){
267 theLevels[NLevels-1-i].seed=theRandom2->Integer(4294967295)+1;
268 }
269
270 //Internal conversion:
271 theICC=new G4NuDEXInternalConversion(Z_Int);
272 snprintf(fname,1000,"%s/ICC_factors.dat",dirname);
273 theICC->Init(fname);
274 theICC->SetRandom4Seed(theRandom3->GetSeed()); //same seed as for generating the cascades
275
276 //PSF:
277 thePSF=new G4NuDEXPSF(Z_Int,A_Int);
278 thePSF->Init(dirname,theLD,inputfname,definputfn,PSFflag);
279
280 //We compute the missing BR in the known part of the level scheme:
281 ComputeKnownLevelsMissingBR();
282
283 //Init TotalGammaRho:
284 TotalGammaRho=new G4double[NLevels];
285 for(G4int i=0;i<NLevels-1;i++){
286 TotalGammaRho[i]=-1;
287 }
288
289 //Thermal capture level:
290 if(Sn>0 && NLevels>1){
291 CreateThermalCaptureLevel();
292 GenerateThermalCaptureLevelBR(dirname);
293 }
294
295 //Init TotalCumulBR, if BROpt==1,2
296 if(BROpt==1 || BROpt==2){
297 TotalCumulBR=new G4double*[NLevels];
298 for(G4int i=0;i<NLevels;i++){
299 TotalCumulBR[i]=0;
300 }
301 }
302
303 return 0;
304}

◆ PrintAll()

void G4NuDEXStatisticalNucleus::PrintAll ( std::ostream & out)

Definition at line 2302 of file G4NuDEXStatisticalNucleus.cc.

2302 {
2303
2304 PrintParameters(out);
2305 PrintKnownLevels(out);
2306 PrintLevelDensity(out);
2307 PrintLevelScheme(out);
2309 PrintPSF(out);
2310 PrintICC(out);
2311
2312}
void PrintLevelDensity(std::ostream &out)
void PrintLevelScheme(std::ostream &out)
void PrintParameters(std::ostream &out)
void PrintKnownLevels(std::ostream &out)
void PrintThermalPrimaryTransitions(std::ostream &out)

◆ PrintBR()

void G4NuDEXStatisticalNucleus::PrintBR ( G4int i_level,
G4double MaxExcEneToPrint_MeV,
std::ostream & out )

Definition at line 2234 of file G4NuDEXStatisticalNucleus.cc.

2234 {
2235
2236 if(TotalCumulBR[i_level]!=0){
2237 out<<" #################################################### "<<std::endl;
2238 out<<" BR FROM LEVEL "<<i_level<<" with ENERGY "<<theLevels[i_level].Energy<<std::endl;
2239 for(G4int i=0;i<i_level;i++){
2240 if(theLevels[i].Energy<MaxExcEneToPrint_MeV || MaxExcEneToPrint_MeV<0){
2241 if(i==0){
2242 out<<theLevels[i].Energy<<" "<<theLevels[i].spinx2/2.<<" "<<theLevels[i].parity<<" "<<TotalCumulBR[i_level][i]<<std::endl;
2243 }
2244 else{
2245 out<<theLevels[i].Energy<<" "<<theLevels[i].spinx2/2.<<" "<<theLevels[i].parity<<" "<<TotalCumulBR[i_level][i]-TotalCumulBR[i_level][i-1]<<std::endl;
2246 }
2247 }
2248 }
2249 out<<" #################################################### "<<std::endl;
2250 }
2251
2252
2253}

◆ PrintICC()

void G4NuDEXStatisticalNucleus::PrintICC ( std::ostream & out)

Definition at line 2296 of file G4NuDEXStatisticalNucleus.cc.

2296 {
2297
2298 theICC->PrintICC(out);
2299
2300}

Referenced by PrintAll().

◆ PrintInput01()

void G4NuDEXStatisticalNucleus::PrintInput01 ( std::ostream & out)

Definition at line 2316 of file G4NuDEXStatisticalNucleus.cc.

2316 {
2317
2318 out<<"LEVELDENSITYTYPE "<<LevelDensityType<<std::endl;
2319 out<<"MAXSPIN "<<maxspinx2/2.<<std::endl;
2320 out<<"MINLEVELSPERBAND "<<MinLevelsPerBand<<std::endl;
2321 out<<"BANDWIDTH_MEV "<<BandWidth<<std::endl;
2322 out<<"MAXEXCENERGY_MEV "<<MaxExcEnergy<<std::endl;
2323 out<<"ECRIT_MEV "<<Ecrit<<std::endl;
2324 out<<"KNOWNLEVELSFLAG "<<KnownLevelsFlag<<std::endl;
2325 out<<std::endl;
2326 out<<"PSF_FLAG "<<PSFflag<<std::endl;
2327 out<<"BROPTION "<<BROpt<<std::endl;
2328 out<<"SAMPLEGAMMAWIDTHS "<<SampleGammaWidths<<std::endl;
2329 out<<std::endl;
2330 out<<"SEED1 "<<seed1<<std::endl;
2331 out<<"SEED2 "<<seed2<<std::endl;
2332 out<<"SEED3 "<<seed3<<std::endl;
2333 out<<std::endl;
2334 out<<"ELECTRONCONVERSIONFLAG "<<ElectronConversionFlag<<std::endl;
2335 out<<"PRIMARYTHCAPGAMNORM "<<PrimaryGammasIntensityNormFactor<<std::endl;
2336 out<<"PRIMARYGAMMASECUT "<<PrimaryGammasEcut<<std::endl;
2337 out<<std::endl;
2338 theLD->PrintParametersInInputFileFormat(out);
2339 thePSF->PrintPSFParametersInInputFileFormat(out);
2340 out<<std::endl;
2341 out<<"END"<<std::endl;
2342
2343}

◆ PrintKnownLevels()

void G4NuDEXStatisticalNucleus::PrintKnownLevels ( std::ostream & out)

Definition at line 2072 of file G4NuDEXStatisticalNucleus.cc.

2072 {
2073
2074 out<<" ########################################################################################################## "<<std::endl;
2075 out<<" KNOWN_LEVEL_SCHEME "<<std::endl;
2076 out<<" NKnownLevels = "<<NKnownLevels<<std::endl;
2077 char buffer[1000];
2078
2079 //for(G4int i=0;i<NKnownLevels;i++){
2080 for(G4int i=0;i<KnownLevelsVectorSize;i++){
2081 snprintf(buffer,1000,"%3d %10.4g %5g %2d %10.4g %3d %3d",theKnownLevels[i].id+1,theKnownLevels[i].Energy,theKnownLevels[i].spinx2/2.,2*(G4int)theKnownLevels[i].parity-1,theKnownLevels[i].T12,theKnownLevels[i].NGammas,theKnownLevels[i].Ndecays);
2082 out<<buffer;
2083 for(G4int j=0;j<theKnownLevels[i].Ndecays;j++){
2084 snprintf(buffer,1000," %10.4g %7s",theKnownLevels[i].decayFraction[j],theKnownLevels[i].decayMode[j].c_str());
2085 out<<buffer;
2086 }
2087 out<<std::endl;
2088 for(G4int j=0;j<theKnownLevels[i].NGammas;j++){
2089 snprintf(buffer,1000," %4d %10.4g %10.4g %10.4g %10.4g %10.4g %2d",theKnownLevels[i].FinalLevelID[j]+1,theKnownLevels[i].Eg[j],theKnownLevels[i].Pg[j],theKnownLevels[i].Pe[j],theKnownLevels[i].Icc[j],theKnownLevels[i].cumulPtot[j],theKnownLevels[i].multipolarity[j]);
2090 out<<buffer<<std::endl;
2091 }
2092 }
2093 out<<" ########################################################################################################## "<<std::endl;
2094
2095}

Referenced by PrintAll().

◆ PrintKnownLevelsInDEGENformat()

void G4NuDEXStatisticalNucleus::PrintKnownLevelsInDEGENformat ( std::ostream & out)

Definition at line 2097 of file G4NuDEXStatisticalNucleus.cc.

2097 {
2098
2099 out<<" ########################################################################################################## "<<std::endl;
2100 out<<" KNOWN_LEVES_DEGEN "<<std::endl;
2101 out<<" NKnownLevels = "<<NKnownLevels<<std::endl;
2102 char buffer[1000];
2103
2104 for(G4int i=0;i<NKnownLevels;i++){
2105 G4double MaxIntens=-100;
2106 G4double GammaEnergy;
2107 for(G4int j=0;j<theKnownLevels[i].NGammas;j++){
2108 if(theKnownLevels[i].Pg[j]>MaxIntens){MaxIntens=theKnownLevels[i].Pg[j];}
2109 }
2110 for(G4int j=0;j<theKnownLevels[i].NGammas;j++){
2111 //snprintf(buffer,1000,"%10.3f %9.3f %9.3f %9.3f %9.3f %9.3f %9.3f %9.3f",theKnownLevels[i].Energy*1000.,theKnownLevels[i].spinx2/2.,2.*(G4int)theKnownLevels[i].parity-1,theKnownLevels[i].Eg[j]*1000.,0.,theKnownLevels[i].Pg[j]/MaxIntens*100.,0.,theKnownLevels[i].Icc[j]);
2112 GammaEnergy=theKnownLevels[i].Energy-theKnownLevels[theKnownLevels[i].FinalLevelID[j]].Energy;
2113 snprintf(buffer,1000,"%10.3f %9.3f %9.3f %9.3f %9.3f %9.3f %9.3f %9.3f",theKnownLevels[i].Energy*1000.,theKnownLevels[i].spinx2/2.,2.*(G4int)theKnownLevels[i].parity-1,GammaEnergy*1000.,0.,theKnownLevels[i].Pg[j]/MaxIntens*100.,0.,theKnownLevels[i].Icc[j]);
2114 out<<buffer<<std::endl;
2115 }
2116 }
2117 out<<" ########################################################################################################## "<<std::endl;
2118
2119}

◆ PrintLevelDensity()

void G4NuDEXStatisticalNucleus::PrintLevelDensity ( std::ostream & out)

Definition at line 2121 of file G4NuDEXStatisticalNucleus.cc.

2121 {
2122
2123 if(theLD==0){return;}
2124
2125 G4double Emin=0;
2126 G4double Emax=E_unk_max;
2127 G4int np=100;
2128
2129 out<<" ###################################################################################### "<<std::endl;
2130 out<<" LEVELDENSITY"<<std::endl;
2131 G4double ene,exp=0;
2132 G4double *ld=new G4double[maxspinx2+2];
2133 G4bool *WriteThisSpin=new G4bool[maxspinx2+1];
2134
2135 for(G4int spx2=0;spx2<=maxspinx2;spx2++){
2136 WriteThisSpin[spx2]=true;
2137 if(((A_Int+spx2)%2)!=0){
2138 WriteThisSpin[spx2]=false;
2139 }
2140 }
2141
2142 out<<np<<" "<<Emin<<" "<<Emax<<" "<<Ecrit<<" "<<maxspinx2<<std::endl;
2143 out<<"ENE EXP TOT SUM(J)";
2144 for(G4int spx2=0;spx2<=maxspinx2;spx2++){
2145 if(WriteThisSpin[spx2]){out<<" J="<<spx2/2.;}
2146 }
2147 out<<std::endl;
2148
2149 for(G4int i=0;i<np;i++){
2150 ene=Emin+(Emax-Emin)*i/(G4double)(np-1);
2151 exp=0;
2152 for(G4int j=0;j<NLevels;j++){if(theLevels[j].Energy<ene){exp+=theLevels[j].NLevels;}}
2153 out<<ene<<" "<<exp<<" ";
2154 ld[maxspinx2+1]=0;
2155 for(G4int spx2=0;spx2<=maxspinx2;spx2++){
2156 ld[spx2]=2*theLD->GetLevelDensity(ene,spx2/2.,true);
2157 ld[maxspinx2+1]+=ld[spx2];
2158 }
2159 //out<<ld[maxspinx2+1];
2160 out<<theLD->GetLevelDensity(ene,0,true,true)<<" "<<ld[maxspinx2+1];
2161 for(G4int spx2=0;spx2<=maxspinx2;spx2++){
2162 if(WriteThisSpin[spx2]){out<<" "<<ld[spx2];}
2163 }
2164 out<<std::endl;
2165 }
2166 out<<" ###################################################################################### "<<std::endl;
2167
2168 delete [] ld;
2169 delete [] WriteThisSpin;
2170}

Referenced by PrintAll().

◆ PrintLevelScheme()

void G4NuDEXStatisticalNucleus::PrintLevelScheme ( std::ostream & out)

Definition at line 2186 of file G4NuDEXStatisticalNucleus.cc.

2186 {
2187 out<<" ###################################################################################### "<<std::endl;
2188 out<<" LEVELSCHEME"<<std::endl;
2189 for(G4int i=0;i<NLevels;i++){
2190 out<<i<<" "<<theLevels[i].Energy<<" "<<theLevels[i].spinx2/2.<<" "<<theLevels[i].parity<<" "<<theLevels[i].KnownLevelID<<" "<<theLevels[i].NLevels<<" "<<theLevels[i].Width<<" "<<theLevels[i].seed<<std::endl;
2191 }
2192 out<<" ###################################################################################### "<<std::endl;
2193}

Referenced by PrintAll().

◆ PrintLevelSchemeInDEGENformat()

void G4NuDEXStatisticalNucleus::PrintLevelSchemeInDEGENformat ( const char * fname,
G4int MaxLevelID = -1 )

Definition at line 2172 of file G4NuDEXStatisticalNucleus.cc.

2172 {
2173
2174 std::ofstream out(fname);
2175 char buffer[1000];
2176 for(G4int i=0;i<NLevels;i++){
2177 if(theLevels[i].Energy>Ecrit && (MaxLevelID>0 && i<=MaxLevelID)){
2178 snprintf(buffer,1000,"%13.5f %17.8f %17.8f ",theLevels[i].Energy*1000.,theLevels[i].spinx2/2.,2.*(G4int)theLevels[i].parity-1);
2179 out<<buffer<<std::endl;
2180 }
2181 }
2182 out.close();
2183
2184}

◆ PrintParameters()

void G4NuDEXStatisticalNucleus::PrintParameters ( std::ostream & out)

Definition at line 2048 of file G4NuDEXStatisticalNucleus.cc.

2048 {
2049
2050 out<<" ###################################################################################### "<<std::endl;
2051 out<<" GENERAL_PARS"<<std::endl;
2052 out<<" Z = "<<Z_Int<<" A = "<<A_Int<<std::endl;
2053 out<<" Sn = "<<Sn<<" I0(ZA-1) = "<<I0<<std::endl;
2054 if(theLD!=0){theLD->PrintParameters(out);}
2055 else{out<<" No level density"<<std::endl;}
2056 out<<" PSFflag = "<<PSFflag<<std::endl;
2057 out<<" Ecrit = "<<Ecrit<<std::endl;
2058 out<<" E_unknown_min = "<<E_unk_min<<" E_unknown_max = "<<E_unk_max<<std::endl;
2059 out<<" maxspin = "<<maxspinx2/2.<<std::endl;
2060 out<<" MaxExcEnergy = "<<MaxExcEnergy<<std::endl;
2061 out<<" NBands = "<<NBands<<" MinLevelsPerBand = "<<MinLevelsPerBand<<" BandWidth = "<<BandWidth<<std::endl;
2062 out<<" Emin_bands = "<<Emin_bands<<" Emax_bands = "<<Emax_bands<<std::endl;
2063 out<<" NLevels = "<<NLevels<<" NKnownLevels = "<<NKnownLevels<<" NUnknownLevels = "<<NUnknownLevels<<std::endl;
2064 out<<" BROpt = "<<BROpt<<" SampleGammaWidths = "<<SampleGammaWidths<<std::endl;
2065 out<<" PrimaryGammasIntensityNormFactor = "<<PrimaryGammasIntensityNormFactor<<" PrimaryGammasEcut = "<<PrimaryGammasEcut<<std::endl;
2066 out<<" KnownLevelsFlag = "<<KnownLevelsFlag<<std::endl;
2067 out<<" ElectronConversionFlag = "<<ElectronConversionFlag<<std::endl;
2068 out<<" ###################################################################################### "<<std::endl;
2069
2070}

Referenced by PrintAll().

◆ PrintPSF()

void G4NuDEXStatisticalNucleus::PrintPSF ( std::ostream & out)

Definition at line 2256 of file G4NuDEXStatisticalNucleus.cc.

2256 {
2257
2258 thePSF->PrintPSFParameters(out);
2259
2260 G4int NVals=400;
2261 G4int nEnePSF=(G4int)Sn+1; //number of excitation energies where the PSF are evaluated
2262 G4double EnePSF[200];
2263 G4double Emin=0;
2264 G4double Emax=10;
2265 G4double xval,e1,m1,e2;
2266
2267 out<<" #################################################### "<<std::endl;
2268 out<<" PSF"<<std::endl;
2269 out<<" "<<NVals<<" "<<Emin<<" "<<Emax<<" "<<nEnePSF<<std::endl;
2270 EnePSF[0]=Sn;
2271 for(G4int i=1;i<nEnePSF;i++){
2272 EnePSF[i]=i;
2273 }
2274 for(G4int i=0;i<nEnePSF;i++){
2275 out<<" "<<EnePSF[i];
2276 }
2277 out<<std::endl;
2278 char word[1000];
2279 out<<" E E1 M1 E2 "<<std::endl;
2280 for(G4int i=0;i<nEnePSF;i++){
2281 for(G4int j=0;j<NVals;j++){
2282 xval=Emin+(Emax-Emin)*j/(NVals-1.);
2283 if(xval==0){xval=1.e-6;}
2284 e1=thePSF->GetE1(xval,EnePSF[i]);
2285 m1=thePSF->GetM1(xval,EnePSF[i]);
2286 e2=thePSF->GetE2(xval,EnePSF[i]);
2287 snprintf(word,1000," %10.4E %10.4E %10.4E %10.4E",xval,e1,m1,e2);
2288 out<<word<<std::endl;
2289 }
2290 }
2291 out<<" #################################################### "<<std::endl;
2292
2293}

Referenced by PrintAll().

◆ PrintThermalPrimaryTransitions()

void G4NuDEXStatisticalNucleus::PrintThermalPrimaryTransitions ( std::ostream & out)

Definition at line 2195 of file G4NuDEXStatisticalNucleus.cc.

2195 {
2196
2197 out<<" #################################################### "<<std::endl;
2198 out<<" THERMAL PRIMARY TRANSITIONS"<<std::endl;
2199 out<<" "<<NLevelsBelowThermalCaptureLevel<<std::endl;
2200 if(theThermalCaptureLevelCumulBR!=0){
2201 out<<" "<<0<<" "<<theLevels[0].Energy<<" "<<Sn-theLevels[0].Energy<<" "<<theThermalCaptureLevelCumulBR[0]<<std::endl;
2202 for(G4int i=1;i<NLevelsBelowThermalCaptureLevel;i++){
2203 out<<" "<<i<<" "<<theLevels[i].Energy<<" "<<Sn-theLevels[i].Energy<<" "<<theThermalCaptureLevelCumulBR[i]-theThermalCaptureLevelCumulBR[i-1]<<std::endl;
2204 }
2205 }
2206 out<<" #################################################### "<<std::endl;
2207
2208 G4double ThresholdIntensity=0.01;
2209 out<<" #################################################### "<<std::endl;
2210 out<<" STRONGEST THERMAL PRIMARY TRANSITIONS"<<std::endl;
2211 out<<" "<<NLevelsBelowThermalCaptureLevel<<std::endl;
2212 if(theThermalCaptureLevelCumulBR!=0){
2213 if(theThermalCaptureLevelCumulBR[0]>ThresholdIntensity){out<<" "<<0<<" "<<theLevels[0].Energy<<" "<<Sn-theLevels[0].Energy<<" "<<theThermalCaptureLevelCumulBR[0]<<std::endl;}
2214 for(G4int i=1;i<NLevelsBelowThermalCaptureLevel;i++){
2215 if(theThermalCaptureLevelCumulBR[i]-theThermalCaptureLevelCumulBR[i-1]>ThresholdIntensity){out<<" "<<i<<" "<<theLevels[i].Energy<<" "<<Sn-theLevels[i].Energy<<" "<<theThermalCaptureLevelCumulBR[i]-theThermalCaptureLevelCumulBR[i-1]<<std::endl;}
2216 }
2217 }
2218 out<<" #################################################### "<<std::endl;
2219}

Referenced by PrintAll().

◆ PrintTotalCumulBR()

void G4NuDEXStatisticalNucleus::PrintTotalCumulBR ( G4int i_level,
std::ostream & out )

Definition at line 2221 of file G4NuDEXStatisticalNucleus.cc.

2221 {
2222
2223 if(TotalCumulBR[i_level]!=0){
2224 out<<" #################################################### "<<std::endl;
2225 out<<" CUMULBR FROM LEVEL "<<i_level<<" with ENERGY "<<theLevels[i_level].Energy<<std::endl;
2226 for(G4int i=0;i<i_level;i++){
2227 out<<theLevels[i].Energy<<" "<<theLevels[i].spinx2/2.<<" "<<theLevels[i].parity<<" "<<TotalCumulBR[i_level][i]<<std::endl;
2228 }
2229 out<<" #################################################### "<<std::endl;
2230 }
2231
2232}

◆ SetBandWidth()

void G4NuDEXStatisticalNucleus::SetBandWidth ( G4double bandWidth)
inline

Definition at line 125 of file G4NuDEXStatisticalNucleus.hh.

125{ if(bandWidth==0){bandWidth=-1;} BandWidth=bandWidth;} //So it is not re-written with the lib-params.

◆ SetBrOption()

void G4NuDEXStatisticalNucleus::SetBrOption ( G4int BrOption)
inline

Definition at line 126 of file G4NuDEXStatisticalNucleus.hh.

126{BROpt=BrOption;}

◆ SetInitialParameters02()

void G4NuDEXStatisticalNucleus::SetInitialParameters02 ( G4int knownLevelsFlag = -1,
G4int electronConversionFlag = -1,
G4double primGamNormFactor = -1,
G4double primGamEcut = -1,
G4double ecrit = -1 )

Definition at line 99 of file G4NuDEXStatisticalNucleus.cc.

99 {
100 if(hasBeenInitialized){
101 //std::cout<<" ############## Error: G4NuDEXStatisticalNucleus::SetInitialParameters02 cannot be used after initializing the nucleus ##############"<<std::endl;
102 NuDEXException(__FILE__,std::to_string(__LINE__).c_str(),"##### Error in NuDEX #####");
103 }
104 if(knownLevelsFlag>=0){KnownLevelsFlag=knownLevelsFlag;}
105 if(electronConversionFlag>=0){ElectronConversionFlag=electronConversionFlag;}
106 if(primGamNormFactor>=0){PrimaryGammasIntensityNormFactor=primGamNormFactor;}
107 if(primGamEcut>=0){PrimaryGammasEcut=primGamEcut;}
108 if(ecrit>=0){Ecrit=ecrit;}
109
110}

◆ SetRandom1Seed()

void G4NuDEXStatisticalNucleus::SetRandom1Seed ( unsigned int seed)
inline

Definition at line 127 of file G4NuDEXStatisticalNucleus.hh.

127{theRandom1->SetSeed(seed); Rand1seedProvided=true;}

◆ SetRandom2Seed()

void G4NuDEXStatisticalNucleus::SetRandom2Seed ( unsigned int seed)
inline

Definition at line 128 of file G4NuDEXStatisticalNucleus.hh.

128{theRandom2->SetSeed(seed); Rand2seedProvided=true;}

◆ SetRandom3Seed()

void G4NuDEXStatisticalNucleus::SetRandom3Seed ( unsigned int seed)
inline

Definition at line 129 of file G4NuDEXStatisticalNucleus.hh.

129{theRandom3->SetSeed(seed); Rand3seedProvided=true;}

◆ SetSomeInitalParameters()

void G4NuDEXStatisticalNucleus::SetSomeInitalParameters ( G4int LDtype = -1,
G4int PSFFlag = -1,
G4double MaxSpin = -1,
G4int minlevelsperband = -1,
G4double BandWidth_MeV = 0,
G4double maxExcEnergy = 0,
G4int BrOption = -1,
G4int sampleGammaWidths = -1,
unsigned int aseed1 = 0,
unsigned int aseed2 = 0,
unsigned int aseed3 = 0 )

Definition at line 112 of file G4NuDEXStatisticalNucleus.cc.

112 {
113
114 if(hasBeenInitialized){
115 std::cout<<" ############## Error: G4NuDEXStatisticalNucleus::SetSomeInitalParameters cannot be used after initializing the nucleus ##############"<<std::endl;
116 NuDEXException(__FILE__,std::to_string(__LINE__).c_str(),"##### Error in NuDEX #####");
117 }
118
119 if(LDtype>0){LevelDensityType=LDtype;}
120 if(PSFFlag>=0){PSFflag=PSFFlag;}
121 if(MaxSpin>0){maxspinx2=(G4int)(2.*MaxSpin+0.01);}
122 if(minlevelsperband>0){MinLevelsPerBand=minlevelsperband;}
123 if(BandWidth_MeV!=0){BandWidth=BandWidth_MeV;}
124 if(maxExcEnergy!=0){MaxExcEnergy=maxExcEnergy;}
125 if(BrOption>0){BROpt=BrOption;}
126 if(sampleGammaWidths>=0){SampleGammaWidths=sampleGammaWidths;}
127 if(aseed1>0){seed1=aseed1; theRandom1->SetSeed(seed1); Rand1seedProvided=true;}
128 if(aseed2>0){seed2=aseed2; theRandom2->SetSeed(seed2); Rand2seedProvided=true;}
129 if(aseed3>0){seed3=aseed3; theRandom3->SetSeed(seed3); Rand3seedProvided=true;}
130
131}

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