GENIEGenerator
|
Generates nuclear de-excitation gamma rays. More...
#include <NucDeExcitationSim.h>
Public Member Functions | |
NucDeExcitationSim () | |
NucDeExcitationSim (string config) | |
~NucDeExcitationSim () | |
void | Configure (const Registry &config) override |
void | Configure (std::string config) override |
void | ProcessEventRecord (GHepRecord *evrec) const override |
Public Member Functions inherited from genie::EventRecordVisitorI | |
virtual | ~EventRecordVisitorI () |
Public Member Functions inherited from genie::Algorithm | |
virtual | ~Algorithm () |
virtual void | Configure (string config) |
virtual void | FindConfig (void) |
virtual const Registry & | GetConfig (void) const |
Registry * | GetOwnedConfig (void) |
virtual const AlgId & | Id (void) const |
Get algorithm ID. More... | |
virtual AlgStatus_t | GetStatus (void) const |
Get algorithm status. More... | |
virtual bool | AllowReconfig (void) const |
virtual AlgCmp_t | Compare (const Algorithm *alg) const |
Compare with input algorithm. More... | |
virtual void | SetId (const AlgId &id) |
Set algorithm ID. More... | |
virtual void | SetId (string name, string config) |
const Algorithm * | SubAlg (const RgKey ®istry_key) const |
void | AdoptConfig (void) |
void | AdoptSubstructure (void) |
virtual void | Print (ostream &stream) const |
Print algorithm info. More... | |
Private Member Functions | |
void | OxygenTargetSim (GHepRecord *evrec) const |
void | CarbonTargetSim (GHepRecord *evrec) const |
void | ArgonTargetSim (GHepRecord *evrec) const |
void | AddPhoton (GHepRecord *evrec, double E0, double t) const |
double | PhotonEnergySmearing (double E0, double t) const |
TLorentzVector | Photon4P (double E) const |
void | LoadConfig () |
Private Attributes | |
bool | fDoCarbon = false |
bool | fDoArgon = false |
Additional Inherited Members | |
Static Public Member Functions inherited from genie::Algorithm | |
static string | BuildParamVectKey (const std::string &comm_name, unsigned int i) |
static string | BuildParamVectSizeKey (const std::string &comm_name) |
static string | BuildParamMatKey (const std::string &comm_name, unsigned int i, unsigned int j) |
static string | BuildParamMatRowSizeKey (const std::string &comm_name) |
static string | BuildParamMatColSizeKey (const std::string &comm_name) |
Protected Member Functions inherited from genie::EventRecordVisitorI | |
EventRecordVisitorI () | |
EventRecordVisitorI (string name) | |
EventRecordVisitorI (string name, string config) | |
Protected Member Functions inherited from genie::Algorithm | |
Algorithm () | |
Algorithm (string name) | |
Algorithm (string name, string config) | |
void | Initialize (void) |
void | DeleteConfig (void) |
void | DeleteSubstructure (void) |
Registry * | ExtractLocalConfig (const Registry &in) const |
Registry * | ExtractLowerConfig (const Registry &in, const string &alg_key) const |
Split an incoming configuration Registry into a block valid for the sub-algo identified by alg_key. More... | |
template<class T > | |
bool | GetParam (const RgKey &name, T &p, bool is_top_call=true) const |
template<class T > | |
bool | GetParamDef (const RgKey &name, T &p, const T &def) const |
template<class T > | |
int | GetParamVect (const std::string &comm_name, std::vector< T > &v, bool is_top_call=true) const |
Handle to load vectors of parameters. More... | |
int | GetParamVectKeys (const std::string &comm_name, std::vector< RgKey > &k, bool is_top_call=true) const |
template<class T > | |
int | GetParamMat (const std::string &comm_name, TMatrixT< T > &mat, bool is_top_call=true) const |
Handle to load matrix of parameters. More... | |
template<class T > | |
int | GetParamMatSym (const std::string &comm_name, TMatrixTSym< T > &mat, bool is_top_call=true) const |
int | GetParamMatKeys (const std::string &comm_name, std::vector< RgKey > &k, bool is_top_call=true) const |
int | AddTopRegistry (Registry *rp, bool owns=true) |
add registry with top priority, also update ownership More... | |
int | AddLowRegistry (Registry *rp, bool owns=true) |
add registry with lowest priority, also update ownership More... | |
int | MergeTopRegistry (const Registry &r) |
int | AddTopRegisties (const vector< Registry * > &rs, bool owns=false) |
Add registries with top priority, also udated Ownerships. More... | |
Protected Attributes inherited from genie::Algorithm | |
bool | fAllowReconfig |
bool | fOwnsSubstruc |
true if it owns its substructure (sub-algs,...) More... | |
AlgId | fID |
algorithm name and configuration set More... | |
vector< Registry * > | fConfVect |
vector< bool > | fOwnerships |
ownership for every registry in fConfVect More... | |
AlgStatus_t | fStatus |
algorithm execution status More... | |
AlgMap * | fOwnedSubAlgMp |
local pool for owned sub-algs (taken out of the factory pool) More... | |
Generates nuclear de-excitation gamma rays.
Definition at line 31 of file NucDeExcitationSim.h.
NucDeExcitationSim::NucDeExcitationSim | ( | ) |
Definition at line 47 of file NucDeExcitationSim.cxx.
NucDeExcitationSim::NucDeExcitationSim | ( | string | config | ) |
Definition at line 53 of file NucDeExcitationSim.cxx.
NucDeExcitationSim::~NucDeExcitationSim | ( | ) |
Definition at line 59 of file NucDeExcitationSim.cxx.
|
private |
Definition at line 486 of file NucDeExcitationSim.cxx.
References genie::GHepRecord::AddParticle(), genie::GHepParticle::E(), genie::GHepParticle::FirstDaughter(), genie::pdg::IsIon(), genie::kIStStableFinalState, genie::kPdgGamma, genie::GHepParticle::LastDaughter(), LOG, genie::units::MeV, genie::GHepRecord::Particle(), genie::GHepParticle::Pdg(), Photon4P(), PhotonEnergySmearing(), pNOTICE, genie::GHepParticle::Px(), genie::GHepParticle::Py(), genie::GHepParticle::Pz(), genie::GHepParticle::SetEnergy(), genie::GHepParticle::SetPx(), genie::GHepParticle::SetPy(), and genie::GHepParticle::SetPz().
Referenced by ArgonTargetSim(), CarbonTargetSim(), and OxygenTargetSim().
|
private |
Definition at line 555 of file NucDeExcitationSim.cxx.
References AddPhoton(), fDoArgon, genie::GHepRecord::HitNucleon(), genie::RandomGen::Instance(), genie::pdg::IsNucleon(), genie::kPdgProton, LOG, genie::GHepParticle::Pdg(), pNOTICE, and genie::RandomGen::RndDec().
Referenced by ProcessEventRecord().
|
private |
Definition at line 378 of file NucDeExcitationSim.cxx.
References AddPhoton(), fDoCarbon, genie::GHepRecord::HitNucleon(), genie::RandomGen::Instance(), LOG, pNOTICE, and genie::RandomGen::RndDec().
Referenced by ProcessEventRecord().
|
overridevirtual |
Configure the algorithm with an external registry The registry is merged with the top level registry if it is owned, Otherwise a copy of it is added with the highest priority
Reimplemented from genie::Algorithm.
Definition at line 628 of file NucDeExcitationSim.cxx.
References genie::Algorithm::Configure(), and LoadConfig().
|
override |
Definition at line 634 of file NucDeExcitationSim.cxx.
References genie::Algorithm::Configure(), and LoadConfig().
|
private |
Definition at line 640 of file NucDeExcitationSim.cxx.
References fDoArgon, fDoCarbon, and genie::Algorithm::GetParamDef().
Referenced by Configure().
|
private |
Definition at line 126 of file NucDeExcitationSim.cxx.
References AddPhoton(), genie::GHepRecord::HitNucleon(), genie::RandomGen::Instance(), genie::kPdgProton, LOG, genie::GHepParticle::Pdg(), pNOTICE, and genie::RandomGen::RndDec().
Referenced by ProcessEventRecord().
|
private |
Definition at line 533 of file NucDeExcitationSim.cxx.
References genie::RandomGen::Instance(), genie::constants::kPi, and genie::RandomGen::RndDec().
Referenced by AddPhoton().
|
private |
Definition at line 516 of file NucDeExcitationSim.cxx.
References genie::RandomGen::Instance(), genie::constants::kPlankConstant, LOG, pNOTICE, genie::RandomGen::RndDec(), and genie::units::s.
Referenced by AddPhoton().
|
overridevirtual |
Implements genie::EventRecordVisitorI.
Definition at line 64 of file NucDeExcitationSim.cxx.
References ArgonTargetSim(), CarbonTargetSim(), genie::RandomGen::Instance(), genie::ProcessInfo::IsDeepInelastic(), genie::ProcessInfo::IsMEC(), genie::ProcessInfo::IsQuasiElastic(), genie::ProcessInfo::IsResonant(), LOG, OxygenTargetSim(), pINFO, pNOTICE, genie::Interaction::ProcInfo(), genie::RandomGen::RndDec(), genie::GHepRecord::Summary(), genie::GHepRecord::TargetNucleus(), and genie::GHepParticle::Z().
|
private |
Definition at line 56 of file NucDeExcitationSim.h.
Referenced by ArgonTargetSim(), and LoadConfig().
|
private |
Definition at line 55 of file NucDeExcitationSim.h.
Referenced by CarbonTargetSim(), and LoadConfig().