61 oldMomentum(0.,0.,0.), previousMomentum(0.,0.,0.),
62 theGlobalNormal(0.,0.,0.), theFacetNormal(0.,0.,0.)
77 theParticleMomentum = 0.;
79 flag_franchissement_surface =
false;
81 flag_reflexion =
false;
82 teleportToDo = teleportDone =
false;
84 ekint = thetat = thetaft = energyThreshold = crossingProbability = 0.0;
176 material1 = pPreStepPoint -> GetMaterial();
177 material2 = pPostStepPoint -> GetMaterial();
184 previousMomentum = oldMomentum;
193 flag_franchissement_surface =
false;
194 flag_reflexion =
false;
200 if (material1 == material2)
212 G4cout <<
" Old Momentum Direction: " << oldMomentum <<
G4endl;
226 theGlobalNormal = -theGlobalNormal;
231 ed <<
" G4MicroElecSurface/PostStepDoIt(): "
232 <<
" The Navigator reports that it returned an invalid normal"
234 G4Exception(
"G4MuElecSurf::PostStepDoIt",
"OpBoun01",
236 "Invalid Surface Normal - Geometry must return valid surface normal");
240 if (oldMomentum * theGlobalNormal > 0.0)
242 theGlobalNormal = -theGlobalNormal;
247 if (flag_reflexion ==
true)
249 flag_reflexion =
false;
255 G4double energyThreshold_surface = 0.0*eV;
257 WorkFunctionTable::iterator postStepWF;
259 WorkFunctionTable::iterator preStepWF;
262 if (postStepWF == tableWF.end())
269 else if (preStepWF == tableWF.end())
278 G4double thresholdNew_surface = postStepWF->second;
279 G4double thresholdOld_surface = preStepWF->second;
280 energyThreshold_surface = thresholdNew_surface - thresholdOld_surface;
283 if (flag_franchissement_surface ==
true)
286 flag_franchissement_surface =
false;
288 if (flag_reflexion ==
true && flag_normal ==
true)
291 flag_reflexion =
false;
303 (pPreStepPoint ->GetPhysicalVolume(),
306 if (Surface ==
nullptr)
315 if(Surface ==
nullptr)
324 if(Surface ==
nullptr)
334 energyThreshold = 0.0*eV;
337 if ((thePrePV)&&(thePostPV))
339 WorkFunctionTable::iterator postStepWF;
341 WorkFunctionTable::iterator preStepWF;
344 if (postStepWF == tableWF.end())
351 else if (preStepWF == tableWF.end())
360 G4double thresholdNew = postStepWF->second;
361 G4double thresholdOld = preStepWF->second;
363 energyThreshold = thresholdNew - thresholdOld;
364 energyDelta = thresholdOld- thresholdNew;
369 thetat= GetIncidentAngle();
370 G4double ekinNormalt=ekint*std::cos(thetat)*std::cos(thetat);
372 thetaft=std::asin(std::sqrt(ekint/(ekint+energyThreshold))*std::sin(thetat));
373 if(std::sqrt(ekint/(ekint+energyThreshold))*std::sin(thetat)>1.0)
375 thetaft=std::asin(1.0);
380 G4double waveVectort=std::sqrt(2*9.1093826E-31*1.602176487E-19)/(6.6260755E-34/(2.0*pi));
385 crossingProbability=0;
387 G4double kft=waveVectort*std::sqrt(ekint+energyThreshold)*std::cos(thetaft);
388 G4double kit=waveVectort*std::sqrt(ekinNormalt);
390 crossingProbability=1-(std::pow(std::sinh(pi*at*(kit-kft)), 2.0)/std::pow(std::sinh(pi*at*(kit+kft)), 2.0));
393 if((aleat<=crossingProbability)&&(ekint> energyDelta))
399 flag_franchissement_surface =
true;
402 thetaft=std::abs(thetaft-thetat);
408 G4double xDirt = std::sqrt(1. - std::cos(thetaft)*std::cos(thetaft));
411 G4ThreeVector zPrimeVerst=((xDirt*xVerst + yDirt*yVerst + std::cos(thetaft)*zVerst));
415 else if ((aleat > crossingProbability) && (ekint> energyDelta))
417 flag_reflexion =
true;
437 flag_reflexion =
true;
const G4ThreeVector & GetMomentumDirection() const
G4double GetTotalMomentum() const