83{
84
85
86
87
88
89
90 fParticleChangeForDecay.Initialize(aTrack);
91
92
94
95
97 G4bool isPreAssigned = (o_products !=
nullptr);
98 G4DecayProducts* products = nullptr;
99
100 if (!isPreAssigned ){
101 fParticleChangeForDecay.SetNumberOfSecondaries(0);
102
103 fParticleChangeForDecay.ProposeTrackStatus(
fStopAndKill ) ;
104 fParticleChangeForDecay.ProposeLocalEnergyDeposit(0.0);
105
107 return &fParticleChangeForDecay ;
108 }
109
110
111 products = new G4DecayProducts(*o_products);
112
113
116 if (ParentEnergy < ParentMass) {
117 ParentEnergy = ParentMass;
118#ifdef G4VERBOSE
120 G4cout <<
"G4UnknownDecay::DoIt : Total Energy is less than its mass" <<
G4endl;
122 G4cout <<
" Energy:" << ParentEnergy/MeV <<
"[MeV]";
123 G4cout <<
" Mass:" << ParentMass/MeV <<
"[MeV]";
125 }
126#endif
127 }
129
132
133
135 products->
Boost( ParentEnergy, ParentDirection);
136 }
137
138
140 fParticleChangeForDecay.SetNumberOfSecondaries(numberOfSecondaries);
141#ifdef G4VERBOSE
143 G4cout <<
"G4UnknownDecay::DoIt : Decay vertex :";
144 G4cout <<
" Time: " << finalGlobalTime/
ns <<
"[ns]";
149 G4cout <<
"G4UnknownDecay::DoIt : decay products in Lab. Frame" <<
G4endl;
151 }
152#endif
156 for (index=0; index < numberOfSecondaries; index++){
157
159
160 G4Track* secondary =
new G4Track( products->
PopProducts(),
161 finalGlobalTime ,
162 currentPosition );
163
166
167 fParticleChangeForDecay.AddSecondary(secondary);
168 }
169 delete products;
170
171
172 fParticleChangeForDecay.ProposeTrackStatus(
fStopAndKill ) ;
173 fParticleChangeForDecay.ProposeLocalEnergyDeposit(energyDeposit);
174 fParticleChangeForDecay.ProposeGlobalTime( finalGlobalTime );
175
177
178 return &fParticleChangeForDecay ;
179}
CLHEP::Hep3Vector G4ThreeVector
G4ReferenceCountedHandle< G4VTouchable > G4TouchableHandle
G4DynamicParticle * PopProducts()
void Boost(G4double totalEnergy, const G4ThreeVector &momentumDirection)
const G4ThreeVector & GetMomentumDirection() const
const G4DecayProducts * GetPreAssignedDecayProducts() const
G4ParticleDefinition * GetDefinition() const
G4double GetTotalEnergy() const
G4double GetPreAssignedDecayProperTime() const
const G4String & GetParticleName() const
const G4ThreeVector & GetPosition() const
void SetTouchableHandle(const G4TouchableHandle &apValue)
G4double GetGlobalTime() const
const G4DynamicParticle * GetDynamicParticle() const
const G4TouchableHandle & GetTouchableHandle() const
void SetGoodForTrackingFlag(G4bool value=true)
void ClearNumberOfInteractionLengthLeft()