116{
117
118 theTotalResult->Initialize(track);
119
120 G4Nucleus* nucleus = &targetNucleus;
121
122
123
124 fElementSelector->SelectZandA(track, nucleus);
125
126 thePro.Initialise(track);
127
128
129 thePro.SetGlobalTime(0.0);
131
132
133
134
135
136 result = fEmCascade->ApplyYourself(thePro, *nucleus);
137 G4double ebound = result->GetLocalEnergyDeposit();
139 G4int nSecondaries = (
G4int)result->GetNumberOfSecondaries();
140 thePro.SetBoundEnergy(ebound);
141
142
143 ++nSecondaries;
144
148
149 G4DynamicParticle* dp =
new G4DynamicParticle(muonicAtom,
G4RandomDirection(),0.);
150 G4HadSecondary hadSec(dp);
151 hadSec.SetTime(time0);
152 result->AddSecondary(hadSec);
153
154
155
157 theTotalResult->ProposeLocalEnergyDeposit(edep);
158 theTotalResult->SetNumberOfSecondaries(nSecondaries);
160 theTotalResult->ProposeWeight(w);
161
162#ifdef G4VERBOSE
165 << " nSecondaries "
166 << nSecondaries
168 }
169#endif
170
171 for(
G4int i=0; i<nSecondaries; ++i) {
172 G4HadSecondary* sec = result->GetSecondary(i);
173
174
176 if(time < 0.0) { time = 0.0; }
177 time += time0;
178
179#ifdef G4VERBOSE
182 << " "
183 << i
184 << " Resulting secondary "
186 << " "
189 }
190#endif
191
192
194 time,
197
199 theTotalResult->AddSecondary(t);
200 }
201 result->Clear();
202
203
204
205
206
207 return theTotalResult;
208}
G4ThreeVector G4RandomDirection()
G4GLOB_DLL std::ostream G4cout
G4ParticleDefinition * GetDefinition() const
G4DynamicParticle * GetParticle()
G4double GetWeight() const
G4ParticleDefinition * GetMuonicAtom(G4Ions const *)
static G4IonTable * GetIonTable()
const G4String & GetParticleName() const
G4double GetWeight() const
void SetWeight(G4double aValue)
const G4ThreeVector & GetPosition() const
void SetTouchableHandle(const G4TouchableHandle &apValue)
G4double GetGlobalTime() const
const G4TouchableHandle & GetTouchableHandle() const
G4int GetVerboseLevel() const