GENIEGenerator
Loading...
Searching...
No Matches
genie::DMETargetRemnantGenerator Class Reference

Generates all the non-primary lepton final state particles in neutrino-electron events. Is a concrete implementation of the EventRecordVisitorI interface. More...

#include <DMETargetRemnantGenerator.h>

Inheritance diagram for genie::DMETargetRemnantGenerator:
[legend]
Collaboration diagram for genie::DMETargetRemnantGenerator:
[legend]

Public Member Functions

 DMETargetRemnantGenerator ()
 DMETargetRemnantGenerator (string config)
 ~DMETargetRemnantGenerator ()
void ProcessEventRecord (GHepRecord *evrec) const
Public Member Functions inherited from genie::EventRecordVisitorI
virtual ~EventRecordVisitorI ()
Public Member Functions inherited from genie::Algorithm
virtual ~Algorithm ()
virtual void Configure (const Registry &config)
virtual void Configure (string config)
virtual void FindConfig (void)
virtual const RegistryGetConfig (void) const
RegistryGetOwnedConfig (void)
virtual const AlgIdId (void) const
 Get algorithm ID.
virtual AlgStatus_t GetStatus (void) const
 Get algorithm status.
virtual bool AllowReconfig (void) const
virtual AlgCmp_t Compare (const Algorithm *alg) const
 Compare with input algorithm.
virtual void SetId (const AlgId &id)
 Set algorithm ID.
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.

Private Member Functions

void AddElectronNeutrino (GHepRecord *evrec) const
void AddTargetNucleusRemnant (GHepRecord *evrec) 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::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.
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.
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.
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
int AddLowRegistry (Registry *rp, bool owns=true)
 add registry with lowest priority, also update ownership
int MergeTopRegistry (const Registry &r)
int AddTopRegisties (const vector< Registry * > &rs, bool owns=false)
 Add registries with top priority, also udated Ownerships.
Protected Attributes inherited from genie::Algorithm
bool fAllowReconfig
bool fOwnsSubstruc
 true if it owns its substructure (sub-algs,...)
AlgId fID
 algorithm name and configuration set
vector< Registry * > fConfVect
vector< bool > fOwnerships
 ownership for every registry in fConfVect
AlgStatus_t fStatus
 algorithm execution status
AlgMapfOwnedSubAlgMp
 local pool for owned sub-algs (taken out of the factory pool)

Detailed Description

Generates all the non-primary lepton final state particles in neutrino-electron events. Is a concrete implementation of the EventRecordVisitorI interface.

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

Definition at line 28 of file DMETargetRemnantGenerator.h.

Constructor & Destructor Documentation

◆ DMETargetRemnantGenerator() [1/2]

DMETargetRemnantGenerator::DMETargetRemnantGenerator ( )

Definition at line 33 of file DMETargetRemnantGenerator.cxx.

33 :
34EventRecordVisitorI("genie::DMETargetRemnantGenerator")
35{
36
37}

References genie::EventRecordVisitorI::EventRecordVisitorI().

◆ DMETargetRemnantGenerator() [2/2]

DMETargetRemnantGenerator::DMETargetRemnantGenerator ( string config)

Definition at line 39 of file DMETargetRemnantGenerator.cxx.

39 :
40EventRecordVisitorI("genie::DMETargetRemnantGenerator", config)
41{
42
43}

References genie::EventRecordVisitorI::EventRecordVisitorI().

◆ ~DMETargetRemnantGenerator()

DMETargetRemnantGenerator::~DMETargetRemnantGenerator ( )

Definition at line 45 of file DMETargetRemnantGenerator.cxx.

46{
47
48}

Member Function Documentation

◆ AddElectronNeutrino()

void DMETargetRemnantGenerator::AddElectronNeutrino ( GHepRecord * evrec) const
private

Definition at line 56 of file DMETargetRemnantGenerator.cxx.

