46 delete fCommonTruncatedExpLaw;
47 delete fForceFreeFlightLaw;
56 proposeForceCondition =
Forced;
57 return fCommonTruncatedExpLaw;
61 proposeForceCondition =
Forced;
62 return fForceFreeFlightLaw;
80 forceFinalState =
true;
81 fDummyParticleChange.Initialize( *track );
82 return &fDummyParticleChange;
84 if ( fInteractionOccured )
86 forceFinalState =
true;
87 fDummyParticleChange.Initialize( *track );
88 return &fDummyParticleChange;
96 if ( processGPIL <= step->GetStepLength() )
102 forceFinalState =
false;
103 fInteractionOccured =
true;
108 forceFinalState =
true;
109 fDummyParticleChange.Initialize( *track );
110 return &fDummyParticleChange;
117 fTotalCrossSection += crossSection;
118 fCrossSections[process] = crossSection;
119 fNumberOfSharing = fCrossSections.size();
124 fCrossSections.clear();
125 fTotalCrossSection = 0.0;
126 fNumberOfSharing = 0;
128 fInteractionOccured =
false;
133 GetNavigatorForTracking()->
134 GetGlobalToLocalTransform()).TransformPoint(track->
GetPosition());
136 GetNavigatorForTracking()->
138 fMaximumDistance = currentSolid->
DistanceToOut(localPosition, localDirection);
139 if ( fMaximumDistance <=
DBL_MIN ) { fMaximumDistance = 0.0; }
140 fCommonTruncatedExpLaw->SetMaximumDistance( fMaximumDistance );
145 fCrossSections.clear();
146 fTotalCrossSection = 0.0;
147 fNumberOfSharing = 0;
150 fCommonTruncatedExpLaw->UpdateForStep( step->
GetStepLength() );
151 fMaximumDistance = fCommonTruncatedExpLaw->GetMaximumDistance();
156 fCommonTruncatedExpLaw->SetForceCrossSection( fTotalCrossSection );
157 fCommonTruncatedExpLaw->Sample();
159 fCommonTruncatedExpLaw->SetSelectedProcessXSfraction(fCrossSections[fProcessToApply] / fTotalCrossSection);
166 for (
auto it = fCrossSections.cbegin(); it != fCrossSections.cend(); ++it)
168 sigmaSelect += (*it).second;
169 if ( sigmaRand <= sigmaSelect )
171 fProcessToApply = (*it).first;
@ NotCandidateForSelection
CLHEP::Hep3Vector G4ThreeVector
void UpdateForStep(const G4Step *)
virtual G4GPILSelection ProposeGPILSelection(const G4GPILSelection processSelection)
void ChooseProcessToApply()
virtual ~G4BOptnForceCommonTruncatedExp()
virtual const G4VBiasingInteractionLaw * ProvideOccurenceBiasingInteractionLaw(const G4BiasingProcessInterface *, G4ForceCondition &)
G4BOptnForceCommonTruncatedExp(const G4String &name)
void AddCrossSection(const G4VProcess *, G4double)
void Initialize(const G4Track *)
virtual G4VParticleChange * ApplyFinalStateBiasing(const G4BiasingProcessInterface *, const G4Track *, const G4Step *, G4bool &)
G4double GetPostStepGPIL() const
G4double GetAlongStepGPIL() const
G4VProcess * GetWrappedProcess() const
G4VSolid * GetSolid() const
G4double GetStepLength() const
G4VPhysicalVolume * GetVolume() const
const G4ThreeVector & GetPosition() const
G4ThreeVector GetMomentum() const
const G4ThreeVector & GetMomentumDirection() const
static G4TransportationManager * GetTransportationManager()
G4VBiasingOperation(const G4String &name)
G4LogicalVolume * GetLogicalVolume() const
virtual G4VParticleChange * PostStepDoIt(const G4Track &track, const G4Step &stepData)=0
virtual G4double DistanceToOut(const G4ThreeVector &p, const G4ThreeVector &v, const G4bool calcNorm=false, G4bool *validNorm=nullptr, G4ThreeVector *n=nullptr) const =0