44#ifndef G4VRadioactiveDecay_h
45#define G4VRadioactiveDecay_h 1
93 const G4Step& theStep)
override;
96 const G4Step& theStep)
override;
131 { theNucleusLimits = theNucleusLimits1; }
140 forceDecayDirection = theDir.
unit();
144 return forceDecayDirection;
148 forceDecayHalfAngle = std::min(std::max(0.*CLHEP::deg,halfAngle),180.*CLHEP::deg);
156 G4double halfAngle = 0.*CLHEP::deg) {
164 fThresholdForVeryLongDecayTime = std::max( 0.0, inputThreshold );
167 return fThresholdForVeryLongDecayTime;
213 G4bool isInitialised{
false};
222 static G4String dirPath;
225 static std::map<G4int, G4String>* theUserRDataFiles;
231 G4double fThresholdForVeryLongDecayTime;
G4double condition(const G4ErrorSymMatrix &m)
G4ParticleChangeForDecay G4ParticleChangeForRadDecay
std::map< G4String, G4DecayTable * > DecayTableMap
CLHEP::Hep3Vector G4ThreeVector
std::map< G4String, G4DecayTable * > DecayTableMap
void SetThresholdForVeryLongDecayTime(const G4double inputThreshold)
virtual G4VParticleChange * DecayIt(const G4Track &theTrack, const G4Step &theStep)
G4double GetThresholdForVeryLongDecayTime() const
~G4VRadioactiveDecay() override
G4ParticleChangeForRadDecay fParticleChangeForRadDecay
G4VRadioactiveDecay(const G4String &processName="RadioactiveDecay", const G4double timeThreshold=-1.0)
void DecayAnalog(const G4Track &theTrack, G4DecayTable *)
void AddUserDecayDataFile(G4int Z, G4int A, const G4String &filename)
G4VRadioactiveDecay & operator=(const G4VRadioactiveDecay &right)=delete
const G4ThreeVector & GetDecayDirection() const
G4PhotonEvaporation * photonEvaporation
void ProcessDescription(std::ostream &outFile) const override
G4DecayProducts * DoDecay(const G4ParticleDefinition &, G4DecayTable *)
void SetNucleusLimits(G4NucleusLimits theNucleusLimits1)
void BuildPhysicsTable(const G4ParticleDefinition &) override
std::vector< G4String > ValidVolumes
G4VParticleChange * AtRestDoIt(const G4Track &theTrack, const G4Step &theStep) override
void SetDecayHalfAngle(G4double halfAngle=0.*CLHEP::deg)
void SelectAVolume(const G4String &aVolume)
G4double GetMeanFreePath(const G4Track &theTrack, G4double previousStepSize, G4ForceCondition *condition) override
G4RadioactiveDecayMessenger * theRadioactiveDecayMessenger
void StreamInfo(std::ostream &os, const G4String &endline)
G4double GetDecayHalfAngle() const
void CollimateDecay(G4DecayProducts *products)
G4DecayTable * LoadDecayTable(const G4Ions *)
G4double GetMeanLifeTime(const G4Track &theTrack, G4ForceCondition *condition) override
G4NucleusLimits GetNucleusLimits() const
G4bool IsApplicable(const G4ParticleDefinition &) override
void SetDecayDirection(const G4ThreeVector &theDir)
G4ThreeVector ChooseCollimationDirection() const
static DecayTableMap * master_dkmap
static const G4double levelTolerance
G4VRadioactiveDecay(const G4VRadioactiveDecay &right)=delete
void DeselectAVolume(const G4String &aVolume)
void SetDecayCollimation(const G4ThreeVector &theDir, G4double halfAngle=0.*CLHEP::deg)
void DeselectAllVolumes()
G4DecayTable * GetDecayTable(const G4ParticleDefinition *)
G4VParticleChange * PostStepDoIt(const G4Track &theTrack, const G4Step &theStep) override
void CollimateDecayProduct(G4DynamicParticle *product)
G4VRestDiscreteProcess(const G4String &, G4ProcessType aType=fNotDefined)