GENIEGenerator
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Public Member Functions | Private Member Functions | List of all members
genie::COHPrimaryLeptonGenerator Class Reference

Generates the final state primary lepton in v COH NC interactions. Is a concrete implementation of the EventRecordVisitorI interface. More...

#include <COHPrimaryLeptonGenerator.h>

Inheritance diagram for genie::COHPrimaryLeptonGenerator:
Inheritance graph
[legend]
Collaboration diagram for genie::COHPrimaryLeptonGenerator:
Collaboration graph
[legend]

Public Member Functions

 COHPrimaryLeptonGenerator ()
 
 COHPrimaryLeptonGenerator (string config)
 
 ~COHPrimaryLeptonGenerator ()
 
void ProcessEventRecord (GHepRecord *event_rec) const
 
- Public Member Functions inherited from genie::PrimaryLeptonGenerator
virtual void SetPolarization (GHepRecord *ev) const
 
virtual TVector3 NucRestFrame2Lab (GHepRecord *ev) const
 
virtual void AddToEventRecord (GHepRecord *ev, int pdgc, const TLorentzVector &p4) const
 
void Configure (const Registry &config)
 
void Configure (string config)
 
- Public Member Functions inherited from genie::EventRecordVisitorI
virtual ~EventRecordVisitorI ()
 
- Public Member Functions inherited from genie::Algorithm
virtual ~Algorithm ()
 
virtual void FindConfig (void)
 
virtual const RegistryGetConfig (void) const
 
RegistryGetOwnedConfig (void)
 
virtual const AlgIdId (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 AlgorithmSubAlg (const RgKey &registry_key) const
 
void AdoptConfig (void)
 
void AdoptSubstructure (void)
 
virtual void Print (ostream &stream) const
 Print algorithm info. More...
 

Private Member Functions

void CalculatePrimaryLepton_AlvarezRuso (GHepRecord *event_rec) const
 

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::PrimaryLeptonGenerator
 PrimaryLeptonGenerator ()
 
 PrimaryLeptonGenerator (string name)
 
 PrimaryLeptonGenerator (string name, string config)
 
virtual ~PrimaryLeptonGenerator ()
 
void LoadConfig (void)
 
- 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)
 
RegistryExtractLocalConfig (const Registry &in) const
 
