48 fForceCollisionModelID(-1),
49 fCurrentTrackData(nullptr),
59 ed <<
" Particle `" << particleName <<
"' not found !" <<
G4endl;
60 G4Exception(
" G4BOptrForceCollision::G4BOptrForceCollision(...)",
70 fForceCollisionModelID(-1),
71 fCurrentTrackData(nullptr),
82 for ( std::map< const G4BiasingProcessInterface*, G4BOptnForceFreeFlight* >::iterator it =
fFreeFlightOperations.begin() ;
84 it++ )
delete (*it).second;
110 if ( interfaceProcessSharedData )
180 G4bool isFirstPhysGPIL = callingProcess-> GetIsFirstPostStepGPILInterface();
183 if ( isFirstPhysGPIL )
218 if ( isFirstPhysGPIL )
230 if ( interactionLength <
DBL_MAX/10. )
240 return operationToReturn;
322 ed <<
"Current track deleted while under biasing by " <<
GetName() <<
". Will result in inconsistencies.";
323 G4Exception(
" G4BOptrForceCollision::EndTracking()",
344 ed <<
" Internal inconsistency : please submit bug report. " <<
G4endl;
345 G4Exception(
" G4BOptrForceCollision::OperationApplied(...)",
369 ed <<
" Internal inconsistency : please submit bug report. " <<
G4endl;
370 G4Exception(
" G4BOptrForceCollision::OperationApplied(...)",
380 ed <<
" Internal inconsistency : please submit bug report. " <<
G4endl;
381 G4Exception(
" G4BOptrForceCollision::OperationApplied(...)",
393 ed <<
" Internal inconsistency : please submit bug report. " <<
G4endl;
394 G4Exception(
" G4BOptrForceCollision::OperationApplied(...)",
413 ed <<
" Internal inconsistency : please submit bug report. " <<
G4endl;
414 G4Exception(
" G4BOptrForceCollision::OperationApplied(...)",
424 ed <<
" Internal inconsistency : please submit bug report. " <<
G4endl;
425 G4Exception(
" G4BOptrForceCollision::OperationApplied(...)",
G4ParticleDefinition * GetDefinition() const
G4VBiasingOperation * GetCurrentOccurenceBiasingOperation() const
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
std::ostringstream G4ExceptionDescription
void UpdateForStep(const G4Step *)
void Initialize(const G4Track *)
G4Track * GetCloneTrack() const
void SetAuxiliaryTrackInformation(G4int idx, G4VAuxiliaryTrackInformation *info) const
G4double fInitialTrackWeight
G4StepStatus GetStepStatus() const
void AddCrossSection(const G4VProcess *, G4double)
const G4BOptrForceCollision * fForceCollisionOperator
G4TrackStatus GetTrackStatus() const
G4BOptrForceCollisionTrackData * fCurrentTrackData
const std::vector< const G4BiasingProcessInterface * > & GetPhysicsBiasingProcessInterfaces() const
virtual G4VBiasingOperation * ProposeNonPhysicsBiasingOperation(const G4Track *track, const G4BiasingProcessInterface *callingProcess) final
G4double GetMaximumDistance() const
virtual void EndTracking() final
const G4ThreeVector & GetInitialMomentum() const
const G4Step * GetStep() const
G4ProcessManager * GetProcessManager() const
G4BOptrForceCollision(G4String particleToForce, G4String name="ForceCollision")
G4VProcess * GetWrappedProcess() const
void OperationApplied(const G4BiasingProcessInterface *callingProcess, G4BiasingAppliedCase biasingCase, G4VBiasingOperation *operationApplied, const G4VParticleChange *particleChangeProduced) final
G4StepPoint * GetPreStepPoint() const
size_t GetNumberOfSharing() const
ForceCollisionState fForceCollisionState
void ResetInitialTrackWeight(G4double w)
G4int GetCurrentStepNumber() const
G4BOptnForceCommonTruncatedExp * fSharedForceInteractionOperation
virtual void StartRun() final
G4double GetCurrentInteractionLength() const
const G4Track * fCurrentTrack
virtual void StartTracking(const G4Track *track) final
G4BOptnCloning * fCloningOperation
virtual void Configure() final
G4bool GetInteractionOccured() const
const G4String & GetProcessName() const
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
G4VAuxiliaryTrackInformation * GetAuxiliaryTrackInformation(G4int idx) const
std::map< const G4BiasingProcessInterface *, G4BOptnForceFreeFlight * > fFreeFlightOperations
void SetCloneWeights(G4double clone1Weight, G4double clone2Weight)
G4ThreeVector GetMomentum() const
static G4ParticleTable * GetParticleTable()
static G4int Register(const G4String &)
virtual G4VBiasingOperation * ProposeFinalStateBiasingOperation(const G4Track *track, const G4BiasingProcessInterface *callingProcess) final
G4double GetWeight() const
G4int fForceCollisionModelID
virtual G4VBiasingOperation * ProposeOccurenceBiasingOperation(const G4Track *track, const G4BiasingProcessInterface *callingProcess) final
virtual void ConfigureForWorker() final
const G4String GetName() const
G4bool IsFreeFromBiasing() const
const G4ParticleDefinition * fParticleToBias
const G4BiasingProcessSharedData * GetSharedData() const