147 using namespace CLHEP;
152 #ifdef G4MULTITHREADED
160 forceDecayDirection(0.,0.,0.), forceDecayHalfAngle(0.*
deg), verboseLevel(0)
164 G4cout <<
"G4RadioactiveDecay constructor: processName = " << processName
178 #ifdef G4MULTITHREADED
179 G4AutoLock lk(&G4RadioactiveDecay::radioactiveDecayMutex);
215 for (DecayTableMap::iterator i =
dkmap->begin(); i !=
dkmap->end(); i++) {
226 if (((
const G4Ions*)(&aParticle))->GetExcitationEnergy() > 0.) {
return true;}
235 G4int A = ((
const G4Ions*) (&aParticle))->GetAtomicMass();
236 G4int Z = ((
const G4Ions*) (&aParticle))->GetAtomicNumber();
248 DecayTableMap::iterator table_ptr =
dkmap->find(key);
251 if (table_ptr ==
dkmap->end() ) {
253 if(theDecayTable) (*dkmap)[key] = theDecayTable;
255 theDecayTable = table_ptr->second;
258 return theDecayTable;
267 for (
size_t i = 0; i < theLogicalVolumes->size(); i++) {
268 volume=(*theLogicalVolumes)[i];
269 if (volume->
GetName() == aVolume) {
277 }
else if(i == theLogicalVolumes->size()) {
278 G4cerr <<
"SelectAVolume: "<< aVolume
279 <<
" is not a valid logical volume name" <<
G4endl;
290 for (
size_t i = 0; i < theLogicalVolumes->size(); i++){
291 volume=(*theLogicalVolumes)[i];
292 if (volume->
GetName() == aVolume) {
293 std::vector<G4String>::iterator location;
300 G4cerr <<
" DeselectVolume:" << aVolume <<
" is not in the list "
305 G4cout <<
" DeselectVolume: " << aVolume <<
" is removed from list "
308 }
else if (i == theLogicalVolumes->size()) {
309 G4cerr <<
" DeselectVolume:" << aVolume
310 <<
"is not a valid logical volume name" <<
G4endl;
326 for (
size_t i = 0; i < theLogicalVolumes->size(); i++){
327 volume = (*theLogicalVolumes)[i];
377 G4cout <<
"The DecayRate Table for " << aParticleName <<
" is selected."
392 long double convolvedTime = 0.L;
401 ed <<
" While count exceeded " <<
G4endl;
402 while (t >
SBin[nbin]) {
405 G4Exception(
"G4RadioactiveDecay::ConvolveSourceTimeProfile()",
415 long double ltau = tau;
418 for (
G4int i = 0; i < nbin; i++) {
419 convolvedTime += (
long double)
SProfile[i] *
420 (std::exp(-(lt-(
long double)
SBin[i+1])/ltau)-std::exp(-(lt-(
long double)
SBin[i])/ltau));
423 convolvedTime += (
long double)
SProfile[nbin] * (1.
L-std::exp(-(lt-(
long double)
SBin[nbin])/ltau));
427 if (convolvedTime < 0.) {
428 G4cout <<
" Convolved time =: " << convolvedTime <<
" reset to zero! " <<
G4endl;
435 G4cout <<
" Convolved time: " << convolvedTime <<
G4endl;
566 ed <<
" While count exceeded " <<
G4endl;
580 G4cout <<
" Decay time: " <<decaytime/
s <<
"[s]" <<G4endl;
592 ed <<
" While count exceeded " <<
G4endl;
593 while ( aDecayTime >
DBin[i] ) {
625 G4cout <<
"G4RadioactiveDecay::GetMeanLifeTime() " <<
G4endl;
627 <<
" GeV, Mass: " << theParticle->
GetMass()/
GeV
628 <<
" GeV, Life time: " << theLife/
ns <<
" ns " <<
G4endl;
632 else if (theLife < 0.0) {meanlife =
DBL_MAX;}
633 else {meanlife = theLife;}
636 if (((
const G4Ions*)(theParticleDef))->GetExcitationEnergy() > 0. &&
637 meanlife ==
DBL_MAX) {meanlife = 0.;}
641 G4cout <<
" mean life time: " << meanlife/
s <<
" s " <<
G4endl;
663 G4cout <<
"G4RadioactiveDecay::GetMeanFreePath() " <<
G4endl;
665 <<
" GeV, Mass: " << aMass/
GeV <<
" GeV, tau: " << tau <<
" ns "
676 }
else if (tau < 0.0) {
679 ed <<
"Ion has negative lifetime " << tau
680 <<
" but is not stable. Setting mean free path to DBL_MAX" <<
G4endl;
681 G4Exception(
"G4RadioactiveDecay::GetMeanFreePath()",
"HAD_RDM_011",
688 pathlength = c_light*tau*betaGamma;
694 G4cout <<
"G4Decay::GetMeanFreePath: "
696 <<
" stops, kinetic energy = "
706 G4cout <<
"mean free path: "<< pathlength/
m <<
" m" <<
G4endl;
726 ed <<
" Atomic deexcitation is not defined.";
727 G4Exception(
"G4RadioactiveDecay::BuildPhysicsTable",
"HAD_RDM_001",
752 G4int A = ((
const G4Ions*)(&theParentNucleus))->GetAtomicMass();
753 G4int Z = ((
const G4Ions*)(&theParentNucleus))->GetAtomicNumber();
755 G4double levelEnergy = ((
const G4Ions*)(&theParentNucleus))->GetExcitationEnergy();
757 ((
const G4Ions*)(&theParentNucleus))->GetFloatLevelBase();
759 #ifdef G4MULTITHREADED
760 G4AutoLock lk(&G4RadioactiveDecay::radioactiveDecayMutex);
763 DecayTableMap::iterator master_table_ptr = master_dkmap->find(key);
765 if (master_table_ptr != master_dkmap->end() ) {
766 return master_table_ptr->second;
774 if (!getenv(
"G4RADIOACTIVEDATA") ) {
775 G4cout <<
"Please setenv G4RADIOACTIVEDATA to point to the radioactive decay data files."
777 throw G4HadronicException(__FILE__, __LINE__,
" Please setenv G4RADIOACTIVEDATA to point to the radioactive decay data files.");
779 G4String dirName = getenv(
"G4RADIOACTIVEDATA");
781 std::ostringstream os;
782 os << dirName <<
"/z" << Z <<
".a" << A <<
'\0';
789 std::ifstream DecaySchemeFile;
790 DecaySchemeFile.open(file);
792 if (DecaySchemeFile.good()) {
795 const G4int nMode = 9;
796 G4double modeTotalBR[nMode] = {0.0};
798 for (
G4int i = 0; i < nMode; i++) {
802 char inputChars[120]={
' '};
824 ed <<
" While count exceeded " <<
G4endl;
826 while (!complete && !DecaySchemeFile.getline(inputChars, 120).eof()) {
833 inputLine = inputChars;
834 inputLine = inputLine.
strip(1);
835 if (inputChars[0] !=
'#' && inputLine.length() != 0) {
836 std::istringstream tmpStream(inputLine);
838 if (inputChars[0] ==
'P') {
841 tmpStream >> recordType >> parentExcitation >> floatingFlag >> dummy;
850 if (floatingLevel !=
noFloat) {
853 if (!floatMatch) found =
false;
862 if (inputLine.length() < 72) {
863 tmpStream >> theDecayMode >> dummy >> decayModeTotal;
864 switch (theDecayMode) {
871 theDecayTable->
Insert(anITChannel);
876 modeTotalBR[1] = decayModeTotal;
break;
878 modeTotalBR[2] = decayModeTotal;
break;
880 modeTotalBR[3] = decayModeTotal;
break;
882 modeTotalBR[4] = decayModeTotal;
break;
884 modeTotalBR[5] = decayModeTotal;
break;
886 modeTotalBR[6] = decayModeTotal;
break;
888 modeTotalBR[7] = decayModeTotal;
break;
890 modeTotalBR[8] = decayModeTotal;
break;
908 G4Exception(
"G4RadioactiveDecay::LoadDecayTable()",
"HAD_RDM_000",
913 if (inputLine.length() < 84) {
914 tmpStream >> theDecayMode >> a >> daughterFloatFlag >> b >> c;
917 tmpStream >> theDecayMode >> a >> daughterFloatFlag >> b >> c >> betaType;
926 switch (theDecayMode) {
931 daughterFloatLevel, betaType);
934 theDecayTable->
Insert(aBetaMinusChannel);
943 daughterFloatLevel, betaType);
946 theDecayTable->
Insert(aBetaPlusChannel);
959 theDecayTable->
Insert(aKECChannel);
972 theDecayTable->
Insert(aLECChannel);
985 theDecayTable->
Insert(aMECChannel);
997 theDecayTable->
Insert(anAlphaChannel);
1006 daughterFloatLevel);
1009 theDecayTable->
Insert(aProtonChannel);
1018 daughterFloatLevel);
1021 theDecayTable->
Insert(aNeutronChannel);
1057 G4Exception(
"G4RadioactiveDecay::LoadDecayTable()",
"HAD_RDM_000",
1075 theNuclearDecayChannel =
static_cast<G4NuclearDecay*
>(theChannel);
1078 if (theDecayMode !=
IT) {
1079 theBR = theChannel->
GetBR();
1080 theChannel->
SetBR(theBR*modeTotalBR[theDecayMode]/modeSumBR[theDecayMode]);
1085 DecaySchemeFile.close();
1087 if (!found && levelEnergy > 0) {
1093 theDecayTable->
Insert(anITChannel);
1100 #ifdef G4MULTITHREADED
1103 return theDecayTable;
1109 if (Z < 1 || A < 2)
G4cout <<
"Z and A not valid!" <<
G4endl;
1111 std::ifstream DecaySchemeFile(filename);
1112 if (DecaySchemeFile) {
1113 G4int ID_ion = A*1000 + Z;
1116 G4cout <<
"The file " << filename <<
" does not exist!" <<
G4endl;
1123 G4int theG, std::vector<G4double> theCoefficients,
1124 std::vector<G4double> theTaos)
1149 G4int nGeneration = 0;
1151 std::vector<G4double> taos;
1154 std::vector<G4double> Acoeffs;
1157 Acoeffs.push_back(-1.);
1159 G4int A = ((
const G4Ions*)(&theParentNucleus))->GetAtomicMass();
1160 G4int Z = ((
const G4Ions*)(&theParentNucleus))->GetAtomicNumber();
1161 G4double E = ((
const G4Ions*)(&theParentNucleus))->GetExcitationEnergy();
1163 if (tao < 0.) tao = 1e-100;
1164 taos.push_back(tao);
1195 std::vector<G4double> TP;
1196 std::vector<G4double> RP;
1200 G4int nearestLevelIndex = 0;
1208 const G4int nMode = 9;
1216 ed <<
" While count exceeded " <<
G4endl;
1225 for (j = nS; j < nT; j++) {
1233 G4cout <<
"G4RadioactiveDecay::AddDecayRateTable : daughters of ("
1234 << ZP <<
", " << AP <<
", " << EP
1235 <<
") are being calculated, generation = " << nGeneration
1239 aParentNucleus = theIonTable->
GetIon(ZP,AP,EP);
1252 for (
G4int k = 0; k < nMode; k++) brs[k] = 0.0;
1255 for (i = 0; i < parentDecayTable->
entries(); i++) {
1257 theNuclearDecayChannel =
static_cast<G4NuclearDecay*
>(theChannel);
1262 AD = ((
const G4Ions*)(theDaughterNucleus))->GetAtomicMass();
1263 ZD = ((
const G4Ions*)(theDaughterNucleus))->GetAtomicNumber();
1269 if (std::abs(daughterExcitation - nearestEnergy) <
levelTolerance) {
1275 summedDecayTable->
Insert(theChannel);
1277 brs[theDecayMode] += theChannel->
GetBR();
1280 brs[theDecayMode] += theChannel->
GetBR();
1283 brs[theDecayMode] += theChannel->
GetBR();
1287 brs[2] = brs[2]+brs[3]+brs[4]+brs[5];
1288 brs[3] = brs[4] =brs[5] = 0.0;
1289 for (i= 0; i<nMode; i++){
1294 theITChannel =
new G4ITDecay(aParentNucleus, brs[0], 0.0, 0.0);
1296 summedDecayTable->
Insert(theITChannel);
1304 summedDecayTable->
Insert(theBetaMinusChannel);
1312 summedDecayTable->
Insert(theBetaPlusChannel);
1319 summedDecayTable->
Insert(theAlphaChannel);
1326 summedDecayTable->
Insert(theProtonChannel);
1332 summedDecayTable->
Insert(theNeutronChannel);
1342 for (i = 0; i < summedDecayTable->
entries(); i++){
1344 theNuclearDecayChannel =
static_cast<G4NuclearDecay*
>(theChannel);
1345 theBR = theChannel->
GetBR();
1350 if (theNuclearDecayChannel->
GetDecayMode() ==
IT && nGeneration == 1) {
1352 A = ((
const G4Ions*)(theDaughterNucleus))->GetAtomicMass();
1353 Z = ((
const G4Ions*)(theDaughterNucleus))->GetAtomicNumber();
1354 theDaughterNucleus=theIonTable->
GetIon(Z,A,0.);
1357 aParentNucleus != theDaughterNucleus) {
1361 if (parentDecayTable->
entries() ) {
1362 A = ((
const G4Ions*)(theDaughterNucleus))->GetAtomicMass();
1363 Z = ((
const G4Ions*)(theDaughterNucleus))->GetAtomicNumber();
1364 E = ((
const G4Ions*)(theDaughterNucleus))->GetExcitationEnergy();
1367 if (TaoPlus <= 0.) TaoPlus = 1e-100;
1377 taos.push_back(TaoPlus);
1383 long double ta1,ta2;
1384 ta2 = (
long double)TaoPlus;
1385 for (k = 0; k < RP.size(); k++){
1386 ta1 = (
long double)TP[k];
1390 theRate = ta1/(ta1-ta2);
1392 theRate = theRate * theBR * RP[k];
1393 Acoeffs.push_back(theRate);
1400 long double aRate, aRate1;
1402 for (k = 0; k < RP.size(); k++){
1403 ta1 = (
long double)TP[k];
1407 aRate = ta2/(ta1-ta2);
1409 aRate = aRate * (
long double)(theBR * RP[k]);
1413 Acoeffs.push_back(theRate);
1425 if (nS == nT) stable =
true;
1452 std::ifstream infile ( filename, std::ios::in );
1455 ed <<
" Could not open file " << filename <<
G4endl;
1456 G4Exception(
"G4RadioactiveDecay::SetSourceTimeProfile()",
"HAD_RDM_001",
1465 ed <<
" While count exceeded " <<
G4endl;
1467 while (infile >> bin >> flux ) {
1476 G4Exception(
"G4RadioactiveDecay::SetSourceTimeProfile()",
"HAD_RDM_002",
1503 std::ifstream infile(filename, std::ios::in);
1504 if (!infile)
G4Exception(
"G4RadioactiveDecay::SetDecayBias()",
"HAD_RDM_003",
1517 ed <<
" While count exceeded " <<
G4endl;
1519 while (infile >> bin >> flux ) {
1528 G4Exception(
"G4RadioactiveDecay::SetDecayBias()",
"HAD_RDM_004",
1575 G4cout <<
"G4RadioactiveDecay::DecayIt : "
1577 <<
" is not selected for the RDM"<<
G4endl;
1600 G4cerr <<
"G4RadioactiveDecay::DecayIt : "
1602 <<
" is not a valid nucleus for the RDM"<<
G4endl;
1615 if (theDecayTable == 0 || theDecayTable->
entries() == 0) {
1620 G4cerr <<
"G4RadioactiveDecay::DecayIt : decay table not defined for ";
1652 if ( products->
entries() == 1) {
1681 if (temptime < 0.) temptime = 0.;
1682 finalGlobalTime += temptime;
1683 finalLocalTime += temptime;
1686 products->
Boost(ParentEnergy, ParentDirection);
1693 G4cout <<
"G4RadioactiveDecay::DecayIt : Decay vertex :";
1694 G4cout <<
" Time: " <<finalGlobalTime/
ns <<
"[ns]";
1699 G4cout <<
"G4Decay::DecayIt : decay products in Lab. Frame" <<
G4endl;
1704 for (index=0; index < numberOfSecondaries; index++) {
1706 finalGlobalTime, currentPosition);
1718 G4cout <<
"DecayIt: Variance Reduction version " <<
G4endl;
1735 std::vector<G4double> PT;
1736 std::vector<G4double> PR;
1738 long double decayRate;
1742 G4int numberOfSecondaries;
1743 G4int totalNumberOfSecondaries = 0;
1747 std::vector<G4DynamicParticle*> secondaryparticles;
1748 std::vector<G4double> pw;
1749 std::vector<G4double> ptime;
1765 }
else if (nbin > 1) {
1790 for (j = 0; j < PT.size(); j++) {
1793 decayRate -= PR[j] * (
long double)taotime;
1815 parentNucleus = theIonTable->
GetIon(PZ,PA,PE);
1827 if (theDecayChannel == 0) {
1831 G4cerr <<
" G4RadioactiveDecay::DoIt : cannot determine decay channel ";
1832 G4cerr <<
" for this nucleus; decay as if no biasing active ";
1837 tempprods =
DoDecay(*parentNucleus);
1842 tempprods = theDecayChannel->DecayIt(tempmass);
1843 weight *= (theDecayChannel->GetBR())*(decayTable->
entries());
1846 tempprods =
DoDecay(*parentNucleus);
1851 numberOfSecondaries = tempprods->
entries();
1852 currentTime = finalGlobalTime + theDecayTime;
1853 for (index = 0; index < numberOfSecondaries; index++) {
1856 pw.push_back(weight);
1857 ptime.push_back(currentTime);
1858 secondaryparticles.push_back(asecondaryparticle);
1861 else if (((
const G4Ions*)(asecondaryparticle->
GetDefinition()))->GetExcitationEnergy()>0. && weight>0.){
1873 totalNumberOfSecondaries = pw.size();
1875 for (index=0; index < totalNumberOfSecondaries; index++) {
1877 ptime[index], currentPosition);
1919 if (theDecayChannel == 0) {
1923 G4Exception(
"G4RadioactiveDecay::DoDecay",
"HAD_RDM_013",
1929 G4cerr <<
"G4RadioactiveDecay::DoIt : selected decay channel addr:";
1948 if (0 == products || 0 == products->
entries())
return;
1967 if (daughterType == electron || daughterType == positron ||
1968 daughterType == neutron || daughterType == gamma ||
1976 G4cout <<
"CollimateDecayProduct for daughter "
2001 dir.setPhi(dir.phi()+phi);
2002 dir.setTheta(dir.theta()+std::acos(cosTheta));
2007 G4cout <<
" ChooseCollimationDirection returns " << dir <<
G4endl;
2016 std::vector<double>& weights_v,
2017 std::vector<double>& times_v,
2018 std::vector<G4DynamicParticle*>& secondaries_v)
2020 G4double elevel=((
const G4Ions*)(apartDef))->GetExcitationEnergy();
2022 while (life_time <halflifethreshold && elevel>0.) {
2026 for (
G4int ind = 0; ind < nb_pevapSecondaries; ind++) {
2030 weights_v.push_back(weight);
2031 times_v.push_back(currentTime);
2032 secondaries_v.push_back(a_pevap_secondary);
2037 elevel=((
const G4Ions*)(apartDef))->GetExcitationEnergy();
G4double halflifethreshold
G4RadioactiveDecayRateVector theDecayRateTable
G4DecayProducts * DoDecay(const G4ParticleDefinition &theParticleDef)
void SetBR(G4double value)
static G4LossTableManager * Instance()
G4double GetLocalTime() const
void SelectAVolume(const G4String aVolume)
std::map< G4String, G4DecayTable * > DecayTableMap
std::ostringstream G4ExceptionDescription
static constexpr double s
G4double GetKineticEnergy() const
CLHEP::Hep3Vector G4ThreeVector
G4bool IsRateTableReady(const G4ParticleDefinition &)
const G4DynamicParticle * GetDynamicParticle() const
void SetHLThreshold(G4double HLT)
std::vector< G4String > ValidVolumes
void SetARM(G4bool onoff)
G4double ConvolveSourceTimeProfile(const G4double, const G4double)
std::vector< ExP01TrackerHit * > a
void SetTaos(std::vector< G4double > value)
G4String strip(G4int strip_Type=trailing, char c=' ')
void SetDecayRateC(std::vector< G4double > value)
const G4LevelManager * GetLevelManager(G4int Z, G4int A)
G4float LifeTime(size_t i) const
G4bool GetPDGStable() const
G4ParticleDefinition * GetIon(G4int Z, G4int A, G4int lvl=0)
static G4Alpha * Definition()
const G4ThreeVector & GetPosition() const
void AddSecondary(G4Track *aSecondary)
G4TrackStatus GetTrackStatus() const
G4RadioactiveDecayMode GetDecayMode()
G4RadioactiveDecayRates theDecayRateVector
static G4Electron * Definition()
void SetTouchableHandle(const G4TouchableHandle &apValue)
G4VDecayChannel * GetDecayChannel(G4int index) const
G4double GetMeanLifeTime(const G4Track &theTrack, G4ForceCondition *condition)
G4int GetVerboseLevel() const
void SetMomentumDirection(const G4ThreeVector &aDirection)
virtual G4DecayProducts * DecayIt(G4double)
G4ParticleDefinition * GetDefinition() const
void SetSourceTimeProfile(G4String filename)
G4bool IsApplicable(const G4ParticleDefinition &)
void Boost(G4double totalEnergy, const G4ThreeVector &momentumDirection)
void SetGeneration(G4int value)
static G4Positron * Definition()
void ClearNumberOfInteractionLengthLeft()
static constexpr double nanosecond
#define G4MUTEX_INITIALIZER
const G4String & GetParticleName() const
void SetWeight(G4double aValue)
void ProposeLocalEnergyDeposit(G4double anEnergyPart)
void SetItsRates(G4RadioactiveDecayRates arate)
G4ParticleChangeForRadDecay fParticleChangeForRadDecay
G4double GetTotalMomentum() const
static G4Proton * Definition()
virtual void Initialize(const G4Track &)
G4IonTable * GetIonTable() const
static G4Ions::G4FloatLevelBase FloatLevelBase(char flbChar)
G4GLOB_DLL std::ostream G4cout
double A(double temperature)
void ProposeLocalTime(G4double t)
static constexpr double m
static const G4ThreeVector origin
void SetDecayRate(G4int, G4int, G4double, G4int, std::vector< G4double >, std::vector< G4double >)
const G4ThreeVector & GetMomentumDirection() const
void CollimateDecayProduct(G4DynamicParticle *product)
G4VDecayChannel * SelectADecayChannel(G4double parentMass=-1.)
static constexpr double cm
static G4LogicalVolumeStore * GetInstance()
G4ThreeVector ChooseCollimationDirection() const
size_t NumberOfTransitions() const
G4int GetDecayTimeBin(const G4double aDecayTime)
void SetProcessSubType(G4int)
void DeselectAllVolumes()
const G4String & GetParticleType() const
const G4ParticleDefinition * GetParticleDefinition() const
G4double GetGlobalTime() const
G4float NearestLevelEnergy(G4double energy, size_t index=0) const
G4NucleusLimits theNucleusLimits
const G4TouchableHandle & GetTouchableHandle() const
G4ParticleDefinition * GetDaughterNucleus()
size_t NearestLevelIndex(G4double energy, size_t index=0) const
G4DecayTable * GetDecayTable(const G4ParticleDefinition *)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
void Insert(G4VDecayChannel *aChannel)
G4double GetDaughterExcitation()
void SetARM(G4bool onoff)
G4double GetMeanFreePath(const G4Track &theTrack, G4double previousStepSize, G4ForceCondition *condition)
G4RadioactiveDecayRate theDecayRate
static const G4double levelTolerance
G4RadioactiveDecayRateTable theDecayRateTableVector
std::map< G4int, G4String > theUserRadioactiveDataFiles
G4LogicalVolume * GetLogicalVolume() const
G4double forceDecayHalfAngle
G4double GetPDGMass() const
static G4ParticleTable * GetParticleTable()
void GetDecayRateTable(const G4ParticleDefinition &)
G4RadioactiveDecaymessenger * theRadioactiveDecaymessenger
void SetNumberOfSecondaries(G4int totSecondaries)
G4DynamicParticle * PopProducts()
G4VParticleChange * pParticleChange
void AddDecayRateTable(const G4ParticleDefinition &)
G4DecayTable * LoadDecayTable(const G4ParticleDefinition &theParentNucleus)
static G4Neutron * Definition()
static constexpr double GeV
G4VPhysicalVolume * GetVolume() const
std::vector< G4RadioactivityTable * > theRadioactivityTables
G4double GetWeight() const
void SetIonName(G4String name)
G4double GetPDGLifeTime() const
G4RadioactiveDecay(const G4String &processName="RadioactiveDecay")
static constexpr double MeV
G4ThreeVector forceDecayDirection
static constexpr double pi
G4VAtomDeexcitation * AtomDeexcitation()
virtual G4DecayProducts * DecayIt(G4double parentMass=-1.0)=0
const G4String & GetName() const
void ProposeTrackStatus(G4TrackStatus status)
void BuildPhysicsTable(const G4ParticleDefinition &)
static constexpr double deg
static constexpr double L
void SetAnalogueMonteCarlo(G4bool r)
static const G4double alpha
void DeselectAVolume(const G4String aVolume)
static constexpr double keV
void AddDeexcitationSpectrumForBiasMode(G4ParticleDefinition *apartDef, G4double weight, G4double currenTime, std::vector< double > &weights_v, std::vector< double > ×_v, std::vector< G4DynamicParticle * > &secondaries_v)
void SetE(G4double value)
static G4NuclearLevelData * GetInstance()
void AddUserDecayDataFile(G4int Z, G4int A, G4String filename)
void CollimateDecay(G4DecayProducts *products)
void SetDecayBias(G4String filename)
static G4Gamma * Definition()
void SetGoodForTrackingFlag(G4bool value=true)
G4VParticleChange * DecayIt(const G4Track &theTrack, const G4Step &theStep)
G4GLOB_DLL std::ostream G4cerr
G4int GetBaryonNumber() const