RegistryExtractLowerConfig (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::PrimaryLeptonGenerator
bool fApplyCoulombCorrection
 
- 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...
 
AlgMapfOwnedSubAlgMp
 local pool for owned sub-algs (taken out of the factory pool) More...
 

Detailed Description

Generates the final state primary lepton in v COH NC interactions. Is a concrete implementation of the EventRecordVisitorI interface.

Author
Costas Andreopoulos <c.andreopoulos cern.ch> University of Liverpool
Created:
September 26, 2005
License:
Copyright (c) 2003-2024, The GENIE Collaboration For the full text of the license visit http://copyright.genie-mc.org

Definition at line 26 of file COHPrimaryLeptonGenerator.h.

Constructor & Destructor Documentation

COHPrimaryLeptonGenerator::COHPrimaryLeptonGenerator ( )

Definition at line 30 of file COHPrimaryLeptonGenerator.cxx.

30  :
31  PrimaryLeptonGenerator("genie::COHPrimaryLeptonGenerator")
32 {
33 
34 }
COHPrimaryLeptonGenerator::COHPrimaryLeptonGenerator ( string  config)

Definition at line 36 of file COHPrimaryLeptonGenerator.cxx.

36  :
37  PrimaryLeptonGenerator("genie::COHPrimaryLeptonGenerator", config)
38 {
39 
40 }
COHPrimaryLeptonGenerator::~COHPrimaryLeptonGenerator ( )

Definition at line 42 of file COHPrimaryLeptonGenerator.cxx.

43 {
44 
45 }

Member Function Documentation

void COHPrimaryLeptonGenerator::CalculatePrimaryLepton_AlvarezRuso ( GHepRecord event_rec) const
private

Definition at line 74 of file COHPrimaryLeptonGenerator.cxx.

References genie::PrimaryLeptonGenerator::AddToEventRecord(), genie::Kinematics::FSLeptonP4(), genie::Interaction::FSPrimLepton(), genie::Interaction::Kine(), genie::PrimaryLeptonGenerator::SetPolarization(), and genie::GHepRecord::Summary().

Referenced by ProcessEventRecord().

75 {
76  Interaction * interaction = evrec->Summary();
77  const Kinematics & kinematics = interaction->Kine();
78  TLorentzVector p4l = kinematics.FSLeptonP4();
79  int pdgc = interaction->FSPrimLepton()->PdgCode();
80  this->AddToEventRecord(evrec, pdgc, p4l);
81  this->SetPolarization( evrec );
82 }
Generated/set kinematical variables for an event.
Definition: Kinematics.h:39
Summary information for an interaction.
Definition: Interaction.h:56
const TLorentzVector & FSLeptonP4(void) const
Definition: Kinematics.h:65
const Kinematics & Kine(void) const
Definition: Interaction.h:71
TParticlePDG * FSPrimLepton(void) const
final state primary lepton
virtual void SetPolarization(GHepRecord *ev) const
virtual void AddToEventRecord(GHepRecord *ev, int pdgc, const TLorentzVector &p4) const
void COHPrimaryLeptonGenerator::ProcessEventRecord ( GHepRecord event_rec) const
virtual

Reimplemented from genie::PrimaryLeptonGenerator.

Definition at line 47 of file COHPrimaryLeptonGenerator.cxx.

References CalculatePrimaryLepton_AlvarezRuso(), genie::EventGeneratorI::CrossSectionAlg(), genie::Algorithm::Id(), genie::RunningThreadInfo::Instance(), LOG, genie::AlgId::Name(), pFATAL, genie::PrimaryLeptonGenerator::ProcessEventRecord(), and genie::RunningThreadInfo::RunningThread().

48 {
49  //-- Access cross section algorithm for running thread
51  const EventGeneratorI * evg = rtinfo->RunningThread();
52  const XSecAlgorithmI *fXSecModel = evg->CrossSectionAlg();
53 
54  // In Rein and Berger-Sehgal, no modification is required to the standard impl.
55  if (fXSecModel->Id().Name() == "genie::ReinSehgalCOHPiPXSec") {
57  }
58  else if ((fXSecModel->Id().Name() == "genie::BergerSehgalCOHPiPXSec2015")) {
60  }
61  else if ((fXSecModel->Id().Name() == "genie::BergerSehgalFMCOHPiPXSec2015")) {
63  }
64  else if ((fXSecModel->Id().Name() == "genie::AlvarezRusoCOHPiPXSec")) {
66  }
67  else {
68  LOG("COHPrimaryLeptonGenerator",pFATAL) <<
69  "ProcessEventRecord >> Cannot calculate primary lepton for " <<
70  fXSecModel->Id().Name();
71  }
72 }
void CalculatePrimaryLepton_AlvarezRuso(GHepRecord *event_rec) const
Cross Section Calculation Interface.
#define pFATAL
Definition: Messenger.h:56
Defines the EventGeneratorI interface.
#define LOG(stream, priority)
A macro that returns the requested log4cpp::Category appending a string (using the FILE...
Definition: Messenger.h:96
string Name(void) const
Definition: AlgId.h:44
virtual void ProcessEventRecord(GHepRecord *evrec) const
static RunningThreadInfo * Instance(void)
virtual const AlgId & Id(void) const
Get algorithm ID.
Definition: Algorithm.h:98
virtual const XSecAlgorithmI * CrossSectionAlg(void) const =0
const EventGeneratorI * RunningThread(void)
Keep info on the event generation thread currently on charge. This is used so that event generation m...

The documentation for this class was generated from the following files: