47#ifndef G4HadronicProcess_h
48#define G4HadronicProcess_h 1
97 const G4Step& aStep)
override;
144 aMaterial,anElement);
248 std::vector<G4VLeadingParticleBiasing*>
theBias;
std::ostringstream G4ExceptionDescription
G4HadronicInteraction * GetHadronicInteraction(const G4HadProjectile &aHadProjectile, G4Nucleus &aTargetNucleus, const G4Material *aMaterial, const G4Element *anElement) const
void FillResult(G4HadFinalState *aR, const G4Track &aT)
const G4Nucleus * GetTargetNucleus() const
G4VParticleChange * PostStepDoIt(const G4Track &aTrack, const G4Step &aStep) override
void ProcessDescription(std::ostream &outFile) const override
void BiasCrossSectionByFactor(G4double aScale)
G4Nucleus * GetTargetNucleusPointer()
G4HadFinalState * CheckResult(const G4HadProjectile &thePro, const G4Nucleus &targetNucleus, G4HadFinalState *result)
void SetEpReportLevel(G4int level)
G4double GetMeanFreePath(const G4Track &aTrack, G4double, G4ForceCondition *) override
G4HadronicInteraction * GetHadronicInteraction() const
G4ParticleChange * theTotalResult
void AddDataSet(G4VCrossSectionDataSet *aDataSet)
G4double GetElementCrossSection(const G4DynamicParticle *part, const G4Element *elm, const G4Material *mat=nullptr)
std::vector< G4HadronicInteraction * > & GetHadronicInteractionList()
void PreparePhysicsTable(const G4ParticleDefinition &) override
G4HadronicProcess(const G4String &processName="Hadronic", G4ProcessType procType=fHadronic)
G4HadronicInteraction * ChooseHadronicInteraction(const G4HadProjectile &aHadProjectile, G4Nucleus &aTargetNucleus, const G4Material *aMaterial, const G4Element *anElement)
std::pair< G4double, G4double > GetEnergyMomentumCheckLevels() const
~G4HadronicProcess() override
G4HadronicProcess & operator=(const G4HadronicProcess &right)
G4double GetLastCrossSection()
void BuildPhysicsTable(const G4ParticleDefinition &) override
G4CrossSectionDataStore * theCrossSectionDataStore
G4double theInitialNumberOfInteractionLength
void CheckEnergyMomentumConservation(const G4Track &, const G4Nucleus &)
G4CrossSectionDataStore * GetCrossSectionDataStore()
G4HadronicInteraction * GetHadronicModel(const G4String &)
std::vector< G4VLeadingParticleBiasing * > theBias
G4EnergyRangeManager theEnergyRangeManager
G4double GetMicroscopicCrossSection(const G4DynamicParticle *part, const G4Element *elm, const G4Material *mat=nullptr)
G4double XBiasSecondaryWeight()
bool G4HadronicProcess_debug_flag
G4HadronicProcessStore * theProcessStore
G4HadronicInteraction * theInteraction
G4double XBiasSurvivalProbability()
void DumpState(const G4Track &, const G4String &, G4ExceptionDescription &)
void GetEnergyMomentumCheckEnvvars()
void DumpPhysicsTable(const G4ParticleDefinition &p)
G4double CrossSectionFactor() const
G4bool levelsSetByProcess
void MultiplyCrossSectionBy(G4double factor)
std::pair< G4double, G4double > epCheckLevels
void SetIntegral(G4bool val)
G4double theLastCrossSection
void RegisterMe(G4HadronicInteraction *a)
G4HadronicProcess(const G4HadronicProcess &)
const G4Isotope * GetTargetIsotope()
void SetEnergyMomentumCheckLevels(G4double relativeLevel, G4double absoluteLevel)
const G4Isotope * GetIsotope()