27#ifndef G4ParticleHPManager_h
28#define G4ParticleHPManager_h 1
93 PRODUCE_FISSION_FRAGMENTS = USE_WENDT_FISSION_MODEL ? false : val;
97 USE_WENDT_FISSION_MODEL = val;
99 if (USE_WENDT_FISSION_MODEL) PRODUCE_FISSION_FRAGMENTS =
false;
112 theInelasticCrossSections[
GetPHPIndex(part)] = ptr;
116 return theInelasticCrossSections[
GetPHPIndex(part)];
127 std::vector<G4ParticleHPChannelList*>*
133 std::vector<G4ParticleHPChannelList*>* ptr)
149 std::map<G4int, std::map<G4double, G4ParticleHPVector*>*>*
152 return theTSCoherentCrossSections;
155 std::map<
G4int, std::map<G4double, G4ParticleHPVector*>*>* val)
157 theTSCoherentCrossSections = val;
159 std::map<G4int, std::map<G4double, G4ParticleHPVector*>*>*
162 return theTSIncoherentCrossSections;
165 std::map<
G4int, std::map<G4double, G4ParticleHPVector*>*>* val)
167 theTSIncoherentCrossSections = val;
169 std::map<G4int, std::map<G4double, G4ParticleHPVector*>*>*
172 return theTSInelasticCrossSections;
175 std::map<
G4int, std::map<G4double, G4ParticleHPVector*>*>* val)
177 theTSInelasticCrossSections = val;
180 std::map<G4int, std::map<G4double, std::vector<std::pair<G4double, G4double>*>*>*>*
183 return theTSCoherentFinalStates;
186 std::map<
G4int, std::map<
G4double, std::vector<std::pair<G4double, G4double>*>*>*>* val)
188 theTSCoherentFinalStates = val;
190 std::map<G4int, std::map<G4double, std::vector<E_isoAng*>*>*>*
193 return theTSIncoherentFinalStates;
196 std::map<
G4int, std::map<
G4double, std::vector<E_isoAng*>*>*>* val)
198 theTSIncoherentFinalStates = val;
200 std::map<G4int, std::map<G4double, std::vector<E_P_E_isoAng*>*>*>*
203 return theTSInelasticFinalStates;
206 std::map<
G4int, std::map<
G4double, std::vector<E_P_E_isoAng*>*>*>* val)
208 theTSInelasticFinalStates = val;
212 {
return theProbabilityTables; }
214 { theProbabilityTables = val; }
216 std::vector< std::pair< G4double, G4double > >*
GetURRlimits()
const {
return theURRlimits; }
217 void RegisterURRlimits( std::vector< std::pair< G4double, G4double > >* val ) { theURRlimits = val; }
239 std::map<G4String, G4String> mDataEvaluation;
241 G4int verboseLevel{1};
244 G4bool USE_ONLY_PHOTONEVAPORATION{
false};
245 G4bool SKIP_MISSING_ISOTOPES{
false};
246 G4bool NEGLECT_DOPPLER{
false};
247 G4bool DO_NOT_ADJUST_FINAL_STATE{
false};
248 G4bool PRODUCE_FISSION_FRAGMENTS{
false};
249 G4bool USE_WENDT_FISSION_MODEL{
false};
250 G4bool USE_NRESP71_MODEL{
false};
252 G4bool CHECK_HP_NAMES{
false};
254 G4bool PHP_USE_POISSON{
false};
258 G4PhysicsTable* theElasticCrossSections{
nullptr};
259 G4PhysicsTable* theCaptureCrossSections{
nullptr};
260 G4PhysicsTable* theInelasticCrossSections[6]{
nullptr};
261 G4PhysicsTable* theFissionCrossSections{
nullptr};
263 std::vector<G4ParticleHPChannel*>* theElasticFSs{
nullptr};
264 std::vector<G4ParticleHPChannelList*>* theInelasticFSs[6]{
nullptr};
265 std::vector<G4ParticleHPChannel*>* theCaptureFSs{
nullptr};
266 std::vector<G4ParticleHPChannel*>* theFissionFSs{
nullptr};
268 std::map<G4int, std::map<G4double, G4ParticleHPVector*>*>* theTSCoherentCrossSections{
nullptr};
269 std::map<G4int, std::map<G4double, G4ParticleHPVector*>*>* theTSIncoherentCrossSections{
nullptr};
270 std::map<G4int, std::map<G4double, G4ParticleHPVector*>*>* theTSInelasticCrossSections{
nullptr};
272 std::map<G4int, std::map<G4double, std::vector<std::pair<G4double, G4double>*>*>*>*
273 theTSCoherentFinalStates{
nullptr};
274 std::map<G4int, std::map<G4double, std::vector<E_isoAng*>*>*>* theTSIncoherentFinalStates{
nullptr};
275 std::map<G4int, std::map<G4double, std::vector<E_P_E_isoAng*>*>*>* theTSInelasticFinalStates{
nullptr};
282 G4String fDataPath[6]{
""};
284 std::vector< std::map< G4int, G4ParticleHPIsoProbabilityTable* > >* theProbabilityTables{
nullptr};
285 std::vector< std::pair< G4double, G4double > >* theURRlimits{
nullptr};
const G4String & GetParticleHPPath(const G4ParticleDefinition *) const
G4PhysicsTable * GetElasticCrossSections() const
void SetUseNRESP71Model(G4bool val)
G4bool GetUseDBRC() const
std::map< G4int, std::map< G4double, std::vector< E_isoAng * > * > * > * GetThermalScatteringIncoherentFinalStates() const
void RegisterThermalScatteringCoherentFinalStates(std::map< G4int, std::map< G4double, std::vector< std::pair< G4double, G4double > * > * > * > *val)
void SetMinADBRC(G4double val)
void SetNeglectDoppler(G4bool val)
std::vector< G4ParticleHPChannel * > * GetFissionFinalStates() const
void SetMaxEnergyDoppler(G4double val)
G4PhysicsTable * GetInelasticCrossSections(const G4ParticleDefinition *part) const
G4bool GetPHPCheck() const
void RegisterElasticFinalStates(std::vector< G4ParticleHPChannel * > *val)
void RegisterInelasticCrossSections(const G4ParticleDefinition *part, G4PhysicsTable *ptr)
G4bool GetProduceFissionFragments() const
std::vector< G4ParticleHPChannel * > * GetElasticFinalStates() const
std::vector< std::pair< G4double, G4double > > * GetURRlimits() const
void GetDataStream2(const G4String &, std::istringstream &iss)
void DumpDataSource() const
void SetMinEnergyDBRC(G4double val)
G4ParticleHPManager & operator=(const G4ParticleHPManager &right)=delete
std::vector< G4ParticleHPChannel * > * GetCaptureFinalStates() const
void RegisterFissionFinalStates(std::vector< G4ParticleHPChannel * > *val)
G4bool GetUseOnlyPhotoEvaporation() const
void SetProduceFissionFragments(G4bool val)
void RegisterThermalScatteringIncoherentCrossSections(std::map< G4int, std::map< G4double, G4ParticleHPVector * > * > *val)
void SetSkipMissingIsotopes(G4bool val)
G4int GetVerboseLevel() const
void SetDoNotAdjustFinalState(G4bool val)
G4int GetPHPIndex(const G4ParticleDefinition *) const
void RegisterURRlimits(std::vector< std::pair< G4double, G4double > > *val)
void RegisterThermalScatteringIncoherentFinalStates(std::map< G4int, std::map< G4double, std::vector< E_isoAng * > * > * > *val)
std::map< G4int, std::map< G4double, G4ParticleHPVector * > * > * GetThermalScatteringCoherentCrossSections() const
void RegisterThermalScatteringInelasticFinalStates(std::map< G4int, std::map< G4double, std::vector< E_P_E_isoAng * > * > * > *val)
const G4String & GetNeutronHPPath() const
G4double GetMaxEnergyDoppler() const
G4bool GetUseWendtFissionModel() const
G4bool GetPHCUsePoisson() const
G4PhysicsTable * GetCaptureCrossSections() const
void RegisterInelasticFinalStates(const G4ParticleDefinition *part, std::vector< G4ParticleHPChannelList * > *ptr)
G4double GetMinEnergyDBRC() const
void SetVerboseLevel(G4int i)
std::map< G4int, std::map< G4double, std::vector< E_P_E_isoAng * > * > * > * GetThermalScatteringInelasticFinalStates() const
void RegisterThermalScatteringCoherentCrossSections(std::map< G4int, std::map< G4double, G4ParticleHPVector * > * > *val)
std::map< G4int, std::map< G4double, G4ParticleHPVector * > * > * GetThermalScatteringInelasticCrossSections() const
G4PhysicsTable * GetFissionCrossSections() const
G4double GetMinADBRC() const
void GetDataStream(const G4String &, std::istringstream &iss)
G4bool GetUseNRESP71Model() const
G4ParticleHPManager(G4ParticleHPManager &)=delete
std::vector< std::map< G4int, G4ParticleHPIsoProbabilityTable * > > * GetProbabilityTables() const
G4bool GetSkipMissingIsotopes() const
std::vector< G4ParticleHPChannelList * > * GetInelasticFinalStates(const G4ParticleDefinition *part) const
void RegisterElasticCrossSections(G4PhysicsTable *val)
void RegisterCaptureCrossSections(G4PhysicsTable *val)
static G4ParticleHPManager * GetInstance()
void SetUseDBRC(G4bool val)
void CloseReactionWhiteBoard()
void SetUseWendtFissionModel(G4bool val)
G4bool GetNeglectDoppler() const
void RegisterProbabilityTables(std::vector< std::map< G4int, G4ParticleHPIsoProbabilityTable * > > *val)
G4bool GetCheckHPNames() const
std::map< G4int, std::map< G4double, std::vector< std::pair< G4double, G4double > * > * > * > * GetThermalScatteringCoherentFinalStates() const
void SetMaxEnergyDBRC(G4double val)
void RegisterThermalScatteringInelasticCrossSections(std::map< G4int, std::map< G4double, G4ParticleHPVector * > * > *val)
void OpenReactionWhiteBoard()
void RegisterCaptureFinalStates(std::vector< G4ParticleHPChannel * > *val)
void SetUseOnlyPhotoEvaporation(G4bool val)
G4double GetMaxEnergyDBRC() const
G4bool GetDoNotAdjustFinalState() const
void RegisterFissionCrossSections(G4PhysicsTable *val)
std::map< G4int, std::map< G4double, G4ParticleHPVector * > * > * GetThermalScatteringIncoherentCrossSections() const
G4ParticleHPReactionWhiteBoard * GetReactionWhiteBoard()