167{
168 if (p != fParticle) { SetParticle(p); }
169
170
173 }
174
175
176 if (!isInitialised) {
177 isInitialised = true;
178 const G4String& pname = fParticle->GetParticleName();
179 if (pname == "proton") {
180 idx = 1;
181 xscurrent = xsdata[1];
182 fElow = fLowestEnergy;
183 } else if (pname == "hydrogen") {
184 idx = 0;
185 xscurrent = xsdata[0];
186 fElow = fLowestEnergy;
187 } else if (pname == "alpha") {
188 idx = 1;
189 xscurrent = xsdata[2];
190 isHelium = true;
191 fElow = fLimitEnergy;
192 } else if (pname == "alpha+") {
193 idx = 1;
194 isHelium = true;
195 xscurrent = xsalphaplus;
196 fElow = fLimitEnergy;
197
198 slaterEffectiveCharge[0]=2.0;
199 slaterEffectiveCharge[1]=2.0;
200 slaterEffectiveCharge[2]=2.0;
201 sCoefficient[0]=0.7;
202 sCoefficient[1]=0.15;
203 sCoefficient[2]=0.15;
204 } else if (pname == "helium") {
205 idx = 0;
206 isHelium = true;
207 fElow = fLimitEnergy;
208 xscurrent = xshelium;
209 slaterEffectiveCharge[0]=1.7;
210 slaterEffectiveCharge[1]=1.15;
211 slaterEffectiveCharge[2]=1.15;
212 sCoefficient[0]=0.5;
213 sCoefficient[1]=0.25;
214 sCoefficient[2]=0.25;
215 } else {
216 isIon = true;
217 idx = -1;
218 xscurrent = xsdata[1];
219 fElow = fLowestEnergy;
220 }
221
223
224
226
227 if (verbose > 0) {
228 G4cout <<
"### G4DNARuddIonisationExtendedModel::Initialise(..) " << pname
229 << "/n idx=" << idx << " isIon=" << isIon
230 <<
" isHelium=" << isHelium <<
G4endl;
231 }
232 }
233}
G4ParticleChangeForGamma * fParticleChangeForGamma
static G4EmParameters * Instance()
G4bool DNAStationary() const
G4VAtomDeexcitation * AtomDeexcitation()
G4ParticleChangeForGamma * GetParticleChangeForGamma()