Class Reference for E1039 Core & Analysis Software
|
Runs G4 as a subsystem. More...
#include </dev/shm/kenichi/update-github-e1039-doc/e1039-core/simulation/g4main/PHG4Reco.h>
Public Member Functions | |
PHG4Reco (const std::string &name="PHG4RECO") | |
constructor More... | |
virtual | ~PHG4Reco () |
destructor More... | |
int | Init (PHCompositeNode *) |
full initialization More... | |
int | InitRun (PHCompositeNode *topNode) |
int | process_event (PHCompositeNode *) |
event processing method More... | |
int | ResetEvent (PHCompositeNode *) |
Clean up after each event. More... | |
int | End (PHCompositeNode *) |
end of run method More... | |
void | Print (const std::string &what=std::string()) const |
print info More... | |
void | registerSubsystem (PHG4Subsystem *subsystem) |
register subsystem More... | |
int | ApplyCommand (const std::string &cmd) |
interface to G4 cmd interpreter More... | |
int | StartGui () |
start the gui More... | |
int | InitField (PHCompositeNode *topNode) |
void | set_field (const float tesla) |
set default magnetic field strength with a constant magnetic field. Only valid if set_field_map() is not used. If available, Field map setting on DST take higher priority. More... | |
void | set_field_map (const std::string &fmap, const PHFieldConfig::FieldConfigTypes dim) |
void | set_field_map () |
void | set_field_rescale (const float rescale) |
set default scaling factor for input magnetic field map. If available, Field map setting on DST take higher priority. More... | |
void | set_optical_photon (bool b) |
speed-up options setters More... | |
void | set_energy_threshold (double t) |
void | set_zero_field_line (double z) |
void | save_DST_geometry (bool b) |
Save geometry from Geant4 to DST. More... | |
void | SetWorldSizeX (const double sx) |
void | SetWorldSizeY (const double sy) |
void | SetWorldSizeZ (const double sz) |
double | GetWorldSizeX () const |
double | GetWorldSizeY () const |
double | GetWorldSizeZ () const |
void | SetWorldShape (const std::string &s) |
void | SetWorldMaterial (const std::string &s) |
void | SetPhysicsList (const std::string &s) |
void | set_rapidity_coverage (const double eta) |
int | setupInputEventNodeReader (PHCompositeNode *) |
void | setGeneratorAction (G4VUserPrimaryGeneratorAction *action) |
PHG4Subsystem * | getSubsystem (const std::string &name) |
void | Dump_GDML (const std::string &filename) |
void | G4Verbosity (const int i) |
![]() | |
virtual | ~SubsysReco () |
virtual int | EndRun (const int) |
Called at the end of each run. More... | |
virtual int | Reset (PHCompositeNode *) |
Reset. More... | |
![]() | |
virtual | ~Fun4AllBase () |
virtual const std::string | Name () const |
Returns the name of this module. More... | |
virtual void | Name (const std::string &name) |
Sets the name of this module. More... | |
virtual void | Verbosity (const int ival) |
Sets the verbosity of this module (0 by default=quiet). More... | |
virtual void | Verbosity (enu_Verbosity ival) |
Sets the verbosity of this module (0 by default=quiet). More... | |
virtual int | Verbosity () const |
Gets the verbosity of this module. More... | |
Static Public Member Functions | |
static void | G4Seed (const unsigned int i) |
Protected Types | |
typedef std::list< PHG4Subsystem * > | SubsystemList |
list of subsystems More... | |
Protected Member Functions | |
int | InitUImanager () |
void | DefineMaterials () |
void | DefineRegions () |
![]() | |
SubsysReco (const std::string &name="NONAME") | |
![]() | |
Fun4AllBase (const std::string &name="NONAME") | |
Additional Inherited Members | |
![]() | |
enum | enu_Verbosity { VERBOSITY_QUIET = 0 , VERBOSITY_SOME = 1 , VERBOSITY_MORE = 2 , VERBOSITY_EVEN_MORE = 3 , VERBOSITY_A_LOT = 4 , VERBOSITY_MAX = INT_MAX - 10 } |
Runs G4 as a subsystem.
Definition at line 36 of file PHG4Reco.h.
|
protected |
list of subsystems
Definition at line 167 of file PHG4Reco.h.
PHG4Reco::PHG4Reco | ( | const std::string & | name = "PHG4RECO" | ) |
|
virtual |
destructor
Definition at line 153 of file PHG4Reco.cc.
References field_, gui_thread, runManager_, subsystems_, uisession_, and visManager.
int PHG4Reco::ApplyCommand | ( | const std::string & | cmd | ) |
interface to G4 cmd interpreter
Definition at line 568 of file PHG4Reco.cc.
References submit_bnl::cmd, InitUImanager(), and UImanager.
|
protected |
ePHENIX TPC - Jin Huang jhuan Ref: B. Yu et al. A gem based tpc for the legs experiment. In Nuclear Science Symposium Conference Record, 2005 IEEE, volume 2, pages 924-928, 2005. doi:10.1109/NSSMIC.2005.1596405. g@bn l.gov
Definition at line 753 of file PHG4Reco.cc.
References Fun4AllBase::verbosity.
Referenced by Init().
|
protected |
Definition at line 1368 of file PHG4Reco.cc.
Referenced by Init().
void PHG4Reco::Dump_GDML | ( | const std::string & | filename | ) |
Definition at line 562 of file PHG4Reco.cc.
References detector_, PHG4GDMLUtility::Dump_GDML(), and PHG4PhenixDetector::GetPhysicalVolume().
Referenced by InitRun().
|
virtual |
|
static |
Definition at line 727 of file PHG4Reco.cc.
Referenced by Init().
void PHG4Reco::G4Verbosity | ( | const int | i | ) |
Definition at line 1405 of file PHG4Reco.cc.
References runManager_.
PHG4Subsystem * PHG4Reco::getSubsystem | ( | const std::string & | name | ) |
Definition at line 1386 of file PHG4Reco.cc.
References subsystems_, and Fun4AllBase::verbosity.
|
inline |
Definition at line 110 of file PHG4Reco.h.
References WorldSize.
|
inline |
Definition at line 111 of file PHG4Reco.h.
References WorldSize.
|
inline |
Definition at line 112 of file PHG4Reco.h.
References WorldSize.
|
virtual |
full initialization
Reimplemented from SubsysReco.
Definition at line 170 of file PHG4Reco.cc.
References DefineMaterials(), DefineRegions(), G4Seed(), PHWHERE, physicslist, runManager_, subsystems_, uisession_, and Fun4AllBase::verbosity.
int PHG4Reco::InitField | ( | PHCompositeNode * | topNode | ) |
Definition at line 268 of file PHG4Reco.cc.
References Fun4AllReturnCodes::EVENT_OK, field_, fieldmapfile, PHFieldUtility::GetFieldMapNode(), magfield, magfield_rescale, mapdim, Fun4AllBase::Verbosity(), and Fun4AllBase::verbosity.
Referenced by InitRun().
|
virtual |
Called for first event when run number is known. Typically this is where you may want to fetch data from database, because you know the run number.
Reimplemented from SubsysReco.
Definition at line 322 of file PHG4Reco.cc.
References PHG4PhenixEventAction::AddAction(), PHG4PhenixSteppingAction::AddAction(), PHG4PhenixTrackingAction::AddAction(), PHG4PhenixDetector::AddDetector(), detector_, Dump_GDML(), energy_threshold_, Fun4AllReturnCodes::EVENT_OK, eventAction_, field_, PHGeomUtility::GenerateGeometryFileName(), G4TBMagneticFieldSetup::GetDummyFieldManager(), PHGeomUtility::ImportGeomFile(), InitField(), recoConsts::instance(), optical_photon_, PHGeomUtility::RemoveGeometryFile(), runManager_, save_DST_geometry_, PHG4PhenixSteppingAction::set_energy_threshold(), PHFlag::set_FloatFlag(), setupInputEventNodeReader(), PHG4PhenixDetector::SetWorldMaterial(), PHG4PhenixDetector::SetWorldShape(), PHG4PhenixDetector::SetWorldSizeX(), PHG4PhenixDetector::SetWorldSizeY(), PHG4PhenixDetector::SetWorldSizeZ(), PHG4PhenixDetector::SetZeroFieldManager(), PHG4PhenixDetector::SetZeroFieldStartZ(), steppingAction_, subsystems_, trackingAction_, uisession_, Fun4AllBase::verbosity, PHG4PhenixDetector::Verbosity(), PHG4UIsession::Verbosity(), worldmaterial, worldshape, WorldSize, and zero_field_line_.
|
protected |
Definition at line 588 of file PHG4Reco.cc.
References UImanager, and visManager.
Referenced by ApplyCommand(), and StartGui().
|
virtual |
print info
Reimplemented from SubsysReco.
Definition at line 679 of file PHG4Reco.cc.
References subsystems_.
|
virtual |
event processing method
Reimplemented from SubsysReco.
Definition at line 602 of file PHG4Reco.cc.
References _timer, Fun4AllReturnCodes::ABORTEVENT, generatorAction_, PHTimeServer::timer::get(), PHG4InEvent::identify(), PHWHERE, PHTimer::restart(), runManager_, PHG4PrimaryGeneratorAction::SetInEvent(), PHTimer::stop(), subsystems_, and Fun4AllBase::Verbosity().
|
inline |
|
virtual |
Clean up after each event.
Reimplemented from SubsysReco.
Definition at line 663 of file PHG4Reco.cc.
References subsystems_.
|
inline |
Save geometry from Geant4 to DST.
Definition at line 106 of file PHG4Reco.h.
References save_DST_geometry_.
|
inline |
Definition at line 102 of file PHG4Reco.h.
References energy_threshold_.
|
inline |
set default magnetic field strength with a constant magnetic field. Only valid if set_field_map() is not used. If available, Field map setting on DST take higher priority.
Definition at line 77 of file PHG4Reco.h.
References magfield.
void PHG4Reco::set_field_map | ( | ) |
Set the magnetic field maps/strengths. This will be the default setting method in E1039. It takes the parameter values from recoConsts. Thus you can change parameters by calling recoConsts::set_DoubleFlag() etc. beforehand.
Definition at line 309 of file PHG4Reco.cc.
References PHFlag::get_CharFlag(), PHFlag::get_DoubleFlag(), recoConsts::instance(), PHFieldConfig::RegionalConst, and Fun4AllBase::verbosity.
|
inline |
Set default field map. If available, Field map setting on DST take higher priority.
[in] | fmap | Field map ROOT file |
[in] | dim | Field map format. See PHFieldConfig::FieldConfigTypes for available formats. |
Definition at line 85 of file PHG4Reco.h.
References fieldmapfile, and mapdim.
|
inline |
set default scaling factor for input magnetic field map. If available, Field map setting on DST take higher priority.
Definition at line 98 of file PHG4Reco.h.
References magfield_rescale.
|
inline |
void PHG4Reco::set_rapidity_coverage | ( | const double | eta | ) |
Definition at line 721 of file PHG4Reco.cc.
References _eta_coverage, and PHG4Utils::SetPseudoRapidityCoverage().
|
inline |
Definition at line 103 of file PHG4Reco.h.
References zero_field_line_.
void PHG4Reco::setGeneratorAction | ( | G4VUserPrimaryGeneratorAction * | action | ) |
Definition at line 712 of file PHG4Reco.cc.
References runManager_.
|
inline |
Definition at line 115 of file PHG4Reco.h.
References physicslist.
int PHG4Reco::setupInputEventNodeReader | ( | PHCompositeNode * | topNode | ) |
Definition at line 694 of file PHG4Reco.cc.
References PHCompositeNode::addNode(), PHNodeIterator::findFirst(), generatorAction_, and runManager_.
Referenced by InitRun().
|
inline |
Definition at line 114 of file PHG4Reco.h.
References worldmaterial.
|
inline |
Definition at line 113 of file PHG4Reco.h.
References worldshape.
|
inline |
Definition at line 107 of file PHG4Reco.h.
References WorldSize.
|
inline |
Definition at line 108 of file PHG4Reco.h.
References WorldSize.
|
inline |
Definition at line 109 of file PHG4Reco.h.
References WorldSize.
int PHG4Reco::StartGui | ( | ) |
start the gui
Definition at line 576 of file PHG4Reco.cc.
References g4guithread(), gui_thread, and InitUImanager().
|
protected |
Definition at line 173 of file PHG4Reco.h.
Referenced by set_rapidity_coverage().
|
protected |
|
protected |
pointer to detector
Definition at line 152 of file PHG4Reco.h.
Referenced by Dump_GDML(), and InitRun().
|
protected |
Definition at line 187 of file PHG4Reco.h.
Referenced by InitRun(), and set_energy_threshold().
|
protected |
|
protected |
magnetic field
Definition at line 143 of file PHG4Reco.h.
Referenced by InitField(), InitRun(), and ~PHG4Reco().
|
protected |
Definition at line 175 of file PHG4Reco.h.
Referenced by InitField(), and set_field_map().
|
protected |
event generator (read from PHG4INEVENT node)
Definition at line 164 of file PHG4Reco.h.
Referenced by process_event(), and setupInputEventNodeReader().
|
protected |
Definition at line 138 of file PHG4Reco.h.
Referenced by InitField(), and set_field().
|
protected |
Definition at line 139 of file PHG4Reco.h.
Referenced by InitField(), and set_field_rescale().
|
protected |
Definition at line 174 of file PHG4Reco.h.
Referenced by InitField(), and set_field_map().
|
protected |
speed up options
Definition at line 186 of file PHG4Reco.h.
Referenced by InitRun(), and set_optical_photon().
|
protected |
Definition at line 178 of file PHG4Reco.h.
Referenced by Init(), and SetPhysicsList().
|
protected |
pointer to geant run manager
Definition at line 146 of file PHG4Reco.h.
Referenced by G4Verbosity(), Init(), InitRun(), process_event(), setGeneratorAction(), setupInputEventNodeReader(), and ~PHG4Reco().
|
protected |
Definition at line 180 of file PHG4Reco.h.
Referenced by InitRun(), and save_DST_geometry().
|
protected |
|
protected |
Definition at line 168 of file PHG4Reco.h.
Referenced by getSubsystem(), Init(), InitRun(), Print(), process_event(), registerSubsystem(), ResetEvent(), and ~PHG4Reco().
|
protected |
|
protected |
pointer to geant ui session
Definition at line 149 of file PHG4Reco.h.
Referenced by Init(), InitRun(), and ~PHG4Reco().
|
protected |
Definition at line 171 of file PHG4Reco.h.
Referenced by InitUImanager(), and ~PHG4Reco().
|
protected |
Definition at line 177 of file PHG4Reco.h.
Referenced by InitRun(), and SetWorldMaterial().
|
protected |
Definition at line 176 of file PHG4Reco.h.
Referenced by InitRun(), and SetWorldShape().
|
protected |
Definition at line 140 of file PHG4Reco.h.
Referenced by GetWorldSizeX(), GetWorldSizeY(), GetWorldSizeZ(), InitRun(), PHG4Reco(), SetWorldSizeX(), SetWorldSizeY(), and SetWorldSizeZ().
|
protected |
Definition at line 188 of file PHG4Reco.h.
Referenced by InitRun(), and set_zero_field_line().