19#ifndef BDSBOPTRCHANGECROSSSECTION_H
20#define BDSBOPTRCHANGECROSSSECTION_H
23#include "G4VBiasingOperator.hh"
25class G4BOptnChangeCrossSection;
26class G4ParticleDefinition;
42 const G4String& name =
"ChangeXS");
45 virtual void StartRun();
46 void SetBias(
const G4String& processName,
51 virtual G4VBiasingOperation* ProposeOccurenceBiasingOperation(
const G4Track* track,
52 const G4BiasingProcessInterface* callingProcess);
54 virtual G4VBiasingOperation* ProposeFinalStateBiasingOperation(
const G4Track*,
const G4BiasingProcessInterface*)
57 virtual G4VBiasingOperation* ProposeNonPhysicsBiasingOperation(
const G4Track*,
const G4BiasingProcessInterface*)
60 using G4VBiasingOperator::OperationApplied;
62 virtual void OperationApplied(
const G4BiasingProcessInterface* callingProcess,
63 G4BiasingAppliedCase biasingCase,
64 G4VBiasingOperation* occurenceOperationApplied,
65 G4double weightForOccurenceInteraction,
66 G4VBiasingOperation* finalStateOperationApplied,
67 const G4VParticleChange* particleChangeProduced );
68 std::map<const G4BiasingProcessInterface*, G4BOptnChangeCrossSection*> fChangeCrossSectionOperations;
69 std::map<const G4BiasingProcessInterface*, G4double> fXSScale;
70 std::map<const G4BiasingProcessInterface*, G4int> fPrimaryScale;
72 G4String particleName;
73 const G4ParticleDefinition* fParticleToBias;
Operator that changes cross section of a process for a particle.