57{
58 //-- Get all initial & final state particles 4-momenta (in the LAB frame)
59
60 //incoming v:
61 GHepParticle * nu = evrec->Probe();
62
63 //struck particle
64 GHepParticle * el = evrec->HitElectron();
65
66 //final state primary lepton:
67 GHepParticle * l = evrec->FinalStatePrimaryLepton();
68
69 assert(nu);
70 assert(el);
71 assert(l);
72
73 //-- Force energy conservation
74 // Pv(Ev,pxv,pyv,pzv) + Pe(En,pxn,pyn,pzn) = Pfsl(El,pxl,pyl,pzl) + Px
75
76 const TLorentzVector & p4v = *(nu->P4());
77 const TLorentzVector & p4e = *(el->P4());
78 const TLorentzVector & p4l = *(l->P4());
79 const TLorentzVector & p4 = p4v + p4e - p4l;
80
81 //-- Vtx position
82 const TLorentzVector & vtx = *(nu->X4());
83
84 LOG("DMETargetRemnant", pINFO) << "Adding final state lepton from e- vtx";
85
86 const ProcessInfo & proc_info = evrec->Summary()->ProcInfo();
87 int mom = evrec->HitElectronPosition();
88 int pdgc = 0;
89 if (proc_info.IsDarkMatterElectronElastic()) pdgc = kPdgElectron;
90 assert(pdgc!=0);
91 evrec->AddParticle(
92 pdgc,kIStStableFinalState, mom,-1,-1,-1, p4, vtx);
93}
#define pINFO
Definition Messenger.h:62
#define LOG(stream, priority)
A macro that returns the requested log4cpp::Category appending a string (using the FILE,...
Definition Messenger.h:96
const TLorentzVector * P4(void) const
const TLorentzVector * X4(void) const
virtual GHepParticle * Probe(void) const
virtual int HitElectronPosition(void) const
virtual GHepParticle * HitElectron(void) const
virtual Interaction * Summary(void) const
virtual void AddParticle(const GHepParticle &p)
virtual GHepParticle * FinalStatePrimaryLepton(void) const
const ProcessInfo & ProcInfo(void) const
Definition Interaction.h:70
bool IsDarkMatterElectronElastic(void) const
@ kIStStableFinalState
Definition GHepStatus.h:30
const int kPdgElectron
Definition PDGCodes.h:35

References genie::GHepRecord::AddParticle(), genie::GHepRecord::FinalStatePrimaryLepton(), genie::GHepRecord::HitElectron(), genie::GHepRecord::HitElectronPosition(), genie::ProcessInfo::IsDarkMatterElectronElastic(), genie::kIStStableFinalState, genie::kPdgElectron, LOG, genie::GHepParticle::P4(), pINFO, genie::GHepRecord::Probe(), genie::Interaction::ProcInfo(), genie::GHepRecord::Summary(), and genie::GHepParticle::X4().

Referenced by ProcessEventRecord().

◆ AddTargetNucleusRemnant()

void DMETargetRemnantGenerator::AddTargetNucleusRemnant ( GHepRecord * evrec) const
private

Definition at line 95 of file DMETargetRemnantGenerator.cxx.

97{
98// add the remnant nuclear target at the GHEP record
99
100 LOG("DMETargetRemnant", pDEBUG) << "Adding final state nucleus";
101
102 //-- get A,Z for initial state nucleus
103 Interaction * interaction = evrec->Summary();
104 const InitialState & init_state = interaction->InitState();
105
106 bool is_nucleus = init_state.Tgt().IsNucleus();
107 if (!is_nucleus) {
108 LOG("DMETargetRemnant", pDEBUG)
109 << "Initial state not a nucleus - no remnant nucleus to add";
110 return;
111 }
112 int A = init_state.Tgt().A();
113 int Z = init_state.Tgt().Z();
114
115 int ipdgc = pdg::IonPdgCode(A, Z);
116 double mass = PDGLibrary::Instance()->Find(ipdgc)->Mass();
117
118 //-- Add the nucleus to the event record
119 LOG("DMETargetRemnant", pINFO)
120 << "Adding nucleus [A = " << A << ", Z = " << Z
121 << ", pdgc = " << ipdgc << "]";
122
123 int mom = evrec->TargetNucleusPosition();
124 evrec->AddParticle(
125 ipdgc,kIStStableFinalState, mom,-1,-1,-1, 0,0,0,mass, 0,0,0,0);
126}
#define pDEBUG
Definition Messenger.h:63
virtual int TargetNucleusPosition(void) const
const Target & Tgt(void) const
const InitialState & InitState(void) const
Definition Interaction.h:69
static PDGLibrary * Instance(void)
TParticlePDG * Find(int pdgc, bool must_exist=true)
int Z(void) const
Definition Target.h:68
int A(void) const
Definition Target.h:70
bool IsNucleus(void) const
Definition Target.cxx:272
int IonPdgCode(int A, int Z)
Definition PDGUtils.cxx:71

References genie::Target::A(), genie::GHepRecord::AddParticle(), genie::PDGLibrary::Find(), genie::Interaction::InitState(), genie::PDGLibrary::Instance(), genie::pdg::IonPdgCode(), genie::Target::IsNucleus(), genie::kIStStableFinalState, LOG, pDEBUG, pINFO, genie::GHepRecord::Summary(), genie::GHepRecord::TargetNucleusPosition(), genie::InitialState::Tgt(), and genie::Target::Z().

Referenced by ProcessEventRecord().

◆ ProcessEventRecord()

void DMETargetRemnantGenerator::ProcessEventRecord ( GHepRecord * evrec) const
virtual

Implements genie::EventRecordVisitorI.

Definition at line 50 of file DMETargetRemnantGenerator.cxx.

51{
52 this -> AddElectronNeutrino (evrec);
53 this -> AddTargetNucleusRemnant (evrec);
54}
void AddTargetNucleusRemnant(GHepRecord *evrec) const
void AddElectronNeutrino(GHepRecord *evrec) const

References AddElectronNeutrino(), and AddTargetNucleusRemnant().


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