Belle II Software development
HitLevelInfoWriterModule Class Reference

Extracts dE/dx information for calibration testing. More...

#include <HitLevelInfoWriter.h>

Inheritance diagram for HitLevelInfoWriterModule:
Module PathElement

Public Types

enum  EModulePropFlags {
  c_Input = 1 ,
  c_Output = 2 ,
  c_ParallelProcessingCertified = 4 ,
  c_HistogramManager = 8 ,
  c_InternalSerializer = 16 ,
  c_TerminateInAllProcesses = 32 ,
  c_DontCollectStatistics = 64
}
 Each module can be tagged with property flags, which indicate certain features of the module. More...
 
typedef ModuleCondition::EAfterConditionPath EAfterConditionPath
 Forward the EAfterConditionPath definition from the ModuleCondition.
 

Public Member Functions

 HitLevelInfoWriterModule ()
 Default constructor.
 
virtual ~HitLevelInfoWriterModule ()
 Destructor.
 
virtual void initialize () override
 Initialize the module.
 
virtual void event () override
 This method is called for each event.
 
virtual void terminate () override
 End of the event processing.
 
void bookOutput (std::string filename)
 Create the output TFiles and TTrees.
 
void recalculateDedx (CDCDedxTrack *dedxTrack, std::map< int, std::vector< double > > &l_var, double(&cdcChi)[Const::ChargedStable::c_SetSize])
 Function to recalculate the dedx with latest constants.
 
double GetCorrection (int &adc, int layer, int wireID, double doca, double enta, double costheta, double ring, double time) const
 Function to get the correction factor.
 
void HadronCorrection (double costheta, double &dedx) const
 Function to apply the hadron correction.
 
double D2I (const double cosTheta, const double D) const
 hadron saturation parameterization part 2
 
double I2D (const double cosTheta, const double I) const
 hadron saturation parameterization part 1
 
void calculateMeans (double *mean, double *truncatedMean, double *truncatedMeanErr, const std::vector< double > &dedx) const
 Save arithmetic and truncated mean for the 'dedx' values.
 
void saveChiValue (double(&chi)[Const::ChargedStable::c_SetSize], CDCDedxTrack *dedxTrack, double dedx) const
 for all particles, save chi values into 'chi' chi array of chi values to be modified
 
virtual std::vector< std::string > getFileNames (bool outputFiles)
 Return a list of output filenames for this modules.
 
virtual void beginRun ()
 Called when entering a new run.
 
virtual void endRun ()
 This method is called if the current run ends.
 
const std::string & getName () const
 Returns the name of the module.
 
const std::string & getType () const
 Returns the type of the module (i.e.
 
const std::string & getPackage () const
 Returns the package this module is in.
 
const std::string & getDescription () const
 Returns the description of the module.
 
void setName (const std::string &name)
 Set the name of the module.
 
void setPropertyFlags (unsigned int propertyFlags)
 Sets the flags for the module properties.
 
LogConfiggetLogConfig ()
 Returns the log system configuration.
 
void setLogConfig (const LogConfig &logConfig)
 Set the log system configuration.
 
void setLogLevel (int logLevel)
 Configure the log level.
 
void setDebugLevel (int debugLevel)
 Configure the debug messaging level.
 
void setAbortLevel (int abortLevel)
 Configure the abort log level.
 
void setLogInfo (int logLevel, unsigned int logInfo)
 Configure the printed log information for the given level.
 
void if_value (const std::string &expression, const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End)
 Add a condition to the module.
 
void if_false (const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End)
 A simplified version to add a condition to the module.
 
void if_true (const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End)
 A simplified version to set the condition of the module.
 
bool hasCondition () const
 Returns true if at least one condition was set for the module.
 
const ModuleConditiongetCondition () const
 Return a pointer to the first condition (or nullptr, if none was set)
 
const std::vector< ModuleCondition > & getAllConditions () const
 Return all set conditions for this module.
 
bool evalCondition () const
 If at least one condition was set, it is evaluated and true returned if at least one condition returns true.
 
std::shared_ptr< PathgetConditionPath () const
 Returns the path of the last true condition (if there is at least one, else reaturn a null pointer).
 
Module::EAfterConditionPath getAfterConditionPath () const
 What to do after the conditional path is finished.
 
std::vector< std::shared_ptr< Path > > getAllConditionPaths () const
 Return all condition paths currently set (no matter if the condition is true or not).
 
bool hasProperties (unsigned int propertyFlags) const
 Returns true if all specified property flags are available in this module.
 
bool hasUnsetForcedParams () const
 Returns true and prints error message if the module has unset parameters which the user has to set in the steering file.
 
const ModuleParamListgetParamList () const
 Return module param list.
 
template<typename T >
ModuleParam< T > & getParam (const std::string &name) const
 Returns a reference to a parameter.
 
bool hasReturnValue () const
 Return true if this module has a valid return value set.
 
int getReturnValue () const
 Return the return value set by this module.
 
std::shared_ptr< PathElementclone () const override
 Create an independent copy of this module.
 
std::shared_ptr< boost::python::list > getParamInfoListPython () const
 Returns a python list of all parameters.
 

Static Public Member Functions

static void exposePythonAPI ()
 Exposes methods of the Module class to Python.
 

Protected Member Functions

virtual void def_initialize ()
 Wrappers to make the methods without "def_" prefix callable from Python.
 
virtual void def_beginRun ()
 Wrapper method for the virtual function beginRun() that has the implementation to be used in a call from Python.
 
virtual void def_event ()
 Wrapper method for the virtual function event() that has the implementation to be used in a call from Python.
 
virtual void def_endRun ()
 This method can receive that the current run ends as a call from the Python side.
 
virtual void def_terminate ()
 Wrapper method for the virtual function terminate() that has the implementation to be used in a call from Python.
 
void setDescription (const std::string &description)
 Sets the description of the module.
 
void setType (const std::string &type)
 Set the module type.
 
template<typename T >
void addParam (const std::string &name, T &paramVariable, const std::string &description, const T &defaultValue)
 Adds a new parameter to the module.
 
template<typename T >
void addParam (const std::string &name, T &paramVariable, const std::string &description)
 Adds a new enforced parameter to the module.
 
void setReturnValue (int value)
 Sets the return value for this module as integer.
 
void setReturnValue (bool value)
 Sets the return value for this module as bool.
 
void setParamList (const ModuleParamList &params)
 Replace existing parameter list.
 

Private Member Functions

void fillTrack (const TrackFitResult *fitResult)
 Fill the TTree with the information from the track fit.
 
void fillDedx (CDCDedxTrack *dedxTrack)
 Fill the TTree with the information from a CDCDedxTrack object.
 
void clearEntries ()
 Clear the arrays before filling an event.
 
std::list< ModulePtrgetModules () const override
 no submodules, return empty list
 
std::string getPathString () const override
 return the module name.
 
void setParamPython (const std::string &name, const boost::python::object &pyObj)
 Implements a method for setting boost::python objects.
 
void setParamPythonDict (const boost::python::dict &dictionary)
 Implements a method for reading the parameter values from a boost::python dictionary.
 

Private Attributes

std::string m_strOutputBaseName
 Base name for the output ROOT files.
 
std::vector< std::string > m_strParticleList
 Vector of ParticleLists to write out.
 
std::vector< std::string > m_filename
 full names of the output ROOT files
 
std::vector< TFile * > m_file
 output ROOT files
 
std::vector< TTree * > m_tree
 output ROOT trees
 
StoreArray< CDCDedxTrackm_dedxTracks
 Required array of CDCDedxTracks.
 
StoreArray< Trackm_tracks
 Required array of input Tracks.
 
StoreArray< TrackFitResultm_trackFitResults
 Required array of input TrackFitResults.
 
StoreArray< ECLClusterm_eclClusters
 Required array of input ECLClusters.
 
StoreArray< KLMClusterm_klmClusters
 Required array of input KLMClusters.
 
StoreObjPtr< EventLevelTriggerTimeInfom_TTDInfo
 Store Object Ptr: EventLevelTriggerTimeInfo.
 
int m_expID { -1}
 experiment in which this Track was found
 
int m_runID { -1}
 run in which this Track was found
 
int m_eventID { -1}
 event in which this Track was found
 
double m_injring { -1.0}
 HER injection status.
 
double m_injtime { -1.0}
 time since last injection in micro seconds
 
double m_d0 {0.}
 Signed distance to the POCA in the r-phi plane.
 
double m_z0 {0.}
 z coordinate of the POCA
 
double m_dz { -1.}
 vertex or POCA in case of tracks z in respect to IPs
 
double m_dr { -1.}
 track d0 relative to IP
 
double m_dphi { -1.}
 POCA in degrees in respect to IP.
 
double m_vx0 {0.}
 X coordinate of track POCA to origin.
 
double m_vy0 {0.}
 Y coordinate of track POCA to origin.
 
double m_vz0 {0.}
 Z coordinate of track POCA to origin.
 
double m_tanlambda { -1.}
 Slope of the track in the r-z plane.
 
double m_phi0 { -1.}
 Angle of the transverse momentum in the r-phi plane.
 
double m_chi2 { -1.}
 chi^2 from track fit
 
double m_nCDChits { -1.}
 Number of CDC hits associated to the track.
 
int m_inCDC { -1}
 frack is CDC acceptance or not
 
int m_trackID { -1}
 ID number of the Track.
 
double m_length { -1.}
 total path length of the Track
 
int m_charge {0}
 the charge for this Track
 
double m_cosTheta { -2.}
 cos(theta) for the track
 
double m_pCDC { -1.}
 momentum valid in CDC
 
double m_p { -1.}
 momentum from tracking
 
double m_pt { -1.}
 transverse momentum from tracking
 
double m_phi { -1.}
 phi for the track
 
double m_ioasym { -1.}
 asymmetry in increasing vs decreasing layer numbers per track
 
double m_theta { -2.}
 cos(theta) for the track
 
double m_PDG { -1.}
 MC PID.
 
double m_mean { -1.}
 dE/dx averaged
 
double m_trunc { -1.}
 dE/dx averaged, truncated mean, with corrections
 
double m_truncNoSat { -1.}
 dE/dx averaged, truncated mean, with corrections (not hadron)
 
double m_error { -1.}
 standard deviation of the truncated mean
 
double m_eop { -1.}
 energy over momentum in the calorimeter
 
double m_e { -1.}
 energy in the calorimeter
 
double m_e1_9 { -1.}
 ratio of energies of the central 1 crystal vs 3x3 crystals
 
double m_e9_21 { -1.}
 ratio of energies of the central 3x3 crystal vs 5x5 crystals
 
double m_klmLayers { -1.}
 number of klm layers with hits
 
double m_eclsnHits { -1.}
 
double m_scale { -1.}
 calibration scale factor
 
double m_cosCor { -1.}
 calibration cosine correction
 
double m_cosEdgeCor { -1.}
 calibration cosine edge correction
 
double m_runGain { -1.}
 calibration run gain
 
double m_timeGain { -1.}
 calibration injection time gain
 
double m_timeReso { -1.}
 calibration injection time reso
 
double m_chieOld { -1.}
 chi value for electron hypothesis
 
double m_chimuOld { -1.}
 chi value for muon hypothesis
 
double m_chipiOld { -1.}
 chi value for pion hypothesis
 
double m_chikOld { -1.}
 chi value for kaon hypothesis
 
double m_chipOld { -1.}
 chi value for proton hypothesis
 
double m_chidOld { -1.}
 chi value for deuteron hypothesis
 
double m_chie { -1.}
 modified chi value for electron hypothesis
 
double m_chimu { -1.}
 modified chi value for muon hypothesis
 
double m_chipi { -1.}
 modified chi value for pion hypothesis
 
double m_chik { -1.}
 modified chi value for kaon hypothesis
 
double m_chip { -1.}
 modified chi value for proton hypothesis
 
double m_chid { -1.}
 modified chi value for deuteron hypothesis
 
double m_prese { -1.}
 pred reso for electron hypothesis
 
double m_presmu { -1.}
 pred reso for muon hypothesis
 
double m_prespi { -1.}
 pred reso for pion hypothesis
 
double m_presk { -1.}
 pred reso for kaon hypothesis
 
double m_presp { -1.}
 pred reso for proton hypothesis
 
double m_presd { -1.}
 pred reso for deuteron hypothesis
 
double m_pmeane { -1.}
 pred mean for electron hypothesis
 
double m_pmeanmu { -1.}
 pred mean for muon hypothesis
 
double m_pmeanpi { -1.}
 pred mean for pion hypothesis
 
double m_pmeank { -1.}
 pred mean for kaon hypothesis
 
double m_pmeanp { -1.}
 pred mean for proton hypothesis
 
double m_pmeand { -1.}
 pred mean for deuteron hypothesis
 
int l_nhits { -1}
 the total number of layer hits for this Track
 
int l_nhitsused { -1}
 the total number of layer hits used for this Track
 
int l_nhitscombined [kMaxHits] = {}
 the number of hits combined this layer
 
int l_wirelongesthit [kMaxHits] = {}
 the wire number of longest hit in this layer
 
int l_layer [kMaxHits] = {}
 layer number
 
double l_path [kMaxHits] = {}
 distance travelled in this layer
 
double l_dedx [kMaxHits] = {}
 dE/dx for this layer
 
int h_nhits { -1}
 the number of good hits for this Track
 
int h_lwire [kMaxHits] = {}
 sense wire within layer
 
int h_wire [kMaxHits] = {}
 sense wire ID
 
int h_layer [kMaxHits] = {}
 layer number
 
double h_path [kMaxHits] = {}
 path length in cell
 
double h_dedx [kMaxHits] = {}
 charge per path length
 
double h_adcraw [kMaxHits] = {}
 charge per hit
 
double h_adccorr [kMaxHits] = {}
 charge per hit corr by nonlinear ADC
 
double h_doca [kMaxHits] = {}
 distance of closest approach
 
double h_ndoca [kMaxHits] = {}
 normalized distance of closest approach
 
double h_ndocaRS [kMaxHits] = {}
 normalized +RS distance of closest approach
 
double h_enta [kMaxHits] = {}
 entrance angle
 
double h_entaRS [kMaxHits] = {}
 normalized + RS distance of entrance angle
 
double h_driftT [kMaxHits] = {}
 drift time
 
double h_driftD [kMaxHits] = {}
 drift distance
 
double h_facnladc [kMaxHits] = {}
 calibration hit gain
 
double h_wireGain [kMaxHits] = {}
 calibration hit gain
 
double h_twodCor [kMaxHits] = {}
 calibration 2D correction
 
double h_onedCor [kMaxHits] = {}
 calibration 1D cleanup correction
 
double h_WeightPionHypo [kMaxHits] = {}
 weight for pion hypothesis from KalmanFitterInfo
 
double h_WeightKaonHypo [kMaxHits] = {}
 weight for kaon hypothesis from KalmanFitterInfo
 
double h_WeightProtonHypo [kMaxHits] = {}
 weight for proton hypothesis from KalmanFitterInfo
 
int h_foundByTrackFinder [kMaxHits] = {}
 the 'found by track finder' flag for the given hit
 
DBObjPtr< CDCDedxScaleFactorm_DBScaleFactor
 Scale factor to make electrons ~1.
 
DBObjPtr< CDCDedxWireGainm_DBWireGains
 Wire gain DB object.
 
DBObjPtr< CDCDedxRunGainm_DBRunGain
 Run gain DB object.
 
DBObjPtr< CDCDedxInjectionTimem_DBInjectTime
 time gain/reso DB object
 
DBObjPtr< CDCDedxCosineCorm_DBCosineCor
 Electron saturation correction DB object.
 
DBObjPtr< CDCDedx2DCellm_DB2DCell
 2D correction DB object
 
DBObjPtr< CDCDedx1DCellm_DB1DCell
 1D correction DB object
 
DBObjPtr< CDCDedxADCNonLinearitym_DBNonlADC
 hadron saturation non linearity
 
DBObjPtr< CDCDedxCosineEdgem_DBCosEdgeCor
 cosine edge calibration
 
DBObjPtr< CDCDedxHadronCorm_DBHadronCor
 hadron saturation parameters
 
std::vector< double > m_hadronpars
 hadron saturation parameters
 
bool m_isDeadwire
 write only active wires
 
bool m_isHitLevel
 Flag to switch on/off hit level info.
 
bool m_isExtraVar
 Flag to switch on/off extra level info and some available w/ release/5 only.
 
bool m_isRelative
 Flag to switch on/off relative constants.
 
bool m_isCorrection
 Flag to switch on/off corrections.
 
std::string m_name
 The name of the module, saved as a string (user-modifiable)
 
std::string m_type
 The type of the module, saved as a string.
 
std::string m_package
 Package this module is found in (may be empty).
 
std::string m_description
 The description of the module.
 
unsigned int m_propertyFlags
 The properties of the module as bitwise or (with |) of EModulePropFlags.
 
LogConfig m_logConfig
 The log system configuration of the module.
 
ModuleParamList m_moduleParamList
 List storing and managing all parameter of the module.
 
bool m_hasReturnValue
 True, if the return value is set.
 
int m_returnValue
 The return value.
 
std::vector< ModuleConditionm_conditions
 Module condition, only non-null if set.
 

Static Private Attributes

static const int kMaxHits = 200
 default hit level index
 

Detailed Description

Extracts dE/dx information for calibration testing.

Writes a ROOT file.

Definition at line 64 of file HitLevelInfoWriter.h.

Member Typedef Documentation

◆ EAfterConditionPath

Forward the EAfterConditionPath definition from the ModuleCondition.

Definition at line 88 of file Module.h.

Member Enumeration Documentation

◆ EModulePropFlags

enum EModulePropFlags
inherited

Each module can be tagged with property flags, which indicate certain features of the module.

Enumerator
c_Input 

This module is an input module (reads data).

c_Output 

This module is an output module (writes data).

c_ParallelProcessingCertified 

This module can be run in parallel processing mode safely (All I/O must be done through the data store, in particular, the module must not write any files.)

c_HistogramManager 

This module is used to manage histograms accumulated by other modules.

c_InternalSerializer 

This module is an internal serializer/deserializer for parallel processing.

c_TerminateInAllProcesses 

When using parallel processing, call this module's terminate() function in all processes().

This will also ensure that there is exactly one process (single-core if no parallel modules found) or at least one input, one main and one output process.

c_DontCollectStatistics 

No statistics is collected for this module.

Definition at line 77 of file Module.h.

77 {
78 c_Input = 1,
79 c_Output = 2,
85 };
@ c_HistogramManager
This module is used to manage histograms accumulated by other modules.
Definition: Module.h:81
@ c_Input
This module is an input module (reads data).
Definition: Module.h:78
@ c_DontCollectStatistics
No statistics is collected for this module.
Definition: Module.h:84
@ c_ParallelProcessingCertified
This module can be run in parallel processing mode safely (All I/O must be done through the data stor...
Definition: Module.h:80
@ c_InternalSerializer
This module is an internal serializer/deserializer for parallel processing.
Definition: Module.h:82
@ c_Output
This module is an output module (writes data).
Definition: Module.h:79
@ c_TerminateInAllProcesses
When using parallel processing, call this module's terminate() function in all processes().
Definition: Module.h:83

Constructor & Destructor Documentation

◆ HitLevelInfoWriterModule()

Default constructor.

Definition at line 19 of file HitLevelInfoWriter.cc.

19 : Module()
20{
21
22 setDescription("Extract dE/dx information for calibration development.");
23
24 addParam("outputBaseName", m_strOutputBaseName, "Suffix for output file name", string("HLInfo.root"));
25 addParam("particleLists", m_strParticleList, "Vector of ParticleLists to save", vector<string>());
26 addParam("enableHitLevel", m_isHitLevel, "True or False for Hit level variables", false);
27 addParam("m_isExtraVar", m_isExtraVar, "True or False for extra track/hit level variables", false);
28 addParam("nodeadwire", m_isDeadwire, "True or False for deadwire hit variables", false);
29 addParam("relativeCorrections", m_isRelative, "If true, apply corrections relative to those used in production", false);
30 addParam("corrections", m_isCorrection, "If true, apply corrections", true);
31
32}
std::string m_strOutputBaseName
Base name for the output ROOT files.
bool m_isHitLevel
Flag to switch on/off hit level info.
bool m_isExtraVar
Flag to switch on/off extra level info and some available w/ release/5 only.
bool m_isCorrection
Flag to switch on/off corrections.
bool m_isDeadwire
write only active wires
bool m_isRelative
Flag to switch on/off relative constants.
std::vector< std::string > m_strParticleList
Vector of ParticleLists to write out.
void setDescription(const std::string &description)
Sets the description of the module.
Definition: Module.cc:214
Module()
Constructor.
Definition: Module.cc:30
void addParam(const std::string &name, T &paramVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
Definition: Module.h:560

◆ ~HitLevelInfoWriterModule()

Destructor.

Definition at line 34 of file HitLevelInfoWriter.cc.

34{ }

Member Function Documentation

◆ beginRun()

virtual void beginRun ( void  )
inlinevirtualinherited

Called when entering a new run.

Called at the beginning of each run, the method gives you the chance to change run dependent constants like alignment parameters, etc.

This method can be implemented by subclasses.

Reimplemented in ARICHBackgroundModule, BeamabortModule, BgoModule, CaveModule, ClawModule, CLAWSModule, DosiModule, FANGSModule, He3tubeModule, MicrotpcModule, Ph1bpipeModule, Ph1sustrModule, PindiodeModule, PlumeModule, QcsmonitorModule, SrsensorModule, GetEventFromSocketModule, CalibrationCollectorModule, EventsOfDoomBusterModule, CosmicsAlignmentValidationModule, EnergyBiasCorrectionModule, ChargedPidMVAModule, ChargedPidMVAMulticlassModule, CurlTaggerModule, LowEnergyPi0IdentificationExpertModule, LowEnergyPi0VetoExpertModule, ParticleVertexFitterModule, PhotonEfficiencySystematicsModule, TagVertexModule, TreeFitterModule, arichBtestModule, ARICHDigitizerModule, ARICHDQMModule, ARICHRateCalModule, ARICHReconstructorModule, B2BIIMCParticlesMonitorModule, B2BIIConvertBeamParamsModule, B2BIIConvertMdstModule, B2BIIFixMdstModule, B2BIIMdstInputModule, BelleMCOutputModule, BeamBkgGeneratorModule, BeamBkgHitRateMonitorModule, BeamBkgMixerModule, BeamBkgTagSetterModule, BGOverlayInputModule, AnalysisPhase1StudyModule, NtuplePhase1_v6Module, ReprocessorModule, BeamabortStudyModule, BeamDigitizerModule, BgoDigitizerModule, BgoStudyModule, ClawDigitizerModule, ClawStudyModule, ClawsDigitizerModule, ClawsStudyModule, CsiDigitizer_v2Module, CsIDigitizerModule, CsiModule, CsiStudy_v2Module, CsIStudyModule, DosiDigitizerModule, DosiStudyModule, FANGSDigitizerModule, FANGSStudyModule, He3DigitizerModule, He3tubeStudyModule, MicrotpcStudyModule, TpcDigitizerModule, PinDigitizerModule, PindiodeStudyModule, PlumeDigitizerModule, QcsmonitorDigitizerModule, QcsmonitorStudyModule, CDCCosmicAnalysisModule, CDCCRTestModule, cdcDQM7Module, CDCDQMModule, CDCPackerModule, CDCRecoTrackFilterModule, CDCUnpackerModule, DAQPerfModule, RxSocketModule, TxSocketModule, DqmHistoManagerModule, MonitorDataModule, TrackAnaModule, Ds2SampleModule, ReceiveEventModule, HLTDQM2ZMQModule, ElapsedTimeModule, DeSerializerPXDModule, GenRawSendModule, SerializerModule, CertifyParallelModule, Ds2RawModule, Ds2RbufModule, EvReductionModule, FastRbuf2DsModule, Raw2DsModule, RawInputModule, Rbuf2DsModule, Rbuf2RbufModule, Ds2RawFileModule, PartialSeqRootReaderModule, SeqRootMergerModule, StorageDeserializerModule, StorageSerializerModule, IPDQMModule, PhysicsObjectsDQMModule, PhysicsObjectsMiraBelleBhabhaModule, PhysicsObjectsMiraBelleDst2Module, PhysicsObjectsMiraBelleDstModule, PhysicsObjectsMiraBelleHadronModule, PhysicsObjectsMiraBelleModule, ECLBackgroundModule, ECLChargedPIDModule, ECLChargedPIDDataAnalysisModule, ECLChargedPIDDataAnalysisValidationModule, ECLChargedPIDMVAModule, ECLClusterPSDModule, ECLCovarianceMatrixModule, ECLCRFinderModule, ECLDataAnalysisModule, ECLDigitCalibratorModule, ECLDigitizerModule, ECLDigitizerPureCsIModule, EclDisplayModule, ECLDQMModule, ECLDQMConnectedRegionsModule, ECLDQMEXTENDEDModule, ECLDQMOutOfTimeDigitsModule, ECLFinalizerModule, ECLHitDebugModule, ECLLocalMaximumFinderModule, ECLLocalRunCalibratorModule, ECLLOMModule, ECLPackerModule, ECLShowerCorrectorModule, ECLShowerShapeModule, ECLSplitterN1Module, ECLSplitterN2Module, ECLUnpackerModule, ECLWaveformFitModule, HistoModule, SubEventModule, SwitchDataStoreModule, EventInfoPrinterModule, EventLimiterModule, IoVDependentConditionModule, ProgressModule, RandomBarrierModule, GearboxModule, HistoManagerModule, StatisticsSummaryModule, SeqRootInputModule, SeqRootOutputModule, RxModule, TxModule, EvtGenDecayModule, EvtGenInputModule, OverrideGenerationFlagsModule, KKGenInputModule, CreateFieldMapModule, ExportGeometryModule, SoftwareTriggerModule, SoftwareTriggerHLTDQMModule, StatisticsTimingHLTDQMModule, BKLMAnaModule, BKLMDigitAnalyzerModule, BKLMSimHistogrammerModule, BKLMTrackingModule, EKLMDataCheckerModule, KLMClusterAnaModule, KLMClusterEfficiencyModule, KLMClustersReconstructorModule, KLMDigitizerModule, KLMDigitTimeShifterModule, KLMDQMModule, KLMDQM2Module, KLMPackerModule, KLMReconstructorModule, KLMScintillatorSimulatorModule, KLMUnpackerModule, MVAExpertModule, MVAMultipleExpertsModule, MVAPrototypeModule, AWESOMEBasicModule, PXDBackgroundModule, PXDRawDQMChipsModule, PXDClustersFromTracksModule, PXDPerformanceModule, PXDClusterizerModule, Convert2RawDetModule, CDCDedxDQMModule, CDCDedxValidationModule, EventT0DQMModule, EventT0ValidationModule, DataWriterModule, ECLExpertModule, KLMExpertModule, KlongValidationModule, KLMMuonIDDNNExpertModule, FullSimModule, MaterialScanModule, SVDBackgroundModule, SVDClusterCalibrationsMonitorModule, SVDHotStripFinderModule, SVDLatencyCalibrationModule, SVDLocalCalibrationsCheckModule, SVDLocalCalibrationsMonitorModule, SVDPositionErrorScaleFactorImporterModule, SVDTimeCalibrationsMonitorModule, SVDDQMHitTimeModule, svdDumpModule, SVDPackerModule, SVDB4CommissioningPlotsModule, SVDClusterEvaluationModule, SVDClusterEvaluationTrueInfoModule, SVDClusterFilterModule, SVDMaxStripTTreeModule, SVDOccupancyAnalysisModule, SVDPerformanceModule, SVDPerformanceTTreeModule, SVDShaperDigitsFromTracksModule, SVDClusterizerModule, SVDCoGTimeEstimatorModule, SVDDataFormatCheckModule, SVDMissingAPVsClusterCreatorModule, SVDRecoDigitCreatorModule, SVD3SamplesEmulatorModule, SVDDigitizerModule, SVDEventInfoSetterModule, SVDTriggerQualityGeneratorModule, SVDSpacePointCreatorModule, SVDTimeGroupingModule, SVDUnpackerModule, TOPBackgroundModule, TOPBunchFinderModule, TOPChannelMaskerModule, TOPChannelT0MCModule, TOPDigitizerModule, TOPTriggerDigitizerModule, TOPDoublePulseGeneratorModule, TOPDQMModule, TOPGainEfficiencyCalculatorModule, TOPLaserHitSelectorModule, TOPInterimFENtupleModule, TOPLaserCalibratorModule, TOPMCTrackMakerModule, TOPModuleT0CalibratorModule, TOPNtupleModule, TOPPackerModule, TOPRawDigitConverterModule, TOPTBCComparatorModule, TOPTimeBaseCalibratorModule, TOPTimeRecalibratorModule, TOPUnpackerModule, TOPWaveformFeatureExtractorModule, TOPXTalkChargeShareSetterModule, DQMHistoModuleBase, SVDEventT0EstimatorModule, ExtModule, FlipQualityModule, BeamSpotMonitorModule, KinkFinderModule, MCV0MatcherModule, MCTrackCandClassifierModule, MuidModule, PXDROIFinderModule, SVDROIFinderAnalysisModule, SVDROIFinderModule, SPTCmomentumSeedRetrieverModule, SPTCvirtualIPRemoverModule, TrackCreatorModule, TrackFinderMCTruthRecoTracksModule, EffPlotsModule, HitXPModule, TrackingPerformanceEvaluationModule, V0findingPerformanceEvaluationModule, TrackQETrainingDataCollectorModule, TrackQualityEstimatorMVAModule, SecMapTrainerBaseModule, SecMapTrainerVXDTFModule, TrackFinderVXDAnalizerModule, VXDSimpleClusterizerModule, QualityEstimatorVXDModule, VXDQETrainingDataCollectorModule, VXDQualityEstimatorMVAModule, SectorMapBootstrapModule, SegmentNetworkProducerModule, TrackFinderVXDBasicPathFinderModule, TrackFinderVXDCellOMatModule, VXDTFTrainingDataCollectorModule, FindletModule< AFindlet >, FindletModule< HitBasedT0Extractor >, FindletModule< CKFToSVDSeedFindlet >, FindletModule< CKFToSVDFindlet >, FindletModule< CosmicsTrackMergerFindlet >, FindletModule< DATCONFPGAFindlet >, FindletModule< MCVXDCDCTrackMergerFindlet >, FindletModule< vxdHoughTracking::SVDHoughTracking >, FindletModule< CKFToCDCFindlet >, FindletModule< CKFToCDCFromEclFindlet >, FindletModule< CKFToPXDFindlet >, FindletModule< AsicBackgroundLibraryCreator >, FindletModule< CDCTrackingEventLevelMdstInfoFillerFromHitsFindlet >, FindletModule< CDCTrackingEventLevelMdstInfoFillerFromSegmentsFindlet >, FindletModule< AxialSegmentPairCreator >, FindletModule< AxialStraightTrackFinder >, FindletModule< AxialTrackCreatorMCTruth >, FindletModule< AxialTrackCreatorSegmentHough >, FindletModule< AxialTrackFinderHough >, FindletModule< AxialTrackFinderLegendre >, FindletModule< ClusterBackgroundDetector >, FindletModule< ClusterPreparer >, FindletModule< ClusterRefiner< BridgingWireHitRelationFilter > >, FindletModule< FacetCreator >, FindletModule< HitReclaimer >, FindletModule< MonopoleAxialTrackFinderLegendre >, FindletModule< MonopoleStereoHitFinder >, FindletModule< MonopoleStereoHitFinderQuadratic >, FindletModule< SegmentCreatorFacetAutomaton >, FindletModule< SegmentCreatorMCTruth >, FindletModule< SegmentFinderFacetAutomaton >, FindletModule< SegmentFitter >, FindletModule< SegmentLinker >, FindletModule< SegmentOrienter >, FindletModule< SegmentPairCreator >, FindletModule< SegmentRejecter >, FindletModule< SegmentTrackCombiner >, FindletModule< SegmentTripleCreator >, FindletModule< StereoHitFinder >, FindletModule< SuperClusterCreator >, FindletModule< TrackCombiner >, FindletModule< TrackCreatorSegmentPairAutomaton >, FindletModule< TrackCreatorSegmentTripleAutomaton >, FindletModule< TrackCreatorSingleSegments >, FindletModule< TrackExporter >, FindletModule< TrackFinderAutomaton >, FindletModule< TrackFinderCosmics >, FindletModule< TrackFinder >, FindletModule< TrackFinderSegmentPairAutomaton >, FindletModule< TrackFinderSegmentTripleAutomaton >, FindletModule< TrackFlightTimeAdjuster >, FindletModule< TrackLinker >, FindletModule< TrackOrienter >, FindletModule< TrackQualityAsserter >, FindletModule< TrackQualityEstimator >, FindletModule< TrackRejecter >, FindletModule< WireHitBackgroundDetector >, FindletModule< WireHitCreator >, FindletModule< WireHitPreparer >, CDCTriggerNeuroDQMModule, CDCTriggerNeuroDQMOnlineModule, CDCTriggerNDFinderModule, CDCTriggerTSFModule, TRGCDCModule, TRGCDCETFUnpackerModule, TRGCDCT2DDQMModule, TRGCDCT3DConverterModule, TRGCDCT3DDQMModule, TRGCDCT3DUnpackerModule, TRGCDCTSFDQMModule, TRGCDCTSFUnpackerModule, TRGCDCTSStreamModule, CDCTriggerUnpackerModule, MCMatcherTRGECLModule, TRGECLFAMModule, TRGECLModule, TRGECLBGTCHitModule, TRGECLDQMModule, TRGECLEventTimingDQMModule, TRGECLQAMModule, TRGECLRawdataAnalysisModule, TRGECLTimingCalModule, TRGECLUnpackerModule, TRGGDLModule, TRGGDLDQMModule, TRGGDLDSTModule, TRGGDLSummaryModule, TRGGDLUnpackerModule, TRGGRLMatchModule, TRGGRLModule, TRGGRLProjectsModule, TRGGRLDQMModule, TRGGRLUnpackerModule, KLMTriggerModule, TRGTOPDQMModule, TRGTOPTRD2TTSConverterModule, TRGTOPUnpackerModule, TRGTOPUnpackerWaveformModule, TRGTOPWaveformPlotterModule, TRGRAWDATAModule, VXDMisalignmentModule, DQMHistAnalysisARICHModule, DQMHistAnalysisCDCDedxModule, DQMHistAnalysisCDCEpicsModule, DQMHistAnalysisCDCMonObjModule, DQMHistAnalysisDAQMonObjModule, DQMHistAnalysisECLModule, DQMHistAnalysisECLConnectedRegionsModule, DQMHistAnalysisECLShapersModule, DQMHistAnalysisECLSummaryModule, DQMHistAnalysisEpicsExampleModule, DQMHistAnalysisEventT0EfficiencyModule, DQMHistAnalysisEventT0TriggerJitterModule, DQMHistAnalysisExampleModule, DQMHistAnalysisExampleFlagsModule, DQMHistAnalysisHLTModule, DQMHistAnalysisInput2Module, DQMHistAnalysisInputPVSrvModule, DQMHistAnalysisInputRootFileModule, DQMHistAnalysisInputTestModule, DQMHistAnalysisKLMModule, DQMHistAnalysisKLM2Module, DQMHistAnalysisMiraBelleModule, DQMHistAnalysisOutputMonObjModule, DQMHistAnalysisOutputRelayMsgModule, DQMHistAnalysisPeakModule, DQMHistAnalysisPXDERModule, DQMHistAnalysisPXDFitsModule, DQMHistAnalysisSVDClustersOnTrackModule, DQMHistAnalysisSVDDoseModule, DQMHistAnalysisSVDEfficiencyModule, DQMHistAnalysisSVDGeneralModule, DQMHistAnalysisSVDOccupancyModule, DQMHistAnalysisSVDOnMiraBelleModule, DQMHistAnalysisSVDUnpackerModule, DQMHistAnalysisTOPModule, DQMHistAnalysisTrackingAbortModule, DQMHistAnalysisTrackingHLTModule, DQMHistAnalysisTRGECLModule, DQMHistAutoCanvasModule, DQMHistComparitorModule, DQMHistDeltaHistoModule, DQMHistReferenceModule, DQMHistSnapshotsModule, DAQMonitorModule, DelayDQMModule, V0ObjectsDQMModule, ECLDQMInjectionModule, PyModule, PXDBgTupleProducerModule, PXDMCBgTupleProducerModule, PXDDAQDQMModule, PXDDQMClustersModule, PXDDQMCorrModule, PXDDQMEfficiencyModule, PXDDQMEfficiencySelftrackModule, PXDDQMExpressRecoModule, PXDGatedDHCDQMModule, PXDGatedModeDQMModule, PXDInjectionDQMModule, PXDRawDQMCorrModule, PXDRawDQMModule, PXDROIDQMModule, PXDTrackClusterDQMModule, PXDDigitizerModule, PXDPackerModule, PXDUnpackerModule, TTDDQMModule, SVDDQMClustersOnTrackModule, SVDDQMDoseModule, SVDDQMExpressRecoModule, SVDDQMInjectionModule, SVDUnpackerDQMModule, PXDclusterFilterModule, PXDdigiFilterModule, PXDROIFinderAnalysisModule, TrackingAbortDQMModule, VXDDQMExpressRecoModule, vxdDigitMaskingModule, DQMHistAnalysisDeltaEpicsMonObjExampleModule, DQMHistAnalysisDeltaTestModule, DQMHistAnalysisEpicsOutputModule, DQMHistAnalysisPhysicsModule, DQMHistAnalysisPXDChargeModule, DQMHistAnalysisPXDCMModule, DQMHistAnalysisPXDDAQModule, DQMHistAnalysisPXDEffModule, DQMHistAnalysisPXDInjectionModule, DQMHistAnalysisPXDReductionModule, DQMHistAnalysisPXDTrackChargeModule, DQMHistAnalysisRooFitExampleModule, DQMHistAnalysisRunNrModule, DQMHistAnalysisTRGModule, DQMHistInjectionModule, and DQMHistOutputToEPICSModule.

Definition at line 147 of file Module.h.

147{};

◆ bookOutput()

void bookOutput ( std::string  filename)

Create the output TFiles and TTrees.

Definition at line 721 of file HitLevelInfoWriter.cc.

722{
723 // register output root file
724 m_file.push_back(new TFile(filename.c_str(), "RECREATE"));
725 m_tree.push_back(new TTree("track", "dE/dx information"));
726
727 int i = m_tree.size() - 1;
728 m_tree[i]->SetDirectory(0);
729
730 // event level information (from emd)
731 m_tree[i]->Branch("exp", &m_expID, "exp/I");
732 m_tree[i]->Branch("run", &m_runID, "run/I");
733 m_tree[i]->Branch("event", &m_eventID, "event/I");
734
735 // track level information (from tfr)
736 m_tree[i]->Branch("dz", &m_dz, "dz/D");
737 m_tree[i]->Branch("dr", &m_dr, "dr/D");
738 m_tree[i]->Branch("chi2", &m_chi2, "chi2/D");
739 m_tree[i]->Branch("injtime", &m_injtime, "injtime/D");
740 m_tree[i]->Branch("isher", &m_injring, "isher/D");
741
742 if (m_isExtraVar) {
743 m_tree[i]->Branch("d0", &m_d0, "d0/D");
744 m_tree[i]->Branch("z0", &m_z0, "z0/D");
745 m_tree[i]->Branch("dphi", &m_dphi, "dphi/D");
746 m_tree[i]->Branch("vx0", &m_vx0, "vx0/D");
747 m_tree[i]->Branch("vy0", &m_vy0, "vy0/D");
748 m_tree[i]->Branch("vz0", &m_vz0, "vz0/D");
749 m_tree[i]->Branch("tanlambda", &m_tanlambda, "tanlambda/D");
750 m_tree[i]->Branch("phi0", &m_phi0, "phi0/D");
751 m_tree[i]->Branch("e1_9", &m_e1_9, "e1_9/D");
752 m_tree[i]->Branch("e9_21", &m_e9_21, "e9_21/D");
753 m_tree[i]->Branch("eclsnhits", &m_eclsnHits, "eclsnhits/D");
754 m_tree[i]->Branch("klmLayers", &m_klmLayers, "klmLayers/I");
755 }
756
757 // track level information (from cdt)
758 m_tree[i]->Branch("nCDChits", &m_nCDChits, "nCDChits/D");
759 m_tree[i]->Branch("inCDC", &m_inCDC, "inCDC/I");
760 m_tree[i]->Branch("track", &m_trackID, "track/I");
761 m_tree[i]->Branch("length", &m_length, "length/D");
762 m_tree[i]->Branch("charge", &m_charge, "charge/I");
763 m_tree[i]->Branch("costh", &m_cosTheta, "costh/D");
764 m_tree[i]->Branch("pF", &m_pCDC, "pF/D");
765 m_tree[i]->Branch("p", &m_p, "p/D");
766 m_tree[i]->Branch("pt", &m_pt, "pt/D");
767 m_tree[i]->Branch("ioasym", &m_ioasym, "ioasym/D");
768 m_tree[i]->Branch("phi", &m_phi, "phi/D");
769 m_tree[i]->Branch("pdg", &m_PDG, "pdg/D");
770 // track level dE/dx measurements
771 m_tree[i]->Branch("mean", &m_mean, "mean/D");
772 m_tree[i]->Branch("dedx", &m_trunc, "dedx/D");
773 m_tree[i]->Branch("dedxnosat", &m_truncNoSat, "dedxnosat/D");
774 m_tree[i]->Branch("dedxerr", &m_error, "dedxerr/D");
775
776 // other track level information
777 m_tree[i]->Branch("eop", &m_eop, "eop/D");
778 m_tree[i]->Branch("e", &m_e, "e/D");
779
780 // calibration constants
781 m_tree[i]->Branch("scale", &m_scale, "scale/D");
782 m_tree[i]->Branch("coscor", &m_cosCor, "coscor/D");
783 m_tree[i]->Branch("cosedgecor", &m_cosEdgeCor, "cosedgecor/D");
784 m_tree[i]->Branch("rungain", &m_runGain, "rungain/D");
785 m_tree[i]->Branch("timegain", &m_timeGain, "timegain/D");
786 m_tree[i]->Branch("timereso", &m_timeReso, "timereso/D");
787
788 // PID values
789 m_tree[i]->Branch("chiE", &m_chie, "chiE/D");
790 m_tree[i]->Branch("chiMu", &m_chimu, "chiMu/D");
791 m_tree[i]->Branch("chiPi", &m_chipi, "chiPi/D");
792 m_tree[i]->Branch("chiK", &m_chik, "chiK/D");
793 m_tree[i]->Branch("chiP", &m_chip, "chiP/D");
794 m_tree[i]->Branch("chiD", &m_chid, "chiD/D");
795
796 m_tree[i]->Branch("chiEOld", &m_chieOld, "chiEOld/D");
797 m_tree[i]->Branch("chiMuOld", &m_chimuOld, "chiMuOld/D");
798 m_tree[i]->Branch("chiPiOld", &m_chipiOld, "chiPiOld/D");
799 m_tree[i]->Branch("chiKOld", &m_chikOld, "chiKOld/D");
800 m_tree[i]->Branch("chiPOld", &m_chipOld, "chiPOld/D");
801 m_tree[i]->Branch("chiDOld", &m_chidOld, "chiDOld/D");
802
803 m_tree[i]->Branch("pmeanE", &m_pmeane, "pmeanE/D");
804 m_tree[i]->Branch("pmeanMu", &m_pmeanmu, "pmeanMu/D");
805 m_tree[i]->Branch("pmeanPi", &m_pmeanpi, "pmeanPi/D");
806 m_tree[i]->Branch("pmeanK", &m_pmeank, "pmeanK/D");
807 m_tree[i]->Branch("pmeanP", &m_pmeanp, "pmeanP/D");
808 m_tree[i]->Branch("pmeanD", &m_pmeand, "pmeanD/D");
809
810 m_tree[i]->Branch("presE", &m_prese, "presE/D");
811 m_tree[i]->Branch("presMu", &m_presmu, "presMu/D");
812 m_tree[i]->Branch("presPi", &m_prespi, "presPi/D");
813 m_tree[i]->Branch("presK", &m_presk, "presK/D");
814 m_tree[i]->Branch("presP", &m_presp, "presP/D");
815 m_tree[i]->Branch("presD", &m_presd, "presD/D");
816
817 // layer level information
818 m_tree[i]->Branch("lNHits", &l_nhits, "lNHits/I");
819 m_tree[i]->Branch("lNHitsUsed", &l_nhitsused, "lNHitsUsed/I");
820 m_tree[i]->Branch("lNHitsCombined", l_nhitscombined, "lNHitsCombined[lNHits]/I");
821 m_tree[i]->Branch("lWireLongestHit", l_wirelongesthit, "lWireLongestHit[lNHits]/I");
822 m_tree[i]->Branch("lLayer", l_layer, "lLayer[lNHits]/I");
823 m_tree[i]->Branch("lPath", l_path, "lPath[lNHits]/D");
824 m_tree[i]->Branch("lDedx", l_dedx, "lDedx[lNHits]/D");
825
826 // hit level information
827 if (m_isHitLevel) {
828 m_tree[i]->Branch("hNHits", &h_nhits, "hNHits/I");
829 m_tree[i]->Branch("hLWire", h_lwire, "hLWire[hNHits]/I");
830 m_tree[i]->Branch("hWire", h_wire, "hWire[hNHits]/I");
831 m_tree[i]->Branch("hLayer", h_layer, "hLayer[hNHits]/I");
832 m_tree[i]->Branch("hPath", h_path, "hPath[hNHits]/D");
833 m_tree[i]->Branch("hDedx", h_dedx, "hDedx[hNHits]/D");
834 m_tree[i]->Branch("hADCRaw", h_adcraw, "hADCRaw[hNHits]/D");
835 m_tree[i]->Branch("hADCCorr", h_adccorr, "hADCCorr[hNHits]/D");
836 m_tree[i]->Branch("hDoca", h_doca, "hDoca[hNHits]/D");
837 m_tree[i]->Branch("hNDoca", h_ndoca, "hNDoca[hNHits]/D");
838 m_tree[i]->Branch("hNDocaRS", h_ndocaRS, "hNDocaRS[hNHits]/D");
839 m_tree[i]->Branch("hEnta", h_enta, "hEnta[hNHits]/D");
840 m_tree[i]->Branch("hEntaRS", h_entaRS, "hEntaRS[hNHits]/D");
841 m_tree[i]->Branch("hDriftT", h_driftT, "hDriftT[hNHits]/D");
842 m_tree[i]->Branch("hDriftD", h_driftD, "hDriftD[hNHits]/D");
843 m_tree[i]->Branch("hFacnlADC", h_facnladc, "hFacnlADC[hNHits]/D");
844 m_tree[i]->Branch("hWireGain", h_wireGain, "hWireGain[hNHits]/D");
845 m_tree[i]->Branch("hTwodcor", h_twodCor, "hTwodcor[hNHits]/D");
846 m_tree[i]->Branch("hOnedcor", h_onedCor, "hOnedcor[hNHits]/D");
847
848 if (m_isExtraVar) {
849 m_tree[i]->Branch("hWeightPionHypo", h_WeightPionHypo, "hWeightPionHypo[hNHits]/D");
850 m_tree[i]->Branch("hWeightKaonHypo", h_WeightKaonHypo, "hWeightKaonHypo[hNHits]/D");
851 m_tree[i]->Branch("hWeightProtonHypo", h_WeightProtonHypo, "hWeightProtonHypo[hNHits]/D");
852 m_tree[i]->Branch("hFoundByTrackFinder", h_foundByTrackFinder, "hFoundByTrackFinder[hNHits]/I");
853 }
854 }
855}
double h_ndoca[kMaxHits]
normalized distance of closest approach
double h_driftD[kMaxHits]
drift distance
double h_onedCor[kMaxHits]
calibration 1D cleanup correction
int l_nhits
the total number of layer hits for this Track
double m_cosEdgeCor
calibration cosine edge correction
double m_presk
pred reso for kaon hypothesis
double m_phi0
Angle of the transverse momentum in the r-phi plane.
double m_d0
Signed distance to the POCA in the r-phi plane.
double m_presp
pred reso for proton hypothesis
int l_wirelongesthit[kMaxHits]
the wire number of longest hit in this layer
double m_ioasym
asymmetry in increasing vs decreasing layer numbers per track
double m_p
momentum from tracking
double m_e9_21
ratio of energies of the central 3x3 crystal vs 5x5 crystals
int m_trackID
ID number of the Track.
double m_vx0
X coordinate of track POCA to origin.
double m_pmeand
pred mean for deuteron hypothesis
double h_enta[kMaxHits]
entrance angle
double m_chipOld
chi value for proton hypothesis
double h_WeightKaonHypo[kMaxHits]
weight for kaon hypothesis from KalmanFitterInfo
double m_pmeanp
pred mean for proton hypothesis
double h_WeightProtonHypo[kMaxHits]
weight for proton hypothesis from KalmanFitterInfo
double m_chid
modified chi value for deuteron hypothesis
double m_chikOld
chi value for kaon hypothesis
double m_dz
vertex or POCA in case of tracks z in respect to IPs
double m_pmeank
pred mean for kaon hypothesis
double h_facnladc[kMaxHits]
calibration hit gain
int h_nhits
the number of good hits for this Track
double h_adccorr[kMaxHits]
charge per hit corr by nonlinear ADC
std::vector< TTree * > m_tree
output ROOT trees
double m_presmu
pred reso for muon hypothesis
double m_cosCor
calibration cosine correction
double m_tanlambda
Slope of the track in the r-z plane.
int h_layer[kMaxHits]
layer number
double h_adcraw[kMaxHits]
charge per hit
int m_expID
experiment in which this Track was found
double h_path[kMaxHits]
path length in cell
double m_chimu
modified chi value for muon hypothesis
double m_vy0
Y coordinate of track POCA to origin.
double m_chik
modified chi value for kaon hypothesis
double m_chi2
chi^2 from track fit
double h_wireGain[kMaxHits]
calibration hit gain
double h_twodCor[kMaxHits]
calibration 2D correction
double m_chie
modified chi value for electron hypothesis
double m_runGain
calibration run gain
int m_eventID
event in which this Track was found
double m_timeGain
calibration injection time gain
double m_chidOld
chi value for deuteron hypothesis
std::vector< TFile * > m_file
output ROOT files
double m_dr
track d0 relative to IP
double m_prese
pred reso for electron hypothesis
int h_foundByTrackFinder[kMaxHits]
the 'found by track finder' flag for the given hit
double m_timeReso
calibration injection time reso
double l_dedx[kMaxHits]
dE/dx for this layer
double l_path[kMaxHits]
distance travelled in this layer
int l_layer[kMaxHits]
layer number
double m_chipiOld
chi value for pion hypothesis
double m_chip
modified chi value for proton hypothesis
double m_pmeane
pred mean for electron hypothesis
double m_cosTheta
cos(theta) for the track
int l_nhitsused
the total number of layer hits used for this Track
double h_dedx[kMaxHits]
charge per path length
double m_chieOld
chi value for electron hypothesis
double h_driftT[kMaxHits]
drift time
double m_dphi
POCA in degrees in respect to IP.
double m_eop
energy over momentum in the calorimeter
double m_presd
pred reso for deuteron hypothesis
double m_scale
calibration scale factor
double m_klmLayers
number of klm layers with hits
int l_nhitscombined[kMaxHits]
the number of hits combined this layer
double m_error
standard deviation of the truncated mean
double m_pCDC
momentum valid in CDC
double m_truncNoSat
dE/dx averaged, truncated mean, with corrections (not hadron)
double m_length
total path length of the Track
double m_injring
HER injection status.
double m_nCDChits
Number of CDC hits associated to the track.
double h_ndocaRS[kMaxHits]
normalized +RS distance of closest approach
double m_vz0
Z coordinate of track POCA to origin.
double m_trunc
dE/dx averaged, truncated mean, with corrections
int m_inCDC
frack is CDC acceptance or not
double h_doca[kMaxHits]
distance of closest approach
double m_chimuOld
chi value for muon hypothesis
double m_z0
z coordinate of the POCA
int m_charge
the charge for this Track
double h_WeightPionHypo[kMaxHits]
weight for pion hypothesis from KalmanFitterInfo
int m_runID
run in which this Track was found
double m_e
energy in the calorimeter
double m_injtime
time since last injection in micro seconds
double m_pmeanmu
pred mean for muon hypothesis
double h_entaRS[kMaxHits]
normalized + RS distance of entrance angle
double m_prespi
pred reso for pion hypothesis
int h_wire[kMaxHits]
sense wire ID
int h_lwire[kMaxHits]
sense wire within layer
double m_chipi
modified chi value for pion hypothesis
double m_pt
transverse momentum from tracking
double m_pmeanpi
pred mean for pion hypothesis
double m_e1_9
ratio of energies of the central 1 crystal vs 3x3 crystals

◆ calculateMeans()

void calculateMeans ( double *  mean,
double *  truncatedMean,
double *  truncatedMeanErr,
const std::vector< double > &  dedx 
) const

Save arithmetic and truncated mean for the 'dedx' values.

Parameters
meancalculated arithmetic mean
truncatedMeancalculated truncated mean
truncatedMeanErrerror for truncatedMean
dedxinput values

Definition at line 624 of file HitLevelInfoWriter.cc.

626{
627 // Calculate the truncated average by skipping the lowest & highest
628 // events in the array of dE/dx values
629 vector<double> sortedDedx = dedx;
630 sort(sortedDedx.begin(), sortedDedx.end());
631 sortedDedx.erase(remove(sortedDedx.begin(), sortedDedx.end(), 0), sortedDedx.end());
632 sortedDedx.shrink_to_fit();
633
634 double truncMeanTmp = 0.0, meanTmp = 0.0, sumOfSqs = 0.0;
635 int nValTrunc = 0;
636 const int numDedx = sortedDedx.size();
637
638 // add a factor of 0.51 here to make sure we are rounding appropriately...
639 const int lEdgeTrunc = int(numDedx * 0.05 + 0.51);
640 const int hEdgeTrunc = int(numDedx * (1 - 0.25) + 0.51);
641 for (int i = 0; i < numDedx; i++) {
642 meanTmp += sortedDedx[i];
643 if (i >= lEdgeTrunc and i < hEdgeTrunc) {
644 truncMeanTmp += sortedDedx[i];
645 sumOfSqs += sortedDedx[i] * sortedDedx[i];
646 nValTrunc++;
647 }
648 }
649
650 if (numDedx != 0) meanTmp /= numDedx;
651
652 if (nValTrunc != 0) truncMeanTmp /= nValTrunc;
653 else truncMeanTmp = meanTmp;
654
655 *mean = meanTmp;
656 *truncMean = truncMeanTmp;
657
658 if (nValTrunc > 1)
659 *truncMeanErr = sqrt(sumOfSqs / double(nValTrunc) - truncMeanTmp * truncMeanTmp) / double(nValTrunc - 1);
660 else *truncMeanErr = 0;
661
662}
double sqrt(double a)
sqrt for double
Definition: beamHelpers.h:28

◆ clearEntries()

void clearEntries ( )
private

Clear the arrays before filling an event.

Definition at line 682 of file HitLevelInfoWriter.cc.

683{
684 for (int il = 0; il < 200; ++il) {
685 l_nhitscombined[il] = 0;
686 l_wirelongesthit[il] = 0;
687 l_layer[il] = 0;
688 l_path[il] = 0;
689 l_dedx[il] = 0;
690 }
691
692 if (m_isHitLevel) {
693 for (int ihit = 0; ihit < 200; ++ihit) {
694 h_lwire[ihit] = 0;
695 h_wire[ihit] = 0;
696 h_layer[ihit] = 0;
697 h_path[ihit] = 0;
698 h_dedx[ihit] = 0;
699 h_adcraw[ihit] = 0;
700 h_adccorr[ihit] = 0;
701 h_doca[ihit] = 0;
702 h_ndoca[ihit] = 0;
703 h_ndocaRS[ihit] = 0;
704 h_enta[ihit] = 0;
705 h_entaRS[ihit] = 0;
706 h_driftT[ihit] = 0;
707 // h_driftD[ihit] = 0;
708 h_facnladc[ihit] = 0;
709 h_wireGain[ihit] = 0;
710 h_twodCor[ihit] = 0;
711 h_onedCor[ihit] = 0;
712 h_WeightPionHypo[ihit] = 0;
713 h_WeightKaonHypo[ihit] = 0;
714 h_WeightProtonHypo[ihit] = 0;
715 h_foundByTrackFinder[ihit] = 0;
716 }
717 }
718}

◆ clone()

std::shared_ptr< PathElement > clone ( ) const
overridevirtualinherited

Create an independent copy of this module.

Note that parameters are shared, so changing them on a cloned module will also affect the original module.

Implements PathElement.

Definition at line 179 of file Module.cc.

180{
182 newModule->m_moduleParamList.setParameters(getParamList());
183 newModule->setName(getName());
184 newModule->m_package = m_package;
185 newModule->m_propertyFlags = m_propertyFlags;
186 newModule->m_logConfig = m_logConfig;
187 newModule->m_conditions = m_conditions;
188
189 return newModule;
190}
std::shared_ptr< Module > registerModule(const std::string &moduleName, std::string sharedLibPath="") noexcept(false)
Creates an instance of a module and registers it to the ModuleManager.
static ModuleManager & Instance()
Exception is thrown if the requested module could not be created by the ModuleManager.
const ModuleParamList & getParamList() const
Return module param list.
Definition: Module.h:363
const std::string & getName() const
Returns the name of the module.
Definition: Module.h:187
const std::string & getType() const
Returns the type of the module (i.e.
Definition: Module.cc:41
unsigned int m_propertyFlags
The properties of the module as bitwise or (with |) of EModulePropFlags.
Definition: Module.h:512
LogConfig m_logConfig
The log system configuration of the module.
Definition: Module.h:514
std::vector< ModuleCondition > m_conditions
Module condition, only non-null if set.
Definition: Module.h:521
std::string m_package
Package this module is found in (may be empty).
Definition: Module.h:510
std::shared_ptr< Module > ModulePtr
Defines a pointer to a module object as a boost shared pointer.
Definition: Module.h:43

◆ D2I()

double D2I ( const double  cosTheta,
const double  D 
) const

hadron saturation parameterization part 2

Definition at line 562 of file HitLevelInfoWriter.cc.

563{
564 double absCosTheta = fabs(cosTheta);
565 double projection = pow(absCosTheta, m_hadronpars[3]) + m_hadronpars[2];
566 if (projection == 0) {
567 B2WARNING("Something wrong with dE/dx hadron constants!");
568 return D;
569 }
570
571 double chargeDensity = D / projection;
572 double numerator = 1 + m_hadronpars[0] * chargeDensity;
573 double denominator = 1 + m_hadronpars[1] * chargeDensity;
574
575 if (denominator == 0) {
576 B2WARNING("Something wrong with dE/dx hadron constants!");
577 return D;
578 }
579
580 double I = D * m_hadronpars[4] * numerator / denominator;
581 return I;
582}
std::vector< double > m_hadronpars
hadron saturation parameters

◆ def_beginRun()

virtual void def_beginRun ( )
inlineprotectedvirtualinherited

Wrapper method for the virtual function beginRun() that has the implementation to be used in a call from Python.

Reimplemented in PyModule.

Definition at line 426 of file Module.h.

426{ beginRun(); }
virtual void beginRun()
Called when entering a new run.
Definition: Module.h:147

◆ def_endRun()

virtual void def_endRun ( )
inlineprotectedvirtualinherited

This method can receive that the current run ends as a call from the Python side.

For regular C++-Modules that forwards the call to the regular endRun() method.

Reimplemented in PyModule.

Definition at line 439 of file Module.h.

439{ endRun(); }
virtual void endRun()
This method is called if the current run ends.
Definition: Module.h:166

◆ def_event()

virtual void def_event ( )
inlineprotectedvirtualinherited

Wrapper method for the virtual function event() that has the implementation to be used in a call from Python.

Reimplemented in PyModule.

Definition at line 432 of file Module.h.

432{ event(); }
virtual void event()
This method is the core of the module.
Definition: Module.h:157

◆ def_initialize()

virtual void def_initialize ( )
inlineprotectedvirtualinherited

Wrappers to make the methods without "def_" prefix callable from Python.

Overridden in PyModule. Wrapper method for the virtual function initialize() that has the implementation to be used in a call from Python.

Reimplemented in PyModule.

Definition at line 420 of file Module.h.

420{ initialize(); }
virtual void initialize()
Initialize the Module.
Definition: Module.h:109

◆ def_terminate()

virtual void def_terminate ( )
inlineprotectedvirtualinherited

Wrapper method for the virtual function terminate() that has the implementation to be used in a call from Python.

Reimplemented in PyModule.

Definition at line 445 of file Module.h.

445{ terminate(); }
virtual void terminate()
This method is called at the end of the event processing.
Definition: Module.h:176

◆ endRun()

virtual void endRun ( void  )
inlinevirtualinherited

This method is called if the current run ends.

Use this method to store information, which should be aggregated over one run.

This method can be implemented by subclasses.

Reimplemented in BeamabortModule, BgoModule, CaveModule, ClawModule, CLAWSModule, DosiModule, FANGSModule, He3tubeModule, MicrotpcModule, Ph1bpipeModule, Ph1sustrModule, PindiodeModule, PlumeModule, QcsmonitorModule, SrsensorModule, GetEventFromSocketModule, CalibrationCollectorModule, AlignDQMModule, CosmicsAlignmentValidationModule, CurlTaggerModule, LowEnergyPi0IdentificationExpertModule, LowEnergyPi0VetoExpertModule, arichBtestModule, ARICHDQMModule, B2BIIMCParticlesMonitorModule, B2BIIConvertMdstModule, B2BIIMdstInputModule, BelleMCOutputModule, BeamBkgGeneratorModule, BeamBkgHitRateMonitorModule, BeamBkgMixerModule, BeamBkgTagSetterModule, BGOverlayInputModule, AnalysisPhase1StudyModule, NtuplePhase1_v6Module, ReprocessorModule, BeamabortStudyModule, BeamDigitizerModule, BgoDigitizerModule, BgoStudyModule, ClawDigitizerModule, ClawStudyModule, ClawsDigitizerModule, ClawsStudyModule, CsiDigitizer_v2Module, CsIDigitizerModule, CsiModule, CsiStudy_v2Module, CsIStudyModule, DosiDigitizerModule, DosiStudyModule, FANGSDigitizerModule, FANGSStudyModule, He3DigitizerModule, He3tubeStudyModule, MicrotpcStudyModule, TpcDigitizerModule, TPCStudyModule, PinDigitizerModule, PindiodeStudyModule, PlumeDigitizerModule, QcsmonitorDigitizerModule, QcsmonitorStudyModule, CDCCosmicAnalysisModule, CDCCRTestModule, cdcDQM7Module, CDCDQMModule, CDCPackerModule, CDCRecoTrackFilterModule, CDCUnpackerModule, DAQPerfModule, RxSocketModule, TxSocketModule, DqmHistoManagerModule, MonitorDataModule, TrackAnaModule, Ds2SampleModule, ReceiveEventModule, HLTDQM2ZMQModule, HLTDs2ZMQModule, ElapsedTimeModule, DeSerializerPXDModule, GenRawSendModule, Root2RawModule, SerializerModule, CertifyParallelModule, Ds2RawModule, Ds2RbufModule, EvReductionModule, FastRbuf2DsModule, Raw2DsModule, RawInputModule, Rbuf2DsModule, Rbuf2RbufModule, Ds2RawFileModule, PartialSeqRootReaderModule, SeqRootMergerModule, StorageDeserializerModule, StorageRootOutputModule, StorageSerializerModule, PhysicsObjectsDQMModule, PhysicsObjectsMiraBelleBhabhaModule, PhysicsObjectsMiraBelleDst2Module, PhysicsObjectsMiraBelleDstModule, PhysicsObjectsMiraBelleHadronModule, PhysicsObjectsMiraBelleModule, ECLBackgroundModule, ECLChargedPIDModule, ECLChargedPIDDataAnalysisModule, ECLChargedPIDDataAnalysisValidationModule, ECLClusterPSDModule, ECLCovarianceMatrixModule, ECLCRFinderModule, ECLDataAnalysisModule, ECLDigitCalibratorModule, ECLDigitizerModule, ECLDigitizerPureCsIModule, EclDisplayModule, ECLDQMModule, ECLDQMEXTENDEDModule, ECLDQMOutOfTimeDigitsModule, ECLFinalizerModule, ECLHitDebugModule, ECLLocalMaximumFinderModule, ECLLocalRunCalibratorModule, ECLLOMModule, ECLPackerModule, ECLShowerCorrectorModule, ECLShowerShapeModule, ECLSplitterN1Module, ECLSplitterN2Module, ECLUnpackerModule, ECLWaveformFitModule, HistoModule, SubEventModule, SwitchDataStoreModule, EventInfoPrinterModule, RandomBarrierModule, HistoManagerModule, StatisticsSummaryModule, SeqRootInputModule, SeqRootOutputModule, RxModule, TxModule, ZMQTxInputModule, ZMQTxWorkerModule, EvtGenDecayModule, OverrideGenerationFlagsModule, BKLMAnaModule, BKLMDigitAnalyzerModule, BKLMSimHistogrammerModule, BKLMTrackingModule, EKLMDataCheckerModule, KLMClusterEfficiencyModule, KLMClustersReconstructorModule, KLMDigitizerModule, KLMDQMModule, KLMDQM2Module, KLMPackerModule, KLMReconstructorModule, KLMScintillatorSimulatorModule, KLMUnpackerModule, AWESOMEBasicModule, PXDBackgroundModule, PXDClustersFromTracksModule, PXDPerformanceModule, Convert2RawDetModule, PrintDataModule, PrintEventRateModule, Root2BinaryModule, CDCDedxDQMModule, CDCDedxValidationModule, EventT0ValidationModule, DataWriterModule, KlongValidationModule, KLMMuonIDDNNExpertModule, FullSimModule, SVDBackgroundModule, SVDClusterCalibrationsMonitorModule, SVDHotStripFinderModule, SVDLatencyCalibrationModule, SVDLocalCalibrationsMonitorModule, SVDPositionErrorScaleFactorImporterModule, SVDTimeCalibrationsMonitorModule, svdDumpModule, SVDPackerModule, SVDB4CommissioningPlotsModule, SVDClusterEvaluationModule, SVDClusterEvaluationTrueInfoModule, SVDClusterFilterModule, SVDOccupancyAnalysisModule, SVDPerformanceModule, SVDShaperDigitsFromTracksModule, SVDClusterizerModule, SVDCoGTimeEstimatorModule, SVDDataFormatCheckModule, SVDRecoDigitCreatorModule, SVD3SamplesEmulatorModule, SVDTriggerQualityGeneratorModule, SVDUnpackerModule, TOPBackgroundModule, TOPChannelT0MCModule, TOPTriggerDigitizerModule, TOPDoublePulseGeneratorModule, TOPGainEfficiencyCalculatorModule, TOPLaserHitSelectorModule, TOPInterimFENtupleModule, TOPLaserCalibratorModule, TOPMCTrackMakerModule, TOPNtupleModule, TOPPackerModule, TOPRawDigitConverterModule, TOPTBCComparatorModule, TOPTimeBaseCalibratorModule, TOPUnpackerModule, TOPWaveformFeatureExtractorModule, TOPWaveformQualityPlotterModule, TOPXTalkChargeShareSetterModule, ExtModule, GenfitVisModule, MCV0MatcherModule, MCTrackCandClassifierModule, MuidModule, MCSlowPionPXDROICreatorModule, PXDROIFinderModule, SVDROIDQMModule, SVDROIFinderAnalysisModule, SVDROIFinderModule, RT2SPTCConverterModule, SPTCmomentumSeedRetrieverModule, SPTCvirtualIPRemoverModule, TrackFinderMCTruthRecoTracksModule, EffPlotsModule, HitXPModule, TrackingPerformanceEvaluationModule, V0findingPerformanceEvaluationModule, SecMapTrainerBaseModule, SecMapTrainerVXDTFModule, TrackFinderVXDAnalizerModule, VXDSimpleClusterizerModule, NoKickCutsEvalModule, SectorMapBootstrapModule, VXDTFTrainingDataCollectorModule, FindletModule< AFindlet >, FindletModule< HitBasedT0Extractor >, FindletModule< CKFToSVDSeedFindlet >, FindletModule< CKFToSVDFindlet >, FindletModule< CosmicsTrackMergerFindlet >, FindletModule< DATCONFPGAFindlet >, FindletModule< MCVXDCDCTrackMergerFindlet >, FindletModule< vxdHoughTracking::SVDHoughTracking >, FindletModule< CKFToCDCFindlet >, FindletModule< CKFToCDCFromEclFindlet >, FindletModule< CKFToPXDFindlet >, FindletModule< AsicBackgroundLibraryCreator >, FindletModule< CDCTrackingEventLevelMdstInfoFillerFromHitsFindlet >, FindletModule< CDCTrackingEventLevelMdstInfoFillerFromSegmentsFindlet >, FindletModule< AxialSegmentPairCreator >, FindletModule< AxialStraightTrackFinder >, FindletModule< AxialTrackCreatorMCTruth >, FindletModule< AxialTrackCreatorSegmentHough >, FindletModule< AxialTrackFinderHough >, FindletModule< AxialTrackFinderLegendre >, FindletModule< ClusterBackgroundDetector >, FindletModule< ClusterPreparer >, FindletModule< ClusterRefiner< BridgingWireHitRelationFilter > >, FindletModule< FacetCreator >, FindletModule< HitReclaimer >, FindletModule< MonopoleAxialTrackFinderLegendre >, FindletModule< MonopoleStereoHitFinder >, FindletModule< MonopoleStereoHitFinderQuadratic >, FindletModule< SegmentCreatorFacetAutomaton >, FindletModule< SegmentCreatorMCTruth >, FindletModule< SegmentFinderFacetAutomaton >, FindletModule< SegmentFitter >, FindletModule< SegmentLinker >, FindletModule< SegmentOrienter >, FindletModule< SegmentPairCreator >, FindletModule< SegmentRejecter >, FindletModule< SegmentTrackCombiner >, FindletModule< SegmentTripleCreator >, FindletModule< StereoHitFinder >, FindletModule< SuperClusterCreator >, FindletModule< TrackCombiner >, FindletModule< TrackCreatorSegmentPairAutomaton >, FindletModule< TrackCreatorSegmentTripleAutomaton >, FindletModule< TrackCreatorSingleSegments >, FindletModule< TrackExporter >, FindletModule< TrackFinderAutomaton >, FindletModule< TrackFinderCosmics >, FindletModule< TrackFinder >, FindletModule< TrackFinderSegmentPairAutomaton >, FindletModule< TrackFinderSegmentTripleAutomaton >, FindletModule< TrackFlightTimeAdjuster >, FindletModule< TrackLinker >, FindletModule< TrackOrienter >, FindletModule< TrackQualityAsserter >, FindletModule< TrackQualityEstimator >, FindletModule< TrackRejecter >, FindletModule< WireHitBackgroundDetector >, FindletModule< WireHitCreator >, FindletModule< WireHitPreparer >, CDCTriggerNeuroDQMModule, CDCTriggerNeuroDQMOnlineModule, CDCTriggerNDFinderModule, TRGCDCModule, TRGCDCETFUnpackerModule, TRGCDCT2DDQMModule, TRGCDCT3DConverterModule, TRGCDCT3DDQMModule, TRGCDCT3DUnpackerModule, TRGCDCTSFDQMModule, TRGCDCTSFUnpackerModule, TRGCDCTSStreamModule, MCMatcherTRGECLModule, TRGECLFAMModule, TRGECLModule, TRGECLBGTCHitModule, TRGECLDQMModule, TRGECLQAMModule, TRGECLRawdataAnalysisModule, TRGECLTimingCalModule, TRGECLUnpackerModule, TRGGDLModule, TRGGDLDQMModule, TRGGDLDSTModule, TRGGDLSummaryModule, TRGGDLUnpackerModule, TRGGRLMatchModule, TRGGRLModule, TRGGRLProjectsModule, TRGGRLDQMModule, TRGGRLUnpackerModule, KLMTriggerModule, TRGTOPDQMModule, TRGTOPTRD2TTSConverterModule, TRGTOPUnpackerModule, TRGTOPUnpackerWaveformModule, TRGTOPWaveformPlotterModule, TRGRAWDATAModule, DQMHistAnalysisARICHModule, DQMHistAnalysisARICHMonObjModule, DQMHistAnalysisCDCDedxModule, DQMHistAnalysisCDCEpicsModule, DQMHistAnalysisCDCMonObjModule, DQMHistAnalysisDAQMonObjModule, DQMHistAnalysisECLModule, DQMHistAnalysisECLConnectedRegionsModule, DQMHistAnalysisECLOutOfTimeDigitsModule, DQMHistAnalysisECLShapersModule, DQMHistAnalysisECLSummaryModule, DQMHistAnalysisEpicsExampleModule, DQMHistAnalysisExampleModule, DQMHistAnalysisExampleFlagsModule, DQMHistAnalysisHLTMonObjModule, DQMHistAnalysisInput2Module, DQMHistAnalysisInputPVSrvModule, DQMHistAnalysisInputTestModule, DQMHistAnalysisKLMModule, DQMHistAnalysisKLM2Module, DQMHistAnalysisMiraBelleModule, DQMHistAnalysisMonObjModule, DQMHistAnalysisOutputFileModule, DQMHistAnalysisOutputMonObjModule, DQMHistAnalysisOutputRelayMsgModule, DQMHistAnalysisPXDFitsModule, DQMHistAnalysisSVDClustersOnTrackModule, DQMHistAnalysisSVDDoseModule, DQMHistAnalysisSVDEfficiencyModule, DQMHistAnalysisSVDGeneralModule, DQMHistAnalysisSVDOccupancyModule, DQMHistAnalysisSVDOnMiraBelleModule, DQMHistAnalysisSVDUnpackerModule, DQMHistAnalysisTOPModule, DQMHistAnalysisTRGECLModule, DQMHistAnalysisTRGGDLModule, DQMHistComparitorModule, DQMHistDeltaHistoModule, DQMHistReferenceModule, DQMHistSnapshotsModule, PyModule, SVDUnpackerDQMModule, TrackSetEvaluatorHopfieldNNDEVModule, vxdDigitMaskingModule, DQMHistAnalysisDeltaEpicsMonObjExampleModule, DQMHistAnalysisDeltaTestModule, DQMHistAnalysisEpicsOutputModule, DQMHistAnalysisPhysicsModule, DQMHistAnalysisPXDChargeModule, DQMHistAnalysisPXDTrackChargeModule, DQMHistAnalysisRooFitExampleModule, DQMHistAnalysisTRGModule, and DQMHistOutputToEPICSModule.

Definition at line 166 of file Module.h.

166{};

◆ evalCondition()

bool evalCondition ( ) const
inherited

If at least one condition was set, it is evaluated and true returned if at least one condition returns true.

If no condition or result value was defined, the method returns false. Otherwise, the condition is evaluated and true returned, if at least one condition returns true. To speed up the evaluation, the condition strings were already parsed in the method if_value().

Returns
True if at least one condition and return value exists and at least one condition expression was evaluated to true.

Definition at line 96 of file Module.cc.

97{
98 if (m_conditions.empty()) return false;
99
100 //okay, a condition was set for this Module...
101 if (!m_hasReturnValue) {
102 B2FATAL("A condition was set for '" << getName() << "', but the module did not set a return value!");
103 }
104
105 for (const auto& condition : m_conditions) {
106 if (condition.evaluate(m_returnValue)) {
107 return true;
108 }
109 }
110 return false;
111}
int m_returnValue
The return value.
Definition: Module.h:519
bool m_hasReturnValue
True, if the return value is set.
Definition: Module.h:518

◆ event()

void event ( void  )
overridevirtual

This method is called for each event.

All processing of the event takes place in this method.

Reimplemented from Module.

Definition at line 63 of file HitLevelInfoWriter.cc.

64{
65
66 int nParticleList = m_strParticleList.size();
67
68 // **************************************************
69 // LOOP OVER dE/dx measurements for all tracks if
70 // no particle list is specified.
71 // **************************************************
72 if (nParticleList == 0) {
73 for (int idedx = 0; idedx < m_dedxTracks.getEntries(); idedx++) {
74
75 CDCDedxTrack* dedxTrack = m_dedxTracks[idedx];
76 if (!dedxTrack) {
77 B2WARNING("No dedx related track...");
78 continue;
79 }
80
81 const Track* track = dedxTrack->getRelatedFrom<Track>();
82 if (!track) {
83 B2WARNING("No related track...");
84 continue;
85 }
86
87 const TrackFitResult* fitResult = track->getTrackFitResultWithClosestMass(Const::pion);
88 if (!fitResult) {
89 B2WARNING("No related fit for this track...");
90 continue;
91 }
92
93 if (dedxTrack->size() == 0 || dedxTrack->size() > 200) continue;
94 if (dedxTrack->getCosTheta() < TMath::Cos(150.0 * TMath::DegToRad()))continue; //-0.866
95 if (dedxTrack->getCosTheta() > TMath::Cos(17.0 * TMath::DegToRad())) continue; //0.95
96
97 // fill the event meta data
99 m_expID = evtMetaData->getExperiment();
100 m_runID = evtMetaData->getRun();
101 m_eventID = evtMetaData->getEvent();
102
103 m_injring = dedxTrack->getInjectionRing();
104 m_injtime = dedxTrack->getInjectionTime();
105
106 //--------REMOVEBAL--------
107 //when CDST are reproduced with injection time
108 if (m_injtime == -1 || m_injring == -1) {
109 if (m_TTDInfo.isValid() && m_TTDInfo->hasInjection()) {
110 m_injring = m_TTDInfo->isHER();
111 m_injtime = m_TTDInfo->getTimeSinceLastInjectionInMicroSeconds();
112 }
113 }
114 //--------REMOVEBAL--------
115
116 // fill the E/P
117 const ECLCluster* eclCluster = track->getRelated<ECLCluster>();
118 if (eclCluster and eclCluster->hasHypothesis(ECLCluster::EHypothesisBit::c_nPhotons)) {
119 m_eop = (eclCluster->getEnergy(ECLCluster::EHypothesisBit::c_nPhotons)) / (fitResult->getMomentum().R());
121 if (m_isExtraVar) {
122 m_e1_9 = eclCluster->getE1oE9();
123 m_e9_21 = eclCluster->getE9oE21();
124 m_eclsnHits = eclCluster->getNumberOfCrystals();
125 }
126 // fill the muon depth
127 const KLMCluster* klmCluster = eclCluster->getRelated<KLMCluster>();
128 if (klmCluster) m_klmLayers = klmCluster->getLayers();
129 }
130
131 // fill the TTree with the Track information
132 fillTrack(fitResult);
133
134 // fill the TTree with the CDCDedxTrack information
135 fillDedx(dedxTrack);
136
137 // fill the TTree
138 m_tree[0]->Fill();
139 }
140 }
141
142 // **************************************************
143 //
144 // LOOP OVER particles in the given particle lists
145 //
146 // **************************************************
147 for (int iList = 0; iList < nParticleList; iList++) {
148 // make sure the list exists and is not empty
149 StoreObjPtr<ParticleList> particlelist(m_strParticleList[iList]);
150 if (!particlelist or particlelist->getListSize(true) == 0) {
151 //B2WARNING("ParticleList " << m_strParticleList[iList] << " not found or empty, skipping");
152 continue;
153 }
154
155 // loop over the particles in the list and follow the links to the
156 // dE/dx information (Particle -> PIDLikelihood -> Track -> CDCDedxTrack)
157 for (unsigned int iPart = 0; iPart < particlelist->getListSize(true); iPart++) {
158 Particle* part = particlelist->getParticle(iPart, true);
159 if (!part) {
160 B2WARNING("No particles...");
161 continue;
162 }
164 if (!pid) {
165 B2WARNING("No related PID likelihood...");
166 continue;
167 }
168 Track* track = pid->getRelatedFrom<Track>();
169 if (!track) {
170 B2WARNING("No related track...");
171 continue;
172 }
173 CDCDedxTrack* dedxTrack = track->getRelatedTo<CDCDedxTrack>();
174 if (!dedxTrack) {
175 B2WARNING("No related CDCDedxTrack...");
176 continue;
177 }
178 string ptype = m_strParticleList[iList].substr(0, m_strParticleList[iList].find(":"));
179 const TrackFitResult* fitResult = track->getTrackFitResult(Const::pion);
180 if (ptype != "pi+") {
181 if (ptype == "K+") fitResult = track->getTrackFitResultWithClosestMass(Const::kaon);
182 else if (ptype == "p+") fitResult = track->getTrackFitResultWithClosestMass(Const::proton);
183 else if (ptype == "deuteron") fitResult = track->getTrackFitResultWithClosestMass(Const::deuteron);
184 else if (ptype == "mu+") fitResult = track->getTrackFitResultWithClosestMass(Const::muon);
185 else if (ptype == "e+") fitResult = track->getTrackFitResultWithClosestMass(Const::electron);
186 }
187 if (!fitResult) {
188 B2WARNING("No related fit for this track...");
189 continue;
190 }
191
192 if (dedxTrack->size() == 0 || dedxTrack->size() > 200) continue;
193 //if out CDC (dont add as we dont correct via correctionmodules)
194 if (dedxTrack->getCosTheta() < TMath::Cos(150.0 * TMath::DegToRad()))continue; //-0.866
195 if (dedxTrack->getCosTheta() > TMath::Cos(17.0 * TMath::DegToRad())) continue; //0.95
196
197 // fill the event meta data
198 StoreObjPtr<EventMetaData> evtMetaData;
199 m_expID = evtMetaData->getExperiment();
200 m_runID = evtMetaData->getRun();
201 m_eventID = evtMetaData->getEvent();
202
203 m_injring = dedxTrack->getInjectionRing();
204 m_injtime = dedxTrack->getInjectionTime();
205
206 //--------REMOVEBAL--------
207 //when CDST are reproduced with injection time
208 if (m_injtime == -1 || m_injring == -1) {
209 if (m_TTDInfo.isValid() && m_TTDInfo->hasInjection()) {
210 m_injring = m_TTDInfo->isHER();
211 m_injtime = m_TTDInfo->getTimeSinceLastInjectionInMicroSeconds();
212 }
213 }
214 //--------REMOVEBAL--------
215
216 // fill the E/P
217 const ECLCluster* eclCluster = track->getRelated<ECLCluster>();
218 if (eclCluster and eclCluster->hasHypothesis(ECLCluster::EHypothesisBit::c_nPhotons)) {
219 m_eop = (eclCluster->getEnergy(ECLCluster::EHypothesisBit::c_nPhotons)) / (fitResult->getMomentum().R());
221 if (m_isExtraVar) {
222 m_e1_9 = eclCluster->getE1oE9();
223 m_e9_21 = eclCluster->getE9oE21();
224 m_eclsnHits = eclCluster->getNumberOfCrystals();
225 }
226 // fill the muon depth
227 const KLMCluster* klmCluster = eclCluster->getRelated<KLMCluster>();
228 if (klmCluster) m_klmLayers = klmCluster->getLayers();
229 }
230
231 // fill the TTree with the Track information
232 fillTrack(fitResult);
233
234 // fill the TTree with the CDCDedxTrack information
235 fillDedx(dedxTrack);
236
237 // fill the TTree
238 m_tree[iList]->Fill();
239 }
240 }
241}
Debug output for CDCDedxPID module.
Definition: CDCDedxTrack.h:25
double getCosTheta() const
Return cos(theta) for this track.
Definition: CDCDedxTrack.h:121
double getInjectionRing() const
Return cos(theta) for this track.
Definition: CDCDedxTrack.h:130
double getInjectionTime() const
Return cos(theta) for this track.
Definition: CDCDedxTrack.h:127
int size() const
Return the number of hits for this track.
Definition: CDCDedxTrack.h:200
static const ChargedStable muon
muon particle
Definition: Const.h:660
static const ChargedStable pion
charged pion particle
Definition: Const.h:661
static const ChargedStable proton
proton particle
Definition: Const.h:663
static const ChargedStable kaon
charged kaon particle
Definition: Const.h:662
static const ChargedStable electron
electron particle
Definition: Const.h:659
static const ChargedStable deuteron
deuteron particle
Definition: Const.h:664
ECL cluster data.
Definition: ECLCluster.h:27
bool hasHypothesis(EHypothesisBit bitmask) const
Return if specific hypothesis bit is set.
Definition: ECLCluster.h:351
double getE1oE9() const
Return E1/E9 (shower shape variable).
Definition: ECLCluster.h:277
double getE9oE21() const
Return E9/E21 (shower shape variable).
Definition: ECLCluster.h:280
double getEnergy(EHypothesisBit hypothesis) const
Return Energy (GeV).
Definition: ECLCluster.cc:23
double getNumberOfCrystals() const
Return number of a crystals in a shower (sum of weights).
Definition: ECLCluster.h:295
@ c_nPhotons
CR is split into n photons (N1)
StoreObjPtr< EventLevelTriggerTimeInfo > m_TTDInfo
Store Object Ptr: EventLevelTriggerTimeInfo.
void fillTrack(const TrackFitResult *fitResult)
Fill the TTree with the information from the track fit.
StoreArray< CDCDedxTrack > m_dedxTracks
Required array of CDCDedxTracks.
void fillDedx(CDCDedxTrack *dedxTrack)
Fill the TTree with the information from a CDCDedxTrack object.
KLM cluster data.
Definition: KLMCluster.h:28
int getLayers() const
Get number of layers with hits.
Definition: KLMCluster.h:66
Class to collect log likelihoods from TOP, ARICH, dEdx, ECL and KLM aimed for output to mdst includes...
Definition: PIDLikelihood.h:29
Class to store reconstructed particles.
Definition: Particle.h:75
TO * getRelatedTo(const std::string &name="", const std::string &namedRelation="") const
Get the object to which this object has a relation.
T * getRelated(const std::string &name="", const std::string &namedRelation="") const
Get the object to or from which this object has a relation.
FROM * getRelatedFrom(const std::string &name="", const std::string &namedRelation="") const
Get the object from which this object has a relation.
Type-safe access to single objects in the data store.
Definition: StoreObjPtr.h:96
Values of the result of a track fit with a given particle hypothesis.
ROOT::Math::XYZVector getMomentum() const
Getter for vector of momentum at closest approach of track in r/phi projection.
Class that bundles various TrackFitResults.
Definition: Track.h:25

◆ exposePythonAPI()

void exposePythonAPI ( )
staticinherited

Exposes methods of the Module class to Python.

Definition at line 325 of file Module.cc.

326{
327 // to avoid confusion between std::arg and boost::python::arg we want a shorthand namespace as well
328 namespace bp = boost::python;
329
330 docstring_options options(true, true, false); //userdef, py sigs, c++ sigs
331
332 void (Module::*setReturnValueInt)(int) = &Module::setReturnValue;
333
334 enum_<Module::EAfterConditionPath>("AfterConditionPath",
335 R"(Determines execution behaviour after a conditional path has been executed:
336
337.. attribute:: END
338
339 End processing of this path after the conditional path. (this is the default for if_value() etc.)
340
341.. attribute:: CONTINUE
342
343 After the conditional path, resume execution after this module.)")
344 .value("END", Module::EAfterConditionPath::c_End)
345 .value("CONTINUE", Module::EAfterConditionPath::c_Continue)
346 ;
347
348 /* Do not change the names of >, <, ... we use them to serialize conditional pathes */
349 enum_<Belle2::ModuleCondition::EConditionOperators>("ConditionOperator")
356 ;
357
358 enum_<Module::EModulePropFlags>("ModulePropFlags",
359 R"(Flags to indicate certain low-level features of modules, see :func:`Module.set_property_flags()`, :func:`Module.has_properties()`. Most useful flags are:
360
361.. attribute:: PARALLELPROCESSINGCERTIFIED
362
363 This module can be run in parallel processing mode safely (All I/O must be done through the data store, in particular, the module must not write any files.)
364
365.. attribute:: HISTOGRAMMANAGER
366
367 This module is used to manage histograms accumulated by other modules
368
369.. attribute:: TERMINATEINALLPROCESSES
370
371 When using parallel processing, call this module's terminate() function in all processes. This will also ensure that there is exactly one process (single-core if no parallel modules found) or at least one input, one main and one output process.
372)")
373 .value("INPUT", Module::EModulePropFlags::c_Input)
374 .value("OUTPUT", Module::EModulePropFlags::c_Output)
375 .value("PARALLELPROCESSINGCERTIFIED", Module::EModulePropFlags::c_ParallelProcessingCertified)
376 .value("HISTOGRAMMANAGER", Module::EModulePropFlags::c_HistogramManager)
377 .value("INTERNALSERIALIZER", Module::EModulePropFlags::c_InternalSerializer)
378 .value("TERMINATEINALLPROCESSES", Module::EModulePropFlags::c_TerminateInAllProcesses)
379 ;
380
381 //Python class definition
382 class_<Module, PyModule> module("Module", R"(
383Base class for Modules.
384
385A module is the smallest building block of the framework.
386A typical event processing chain consists of a Path containing
387modules. By inheriting from this base class, various types of
388modules can be created. To use a module, please refer to
389:func:`Path.add_module()`. A list of modules is available by running
390``basf2 -m`` or ``basf2 -m package``, detailed information on parameters is
391given by e.g. ``basf2 -m RootInput``.
392
393The 'Module Development' section in the manual provides detailed information
394on how to create modules, setting parameters, or using return values/conditions:
395https://confluence.desy.de/display/BI/Software+Basf2manual#Module_Development
396
397)");
398 module
399 .def("__str__", &Module::getPathString)
400 .def("name", &Module::getName, return_value_policy<copy_const_reference>(),
401 "Returns the name of the module. Can be changed via :func:`set_name() <Module.set_name()>`, use :func:`type() <Module.type()>` for identifying a particular module class.")
402 .def("type", &Module::getType, return_value_policy<copy_const_reference>(),
403 "Returns the type of the module (i.e. class name minus 'Module')")
404 .def("set_name", &Module::setName, args("name"), R"(
405Set custom name, e.g. to distinguish multiple modules of the same type.
406
407>>> path.add_module('EventInfoSetter')
408>>> ro = path.add_module('RootOutput', branchNames=['EventMetaData'])
409>>> ro.set_name('RootOutput_metadata_only')
410>>> print(path)
411[EventInfoSetter -> RootOutput_metadata_only]
412
413)")
414 .def("description", &Module::getDescription, return_value_policy<copy_const_reference>(),
415 "Returns the description of this module.")
416 .def("package", &Module::getPackage, return_value_policy<copy_const_reference>(),
417 "Returns the package this module belongs to.")
418 .def("available_params", &_getParamInfoListPython,
419 "Return list of all module parameters as `ModuleParamInfo` instances")
420 .def("has_properties", &Module::hasProperties, (bp::arg("properties")),
421 R"DOCSTRING(Allows to check if the module has the given properties out of `ModulePropFlags` set.
422
423>>> if module.has_properties(ModulePropFlags.PARALLELPROCESSINGCERTIFIED):
424>>> ...
425
426Parameters:
427 properties (int): bitmask of `ModulePropFlags` to check for.
428)DOCSTRING")
429 .def("set_property_flags", &Module::setPropertyFlags, args("property_mask"),
430 "Set module properties in the form of an OR combination of `ModulePropFlags`.");
431 {
432 // python signature is too crowded, make ourselves
433 docstring_options subOptions(true, false, false); //userdef, py sigs, c++ sigs
434 module
435 .def("if_value", &Module::if_value,
436 (bp::arg("expression"), bp::arg("condition_path"), bp::arg("after_condition_path")= Module::EAfterConditionPath::c_End),
437 R"DOCSTRING(if_value(expression, condition_path, after_condition_path=AfterConditionPath.END)
438
439Sets a conditional sub path which will be executed after this
440module if the return value set in the module passes the given ``expression``.
441
442Modules can define a return value (int or bool) using ``setReturnValue()``,
443which can be used in the steering file to split the Path based on this value, for example
444
445>>> module_with_condition.if_value("<1", another_path)
446
447In case the return value of the ``module_with_condition`` for a given event is
448less than 1, the execution will be diverted into ``another_path`` for this event.
449
450You could for example set a special return value if an error occurs, and divert
451the execution into a path containing :b2:mod:`RootOutput` if it is found;
452saving only the data producing/produced by the error.
453
454After a conditional path has executed, basf2 will by default stop processing
455the path for this event. This behaviour can be changed by setting the
456``after_condition_path`` argument.
457
458Parameters:
459 expression (str): Expression to determine if the conditional path should be executed.
460 This should be one of the comparison operators ``<``, ``>``, ``<=``,
461 ``>=``, ``==``, or ``!=`` followed by a numerical value for the return value
462 condition_path (Path): path to execute in case the expression is fulfilled
463 after_condition_path (AfterConditionPath): What to do once the ``condition_path`` has been executed.
464)DOCSTRING")
465 .def("if_false", &Module::if_false,
466 (bp::arg("condition_path"), bp::arg("after_condition_path")= Module::EAfterConditionPath::c_End),
467 R"DOC(if_false(condition_path, after_condition_path=AfterConditionPath.END)
468
469Sets a conditional sub path which will be executed after this module if
470the return value of the module evaluates to False. This is equivalent to
471calling `if_value` with ``expression=\"<1\"``)DOC")
472 .def("if_true", &Module::if_true,
473 (bp::arg("condition_path"), bp::arg("after_condition_path")= Module::EAfterConditionPath::c_End),
474 R"DOC(if_true(condition_path, after_condition_path=AfterConditionPath.END)
475
476Sets a conditional sub path which will be executed after this module if
477the return value of the module evaluates to True. It is equivalent to
478calling `if_value` with ``expression=\">=1\"``)DOC");
479 }
480 module
481 .def("has_condition", &Module::hasCondition,
482 "Return true if a conditional path has been set for this module "
483 "using `if_value`, `if_true` or `if_false`")
484 .def("get_all_condition_paths", &_getAllConditionPathsPython,
485 "Return a list of all conditional paths set for this module using "
486 "`if_value`, `if_true` or `if_false`")
487 .def("get_all_conditions", &_getAllConditionsPython,
488 "Return a list of all conditional path expressions set for this module using "
489 "`if_value`, `if_true` or `if_false`")
490 .add_property("logging", make_function(&Module::getLogConfig, return_value_policy<reference_existing_object>()),
@ c_GE
Greater or equal than: ">=".
@ c_SE
Smaller or equal than: "<=".
@ c_GT
Greater than: ">"
@ c_NE
Not equal: "!=".
@ c_EQ
Equal: "=" or "=="
@ c_ST
Smaller than: "<"
Base class for Modules.
Definition: Module.h:72
LogConfig & getLogConfig()
Returns the log system configuration.
Definition: Module.h:225
void if_value(const std::string &expression, const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End)
Add a condition to the module.
Definition: Module.cc:79
void setPropertyFlags(unsigned int propertyFlags)
Sets the flags for the module properties.
Definition: Module.cc:208
void if_true(const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End)
A simplified version to set the condition of the module.
Definition: Module.cc:90
void setReturnValue(int value)
Sets the return value for this module as integer.
Definition: Module.cc:220
void setLogConfig(const LogConfig &logConfig)
Set the log system configuration.
Definition: Module.h:230
const std::string & getDescription() const
Returns the description of the module.
Definition: Module.h:202
void if_false(const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End)
A simplified version to add a condition to the module.
Definition: Module.cc:85
bool hasCondition() const
Returns true if at least one condition was set for the module.
Definition: Module.h:311
const std::string & getPackage() const
Returns the package this module is in.
Definition: Module.h:197
void setName(const std::string &name)
Set the name of the module.
Definition: Module.h:214
bool hasProperties(unsigned int propertyFlags) const
Returns true if all specified property flags are available in this module.
Definition: Module.cc:160
std::string getPathString() const override
return the module name.
Definition: Module.cc:192

◆ fillDedx()

void fillDedx ( CDCDedxTrack dedxTrack)
private

Fill the TTree with the information from a CDCDedxTrack object.

Definition at line 297 of file HitLevelInfoWriter.cc.

298{
299 // clear the containers first
300 clearEntries();
301
302 m_trackID = dedxTrack->trackID();
303 m_length = dedxTrack->getLength();
304 m_charge = dedxTrack->getCharge();
305 m_cosTheta = dedxTrack->getCosTheta();
306 m_PDG = dedxTrack->getPDG();
307
308 m_pCDC = dedxTrack->getMomentum();
309 if (m_charge < 0) {
310 m_pCDC *= -1;
311 }
312
313 h_nhits = dedxTrack->size();
314
315 // Get the calibration constants
316 m_scale = m_DBScaleFactor->getScaleFactor();
317 m_runGain = m_DBRunGain->getRunGain();
319 m_timeGain = m_DBInjectTime->getCorrection("mean", m_injring, m_injtime);
320 m_timeReso = m_DBInjectTime->getCorrection("reso", m_injring, m_injtime);
321
322 if (m_cosTheta <= -0.850 || m_cosTheta >= 0.950) {
324 } else {
325 m_cosEdgeCor = 1.0;
326 }
327 m_hadronpars = m_DBHadronCor->getHadronPars();
328
329 //variable to save layer variables
330 map<int, vector<double>>l_var;
331 double cdcChi[Const::ChargedStable::c_SetSize];
332
333 //Modify the hit level dedx
334 if (m_isCorrection) {
335 recalculateDedx(dedxTrack, l_var, cdcChi);
336 m_chie = cdcChi[0];
337 m_chimu = cdcChi[1];
338 m_chipi = cdcChi[2];
339 m_chik = cdcChi[3];
340 m_chip = cdcChi[4];
341 m_chid = cdcChi[5];
342 } else {
343 m_mean = dedxTrack->getDedxMean();
344 m_trunc = dedxTrack->getDedx();
345 m_truncNoSat = dedxTrack->getDedxNoSat();
346 m_error = dedxTrack->getDedxError();
347 m_chie = dedxTrack->getChi(0);
348 m_chimu = dedxTrack->getChi(1);
349 m_chipi = dedxTrack->getChi(2);
350 m_chik = dedxTrack->getChi(3);
351 m_chip = dedxTrack->getChi(4);
352 m_chid = dedxTrack->getChi(5);
353 }
354
355 m_pmeane = dedxTrack->getPmean(0);
356 m_pmeanmu = dedxTrack->getPmean(1);
357 m_pmeanpi = dedxTrack->getPmean(2);
358 m_pmeank = dedxTrack->getPmean(3);
359 m_pmeanp = dedxTrack->getPmean(4);
360 m_pmeand = dedxTrack->getPmean(5);
361
362 m_prese = dedxTrack->getPreso(0);
363 m_presmu = dedxTrack->getPreso(1);
364 m_prespi = dedxTrack->getPreso(2);
365 m_presk = dedxTrack->getPreso(3);
366 m_presp = dedxTrack->getPreso(4);
367 m_presd = dedxTrack->getPreso(5);
368
369 // Get the vector of dE/dx values for all layers
370 double lout = 0, lin = 0, increment = 0;
371 int lastlayer = 0;
372
373 if (m_isCorrection) {
374 l_nhits = l_var[0].size();
375 const int lEdgeTrunc = int(l_nhits * 0.05 + 0.51);
376 const int hEdgeTrunc = int(l_nhits * (1 - 0.25) + 0.51);
377 l_nhitsused = hEdgeTrunc - lEdgeTrunc;
378 } else {
379 l_nhits = dedxTrack->getNLayerHits();
380 l_nhitsused = dedxTrack->getNLayerHitsUsed();
381 }
382
383 for (int il = 0; il < l_nhits; ++il) {
384 if (m_isCorrection) {
385 l_nhitscombined[il] = l_var[0][il];
386 l_wirelongesthit[il] = l_var[1][il];
387 l_layer[il] = l_var[2][il];
388 l_path[il] = l_var[3][il];
389 l_dedx[il] = l_var[4][il];
390 } else {
391 l_nhitscombined[il] = dedxTrack->getNHitsCombined(il);
392 l_wirelongesthit[il] = dedxTrack->getWireLongestHit(il);
393 l_layer[il] = dedxTrack->getLayer(il);
394 l_path[il] = dedxTrack->getLayerPath(il);
395 l_dedx[il] = dedxTrack->getLayerDedx(il);
396 }
397 if (l_layer[il] > lastlayer) lout++;
398 else if (l_layer[il] < lastlayer) lin++;
399 else continue;
400
401 lastlayer = l_layer[il];
402 increment++;
403 }
404 m_ioasym = (lout - lin) / increment;
405
406 // Get the vector of dE/dx values for all hits
407 if (m_isHitLevel) {
408 for (int ihit = 0; ihit < h_nhits; ++ihit) {
409
410 if (m_isDeadwire) continue;
411
412 h_lwire[ihit] = dedxTrack->getWireInLayer(ihit);
413 h_wire[ihit] = dedxTrack->getWire(ihit);
414 h_layer[ihit] = dedxTrack->getHitLayer(ihit);
415 h_path[ihit] = dedxTrack->getPath(ihit);
416 h_dedx[ihit] = dedxTrack->getDedx(ihit);
417 h_adcraw[ihit] = dedxTrack->getADCBaseCount(ihit);
418 h_adccorr[ihit] = dedxTrack->getADCCount(ihit);
419 h_doca[ihit] = dedxTrack->getDoca(ihit);
420 h_ndoca[ihit] = h_doca[ihit] / dedxTrack->getCellHalfWidth(ihit);
421 h_ndocaRS[ihit] = dedxTrack->getDocaRS(ihit) / dedxTrack->getCellHalfWidth(ihit);
422 h_enta[ihit] = dedxTrack->getEnta(ihit);
423 h_entaRS[ihit] = dedxTrack->getEntaRS(ihit);
424 h_driftT[ihit] = dedxTrack->getDriftT(ihit);
425 h_driftD[ihit] = dedxTrack->getDriftD(ihit);
426
427 // Get extra variable from tracking
428 if (m_isExtraVar) {
429 h_WeightPionHypo[ihit] = dedxTrack->getWeightPionHypo(ihit);
430 h_WeightKaonHypo[ihit] = dedxTrack->getWeightKaonHypo(ihit);
431 h_WeightProtonHypo[ihit] = dedxTrack->getWeightProtonHypo(ihit);
432 h_foundByTrackFinder[ihit] = dedxTrack->getFoundByTrackFinder(ihit);
433 }
434 // Get the calibration constants
435 h_facnladc[ihit] = dedxTrack->getNonLADCCorrection(ihit);
436 h_wireGain[ihit] = m_DBWireGains->getWireGain(h_wire[ihit]);
437 h_twodCor[ihit] = m_DB2DCell->getMean(h_layer[ihit], h_ndocaRS[ihit], h_entaRS[ihit]);
438 h_onedCor[ihit] = m_DB1DCell->getMean(h_layer[ihit], h_entaRS[ihit]);
439 }
440 }
441
442}
int getHitLayer(int i) const
Return the (global) layer number for a hit.
Definition: CDCDedxTrack.h:209
int getADCBaseCount(int i) const
Return the base adcCount (no non-linearity) for this hit.
Definition: CDCDedxTrack.h:221
int getADCCount(int i) const
Return the adcCount for this hit.
Definition: CDCDedxTrack.h:218
double getDedxMean() const
Get the dE/dx mean for this track.
Definition: CDCDedxTrack.h:112
double getDriftD(int i) const
Return the drift distance for this hit.
Definition: CDCDedxTrack.h:251
int getLayer(int i) const
Return the (global) layer number for a layer hit.
Definition: CDCDedxTrack.h:186
double getDoca(int i) const
Return the distance of closest approach to the sense wire for this hit.
Definition: CDCDedxTrack.h:227
double getDedx() const
Get dE/dx truncated mean for this track.
Definition: CDCDedxTrack.h:103
double getPath(int i) const
Return the path length through the cell for this hit.
Definition: CDCDedxTrack.h:212
int getWireInLayer(int i) const
Return the sensor ID for this hit: wire number in the layer.
Definition: CDCDedxTrack.h:203
double getPmean(int i) const
Return the PID (predicted mean) value.
Definition: CDCDedxTrack.h:282
int getWireLongestHit(int i) const
Return the wire number of the longest hit per layer.
Definition: CDCDedxTrack.h:183
double getWeightKaonHypo(int i) const
Return the max weights from KalmanFitterInfo using kaon hypothesis.
Definition: CDCDedxTrack.h:273
double getEntaRS(int i) const
Return rescaled enta value for cell height=width assumption.
Definition: CDCDedxTrack.h:236
double getLayerDedx(int i) const
Return the total dE/dx for this layer.
Definition: CDCDedxTrack.h:192
double getCellHalfWidth(int i) const
Return the half-width of the CDC cell.
Definition: CDCDedxTrack.h:248
double getPDG() const
Get the identity of the particle.
Definition: CDCDedxTrack.h:100
double getPreso(int i) const
Return the PID (predicted reso) value.
Definition: CDCDedxTrack.h:285
int getNLayerHits() const
Return the number of layer hits for this track.
Definition: CDCDedxTrack.h:174
int getFoundByTrackFinder(int i) const
Return the TrackFinder which added the given hit to track.
Definition: CDCDedxTrack.h:267
int getDriftT(int i) const
Return the drift time for this hit.
Definition: CDCDedxTrack.h:239
int getCharge() const
Return the charge for this track.
Definition: CDCDedxTrack.h:124
double getWeightPionHypo(int i) const
Return the max weights from KalmanFitterInfo using pion hypothesis.
Definition: CDCDedxTrack.h:270
int getWire(int i) const
Return the sensor ID for this hit: wire number for CDC (0-14336)
Definition: CDCDedxTrack.h:206
double getDocaRS(int i) const
Return rescaled doca value for cell height=width assumption.
Definition: CDCDedxTrack.h:233
double getNonLADCCorrection(int i) const
Return the factor introduce for adcCount (non-linearity) correction.
Definition: CDCDedxTrack.h:224
double getDedxError() const
Get the error on the dE/dx truncated mean for this track.
Definition: CDCDedxTrack.h:109
double getWeightProtonHypo(int i) const
Return the max weights from KalmanFitterInfo using proton hypothesis.
Definition: CDCDedxTrack.h:276
double getEnta(int i) const
Return the entrance angle in the CDC cell for this hit.
Definition: CDCDedxTrack.h:230
double trackID() const
Return the track ID.
Definition: CDCDedxTrack.h:97
double getLayerPath(int i) const
Return the distance travelled in this layer.
Definition: CDCDedxTrack.h:189
double getChi(int i) const
Return the PID (chi) value.
Definition: CDCDedxTrack.h:279
double getLength() const
Return the total path length for this track.
Definition: CDCDedxTrack.h:133
int getNHitsCombined(int i) const
Return the number of hits combined per layer.
Definition: CDCDedxTrack.h:180
double getDedxNoSat() const
Get dE/dx truncated mean without the saturation correction for this track.
Definition: CDCDedxTrack.h:106
double getNLayerHitsUsed() const
Return the number of hits used to determine the truncated mean.
Definition: CDCDedxTrack.h:177
double getMomentum() const
Return the track momentum valid in the CDC.
Definition: CDCDedxTrack.h:118
static const unsigned int c_SetSize
Number of elements (for use in array bounds etc.)
Definition: Const.h:615
DBObjPtr< CDCDedxRunGain > m_DBRunGain
Run gain DB object.
DBObjPtr< CDCDedxHadronCor > m_DBHadronCor
hadron saturation parameters
DBObjPtr< CDCDedxCosineEdge > m_DBCosEdgeCor
cosine edge calibration
DBObjPtr< CDCDedx1DCell > m_DB1DCell
1D correction DB object
void recalculateDedx(CDCDedxTrack *dedxTrack, std::map< int, std::vector< double > > &l_var, double(&cdcChi)[Const::ChargedStable::c_SetSize])
Function to recalculate the dedx with latest constants.
DBObjPtr< CDCDedx2DCell > m_DB2DCell
2D correction DB object
void clearEntries()
Clear the arrays before filling an event.
DBObjPtr< CDCDedxCosineCor > m_DBCosineCor
Electron saturation correction DB object.
DBObjPtr< CDCDedxWireGain > m_DBWireGains
Wire gain DB object.
DBObjPtr< CDCDedxInjectionTime > m_DBInjectTime
time gain/reso DB object
DBObjPtr< CDCDedxScaleFactor > m_DBScaleFactor
Scale factor to make electrons ~1.

◆ fillTrack()

void fillTrack ( const TrackFitResult fitResult)
private

Fill the TTree with the information from the track fit.

Definition at line 258 of file HitLevelInfoWriter.cc.

259{
260 ROOT::Math::XYZVector trackMom = fitResult->getMomentum();
261 m_p = trackMom.R();
262 m_pt = trackMom.Rho();
263 m_phi = trackMom.Phi();
264
265 m_theta = trackMom.Theta() * 180. / TMath::Pi(); //in degree
266 if (m_theta > 17. && m_theta < 150.)m_inCDC = 1;
267 else m_inCDC = 0;
268
269 if (fitResult->getChargeSign() < 0) {
270 m_p *= -1;
271 m_pt *= -1;
272 }
273
274 ROOT::Math::XYZVector trackPos = fitResult->getPosition();
275 m_vx0 = trackPos.X();
276 m_vy0 = trackPos.Y();
277 m_vz0 = trackPos.Z();
278
279 m_d0 = fitResult->getD0();
280 m_z0 = fitResult->getZ0();
281 m_chi2 = fitResult->getPValue();
282 m_tanlambda = fitResult->getTanLambda();
283 m_phi0 = fitResult->getPhi0();
284 m_nCDChits = fitResult->getHitPatternCDC().getNHits();
285
286 static DBObjPtr<BeamSpot> beamSpotDB;
287 const auto& frame = ReferenceFrame::GetCurrent();
288 UncertainHelix helix = fitResult->getUncertainHelix();
289 helix.passiveMoveBy(ROOT::Math::XYZVector(beamSpotDB->getIPPosition()));
290 m_dr = frame.getVertex(ROOT::Math::XYZVector(helix.getPerigee())).Rho();
291 m_dphi = frame.getVertex(ROOT::Math::XYZVector(helix.getPerigee())).Phi();
292 m_dz = frame.getVertex(ROOT::Math::XYZVector(helix.getPerigee())).Z();
293
294}
Class for accessing objects in the database.
Definition: DBObjPtr.h:21
double m_theta
cos(theta) for the track
unsigned short getNHits() const
Get the total Number of CDC hits in the fit.
static const ReferenceFrame & GetCurrent()
Get current rest frame.
short getChargeSign() const
Return track charge (1 or -1).
double getPValue() const
Getter for Chi2 Probability of the track fit.
double getD0() const
Getter for d0.
double getTanLambda() const
Getter for tanLambda.
double getZ0() const
Getter for z0.
ROOT::Math::XYZVector getPosition() const
Getter for vector of position at closest approach of track in r/phi projection.
HitPatternCDC getHitPatternCDC() const
Getter for the hit pattern in the CDC;.
UncertainHelix getUncertainHelix() const
Conversion to framework Uncertain Helix (i.e., with covariance).
double getPhi0() const
Getter for phi0.
This class represents an ideal helix in perigee parameterization including the covariance matrix of t...
double passiveMoveBy(const ROOT::Math::XYZVector &by)
Moves origin of the coordinate system (passive transformation) by the given vector.

◆ getAfterConditionPath()

Module::EAfterConditionPath getAfterConditionPath ( ) const
inherited

What to do after the conditional path is finished.

(defaults to c_End if no condition is set)

Definition at line 133 of file Module.cc.

134{
135 if (m_conditions.empty()) return EAfterConditionPath::c_End;
136
137 //okay, a condition was set for this Module...
138 if (!m_hasReturnValue) {
139 B2FATAL("A condition was set for '" << getName() << "', but the module did not set a return value!");
140 }
141
142 for (const auto& condition : m_conditions) {
143 if (condition.evaluate(m_returnValue)) {
144 return condition.getAfterConditionPath();
145 }
146 }
147
148 return EAfterConditionPath::c_End;
149}

◆ getAllConditionPaths()

std::vector< std::shared_ptr< Path > > getAllConditionPaths ( ) const
inherited

Return all condition paths currently set (no matter if the condition is true or not).

Definition at line 150 of file Module.cc.

151{
152 std::vector<std::shared_ptr<Path>> allConditionPaths;
153 for (const auto& condition : m_conditions) {
154 allConditionPaths.push_back(condition.getPath());
155 }
156
157 return allConditionPaths;
158}

◆ getAllConditions()

const std::vector< ModuleCondition > & getAllConditions ( ) const
inlineinherited

Return all set conditions for this module.

Definition at line 324 of file Module.h.

325 {
326 return m_conditions;
327 }

◆ getCondition()

const ModuleCondition * getCondition ( ) const
inlineinherited

Return a pointer to the first condition (or nullptr, if none was set)

Definition at line 314 of file Module.h.

315 {
316 if (m_conditions.empty()) {
317 return nullptr;
318 } else {
319 return &m_conditions.front();
320 }
321 }

◆ getConditionPath()

std::shared_ptr< Path > getConditionPath ( ) const
inherited

Returns the path of the last true condition (if there is at least one, else reaturn a null pointer).


Definition at line 113 of file Module.cc.

114{
115 PathPtr p;
116 if (m_conditions.empty()) return p;
117
118 //okay, a condition was set for this Module...
119 if (!m_hasReturnValue) {
120 B2FATAL("A condition was set for '" << getName() << "', but the module did not set a return value!");
121 }
122
123 for (const auto& condition : m_conditions) {
124 if (condition.evaluate(m_returnValue)) {
125 return condition.getPath();
126 }
127 }
128
129 // if none of the conditions were true, return a null pointer.
130 return p;
131}
std::shared_ptr< Path > PathPtr
Defines a pointer to a path object as a boost shared pointer.
Definition: Path.h:35

◆ GetCorrection()

double GetCorrection ( int &  adc,
int  layer,
int  wireID,
double  doca,
double  enta,
double  costheta,
double  ring,
double  time 
) const

Function to get the correction factor.

Definition at line 536 of file HitLevelInfoWriter.cc.

538{
539 double correction = 1.0;
540 correction *= m_DBScaleFactor->getScaleFactor();
541 correction *= m_DBRunGain->getRunGain();
542 correction *= m_DB2DCell->getMean(layer, doca, enta);
543 correction *= m_DB1DCell->getMean(layer, enta);
544 correction *= m_DBCosineCor->getMean(costheta);
545 correction *= m_DBInjectTime->getCorrection("mean", ring, time);
546 if (costheta <= -0.850 || costheta >= 0.950) correction *= m_DBCosEdgeCor->getMean(costheta);
547 if (m_DBWireGains->getWireGain(wireID) > 0) correction *= m_DBWireGains->getWireGain(wireID);
548
549 //last is only for abs constant
550 if (!m_isRelative) adc = m_DBNonlADC->getCorrectedADC(adc, layer);
551
552 return correction;
553}
DBObjPtr< CDCDedxADCNonLinearity > m_DBNonlADC
hadron saturation non linearity

◆ getDescription()

const std::string & getDescription ( ) const
inlineinherited

Returns the description of the module.

Definition at line 202 of file Module.h.

202{return m_description;}
std::string m_description
The description of the module.
Definition: Module.h:511

◆ getFileNames()

virtual std::vector< std::string > getFileNames ( bool  outputFiles)
inlinevirtualinherited

Return a list of output filenames for this modules.

This will be called when basf2 is run with "--dry-run" if the module has set either the c_Input or c_Output properties.

If the parameter outputFiles is false (for modules with c_Input) the list of input filenames should be returned (if any). If outputFiles is true (for modules with c_Output) the list of output files should be returned (if any).

If a module has sat both properties this member is called twice, once for each property.

The module should return the actual list of requested input or produced output filenames (including handling of input/output overrides) so that the grid system can handle input/output files correctly.

This function should return the same value when called multiple times. This is especially important when taking the input/output overrides from Environment as they get consumed when obtained so the finalized list of output files should be stored for subsequent calls.

Reimplemented in RootInputModule, StorageRootOutputModule, and RootOutputModule.

Definition at line 134 of file Module.h.

135 {
136 return std::vector<std::string>();
137 }

◆ getLogConfig()

LogConfig & getLogConfig ( )
inlineinherited

Returns the log system configuration.

Definition at line 225 of file Module.h.

225{return m_logConfig;}

◆ getModules()

std::list< ModulePtr > getModules ( ) const
inlineoverrideprivatevirtualinherited

no submodules, return empty list

Implements PathElement.

Definition at line 506 of file Module.h.

506{ return std::list<ModulePtr>(); }

◆ getName()

const std::string & getName ( ) const
inlineinherited

Returns the name of the module.

This can be changed via e.g. set_name() in the steering file to give more useful names if there is more than one module of the same type.

For identifying the type of a module, using getType() (or type() in Python) is recommended.

Definition at line 187 of file Module.h.

187{return m_name;}
std::string m_name
The name of the module, saved as a string (user-modifiable)
Definition: Module.h:508

◆ getPackage()

const std::string & getPackage ( ) const
inlineinherited

Returns the package this module is in.

Definition at line 197 of file Module.h.

197{return m_package;}

◆ getParamInfoListPython()

std::shared_ptr< boost::python::list > getParamInfoListPython ( ) const
inherited

Returns a python list of all parameters.

Each item in the list consists of the name of the parameter, a string describing its type, a python list of all default values and the description of the parameter.

Returns
A python list containing the parameters of this parameter list.

Definition at line 279 of file Module.cc.

280{
282}
std::shared_ptr< boost::python::list > getParamInfoListPython() const
Returns a python list of all parameters.
ModuleParamList m_moduleParamList
List storing and managing all parameter of the module.
Definition: Module.h:516

◆ getParamList()

const ModuleParamList & getParamList ( ) const
inlineinherited

Return module param list.

Definition at line 363 of file Module.h.

363{ return m_moduleParamList; }

◆ getPathString()

std::string getPathString ( ) const
overrideprivatevirtualinherited

return the module name.

Implements PathElement.

Definition at line 192 of file Module.cc.

193{
194
195 std::string output = getName();
196
197 for (const auto& condition : m_conditions) {
198 output += condition.getString();
199 }
200
201 return output;
202}

◆ getReturnValue()

int getReturnValue ( ) const
inlineinherited

Return the return value set by this module.

This value is only meaningful if hasReturnValue() is true

Definition at line 381 of file Module.h.

381{ return m_returnValue; }

◆ getType()

const std::string & getType ( ) const
inherited

Returns the type of the module (i.e.

class name minus 'Module')

Definition at line 41 of file Module.cc.

42{
43 if (m_type.empty())
44 B2FATAL("Module type not set for " << getName());
45 return m_type;
46}
std::string m_type
The type of the module, saved as a string.
Definition: Module.h:509

◆ HadronCorrection()

void HadronCorrection ( double  costheta,
double &  dedx 
) const

Function to apply the hadron correction.

Definition at line 556 of file HitLevelInfoWriter.cc.

557{
558 dedx = D2I(costheta, I2D(costheta, 1.00) / 1.00 * dedx);
559}
double D2I(const double cosTheta, const double D) const
hadron saturation parameterization part 2
double I2D(const double cosTheta, const double I) const
hadron saturation parameterization part 1

◆ hasCondition()

bool hasCondition ( ) const
inlineinherited

Returns true if at least one condition was set for the module.

Definition at line 311 of file Module.h.

311{ return not m_conditions.empty(); };

◆ hasProperties()

bool hasProperties ( unsigned int  propertyFlags) const
inherited

Returns true if all specified property flags are available in this module.

Parameters
propertyFlagsOred EModulePropFlags which should be compared with the module flags.

Definition at line 160 of file Module.cc.

161{
162 return (propertyFlags & m_propertyFlags) == propertyFlags;
163}

◆ hasReturnValue()

bool hasReturnValue ( ) const
inlineinherited

Return true if this module has a valid return value set.

Definition at line 378 of file Module.h.

378{ return m_hasReturnValue; }

◆ hasUnsetForcedParams()

bool hasUnsetForcedParams ( ) const
inherited

Returns true and prints error message if the module has unset parameters which the user has to set in the steering file.

Definition at line 166 of file Module.cc.

167{
169 std::string allMissing = "";
170 for (const auto& s : missing)
171 allMissing += s + " ";
172 if (!missing.empty())
173 B2ERROR("The following required parameters of Module '" << getName() << "' were not specified: " << allMissing <<
174 "\nPlease add them to your steering file.");
175 return !missing.empty();
176}
std::vector< std::string > getUnsetForcedParams() const
Returns list of unset parameters (if they are required to have a value.

◆ I2D()

double I2D ( const double  cosTheta,
const double  I 
) const

hadron saturation parameterization part 1

Definition at line 585 of file HitLevelInfoWriter.cc.

586{
587 double absCosTheta = fabs(cosTheta);
588 double projection = pow(absCosTheta, m_hadronpars[3]) + m_hadronpars[2];
589
590 if (projection == 0 || m_hadronpars[4] == 0) {
591 B2WARNING("Something wrong with dE/dx hadron constants!");
592 return I;
593 }
594
595 double a = m_hadronpars[0] / projection;
596 double b = 1 - m_hadronpars[1] / projection * (I / m_hadronpars[4]);
597 double c = -1.0 * I / m_hadronpars[4];
598
599 if (b == 0 && a == 0) {
600 B2WARNING("both a and b coefficiants for hadron correction are 0");
601 return I;
602 }
603
604 double discr = b * b - 4.0 * a * c;
605 if (discr < 0) {
606 B2WARNING("negative discriminant; return uncorrectecd value");
607 return I;
608 }
609
610 double D = (a != 0) ? (-b + sqrt(discr)) / (2.0 * a) : -c / b;
611 if (D < 0) {
612 B2WARNING("D is less 0! will try another solution");
613 D = (a != 0) ? (-b - sqrt(discr)) / (2.0 * a) : -c / b;
614 if (D < 0) {
615 B2WARNING("D is still less 0! just return uncorrectecd value");
616 return I;
617 }
618 }
619
620 return D;
621}

◆ if_false()

void if_false ( const std::shared_ptr< Path > &  path,
EAfterConditionPath  afterConditionPath = EAfterConditionPath::c_End 
)
inherited

A simplified version to add a condition to the module.

Please note that successive calls of this function will add more than one condition to the module. If more than one condition results in true, only the last of them will be used.

Please be careful: Avoid creating cyclic paths, e.g. by linking a condition to a path which is processed before the path where this module is located in.

It is equivalent to the if_value() method, using the expression "<1". This method is meant to be used together with the setReturnValue(bool value) method.

Parameters
pathShared pointer to the Path which will be executed if the return value is false.
afterConditionPathWhat to do after executing 'path'.

Definition at line 85 of file Module.cc.

86{
87 if_value("<1", path, afterConditionPath);
88}

◆ if_true()

void if_true ( const std::shared_ptr< Path > &  path,
EAfterConditionPath  afterConditionPath = EAfterConditionPath::c_End 
)
inherited

A simplified version to set the condition of the module.

Please note that successive calls of this function will add more than one condition to the module. If more than one condition results in true, only the last of them will be used.

Please be careful: Avoid creating cyclic paths, e.g. by linking a condition to a path which is processed before the path where this module is located in.

It is equivalent to the if_value() method, using the expression ">=1". This method is meant to be used together with the setReturnValue(bool value) method.

Parameters
pathShared pointer to the Path which will be executed if the return value is true.
afterConditionPathWhat to do after executing 'path'.

Definition at line 90 of file Module.cc.

91{
92 if_value(">=1", path, afterConditionPath);
93}

◆ if_value()

void if_value ( const std::string &  expression,
const std::shared_ptr< Path > &  path,
EAfterConditionPath  afterConditionPath = EAfterConditionPath::c_End 
)
inherited

Add a condition to the module.

Please note that successive calls of this function will add more than one condition to the module. If more than one condition results in true, only the last of them will be used.

See https://confluence.desy.de/display/BI/Software+ModCondTut or ModuleCondition for a description of the syntax.

Please be careful: Avoid creating cyclic paths, e.g. by linking a condition to a path which is processed before the path where this module is located in.

Parameters
expressionThe expression of the condition.
pathShared pointer to the Path which will be executed if the condition is evaluated to true.
afterConditionPathWhat to do after executing 'path'.

Definition at line 79 of file Module.cc.

80{
81 m_conditions.emplace_back(expression, path, afterConditionPath);
82}

◆ initialize()

void initialize ( void  )
overridevirtual

Initialize the module.

Reimplemented from Module.

Definition at line 36 of file HitLevelInfoWriter.cc.

37{
38
39 B2INFO("Creating a ROOT file for the hit level information...");
40
41 // required inputs
42 m_dedxTracks.isRequired();
43 m_tracks.isRequired();
44 m_trackFitResults.isRequired();
45 m_eclClusters.isOptional();
46 m_klmClusters.isOptional();
47
48 // build a map to relate input strings to the right particle type
49 map<string, string> pdgMap = {{"pi+", "Const::pion.getPDGCode()"}, {"K+", "Const::kaon.getPDGCode()"}, {"mu+", "Const::muon.getPDGCode()"}, {"e+", "Const::electron.getPDGCode()"}, {"p+", "Const::proton.getPDGCode()"}, {"deuteron", "Const::deuteron.getPDGCode()"}};
50
51 // if no particle lists are given, write out all tracks
53
54 // create a new output file for each particle list specified
55 for (unsigned int i = 0; i < m_strParticleList.size(); i++) {
56 // strip the name of the particle lists to make this work
57 string pdg = pdgMap[m_strParticleList[i].substr(0, m_strParticleList[i].find(":"))];
58 string filename = string(m_strOutputBaseName + "_PID" + pdg + ".root");
59 bookOutput(filename);
60 }
61}
StoreArray< KLMCluster > m_klmClusters
Required array of input KLMClusters.
StoreArray< TrackFitResult > m_trackFitResults
Required array of input TrackFitResults.
void bookOutput(std::string filename)
Create the output TFiles and TTrees.
StoreArray< Track > m_tracks
Required array of input Tracks.
StoreArray< ECLCluster > m_eclClusters
Required array of input ECLClusters.

◆ recalculateDedx()

void recalculateDedx ( CDCDedxTrack dedxTrack,
std::map< int, std::vector< double > > &  l_var,
double(&)  cdcChi[Const::ChargedStable::c_SetSize] 
)

Function to recalculate the dedx with latest constants.

Definition at line 445 of file HitLevelInfoWriter.cc.

447{
448 vector<double> newLayerHits;
449 double newLayerDe = 0, newLayerDx = 0;
450 int nhitscombined = 0; // number of hits combined per layer
451 int wirelongesthit = 0; // wire number of longest hit
452 double longesthit = 0; // path length of longest hit
453
454 for (int ihit = 0; ihit < h_nhits; ++ihit) {
455 int jadcbase = dedxTrack->getADCBaseCount(ihit);
456 int jLayer = dedxTrack->getHitLayer(ihit);
457 double jWire = dedxTrack->getWire(ihit);
458 double jNDocaRS = dedxTrack->getDocaRS(ihit) / dedxTrack->getCellHalfWidth(ihit);
459 double jEntaRS = dedxTrack->getEntaRS(ihit);
460 double jPath = dedxTrack->getPath(ihit);
461
462 double correction = dedxTrack->getScaleFactor() * dedxTrack->getRunGain() * dedxTrack->getTimeMean() *
463 dedxTrack->getCosineCorrection() * dedxTrack->getCosEdgeCorrection() *
464 dedxTrack->getTwoDCorrection(ihit) * dedxTrack->getOneDCorrection(ihit) *
465 dedxTrack->getNonLADCCorrection(ihit);
466 if (dedxTrack->getWireGain(ihit) > 0) correction *= dedxTrack->getWireGain(ihit); //also keep dead wire
467
468 if (m_isRelative) {
469 //get same base adc + rel correction factor
470 correction *= GetCorrection(jadcbase, jLayer, jWire, jNDocaRS, jEntaRS, m_cosTheta, m_injring, m_injtime);
471 if (!m_DBWireGains && dedxTrack->getWireGain(ihit) == 0) correction = 0;
472 } else {
473 //get modifed adc + abs correction factor
474 correction = GetCorrection(jadcbase, jLayer, jWire, jNDocaRS, jEntaRS, m_cosTheta, m_injring, m_injtime);
475 }
476
477 double newhitdedx = 1.0;
478
479 newhitdedx *= jadcbase * sqrt(1 - m_cosTheta * m_cosTheta) / jPath;
480
481 if (correction != 0) {
482 newhitdedx /= correction;
483 if (m_DBWireGains->getWireGain(jWire) != 0) {
484 newLayerDe += jadcbase / correction;
485 newLayerDx += jPath;
486 if (jPath > longesthit) {
487 longesthit = jPath;
488 wirelongesthit = jWire;
489 }
490 nhitscombined++;
491 }
492 } else newhitdedx = 0;
493
494 dedxTrack->setDedx(ihit, newhitdedx);
495
496 if (ihit + 1 < h_nhits && dedxTrack->getHitLayer(ihit + 1) == jLayer) {
497 continue;
498 } else {
499 if (newLayerDx != 0) {
500 double totalDistance = newLayerDx / sqrt(1 - m_cosTheta * m_cosTheta);
501 double newLayerDedx = newLayerDe / totalDistance ;
502 newLayerHits.push_back(newLayerDedx);
503 l_var[0].push_back(nhitscombined);
504 l_var[1].push_back(wirelongesthit);
505 l_var[2].push_back(jLayer);
506 l_var[3].push_back(totalDistance);
507 l_var[4].push_back(newLayerDedx);
508 }
509
510 newLayerDe = 0;
511 newLayerDx = 0;
512 nhitscombined = 0;
513 wirelongesthit = 0;
514 longesthit = 0;
515 }
516 }
517
518 // recalculate the truncated means
519 double dedxmean, dedxtrunc, dedxtruncNoSat, dedxerror;
520
521 calculateMeans(&dedxmean, &dedxtruncNoSat, &dedxerror, newLayerHits);
522
523 dedxtrunc = dedxtruncNoSat;
524
525 HadronCorrection(m_cosTheta, dedxtrunc);
526 m_mean = dedxmean;
527 m_trunc = dedxtrunc;
528 m_truncNoSat = dedxtruncNoSat;
529 m_error = dedxerror;
530
531 // save the PID information
532 saveChiValue(cdcChi, dedxTrack, m_trunc);
533}
double getTimeMean() const
Return the injection gain for this track.
Definition: CDCDedxTrack.h:148
double getOneDCorrection(int i) const
Return the 1D correction for this hit.
Definition: CDCDedxTrack.h:263
void setDedx(double mean)
Set the dE/dx truncated average for this track.
Definition: CDCDedxTrack.h:157
double getCosineCorrection() const
Return the cosine correction for this track.
Definition: CDCDedxTrack.h:136
double getTwoDCorrection(int i) const
Return the 2D correction for this hit.
Definition: CDCDedxTrack.h:260
double getWireGain(int i) const
Return the wire gain for this hit.
Definition: CDCDedxTrack.h:257
double getCosEdgeCorrection() const
Return the cosine correction for this track.
Definition: CDCDedxTrack.h:139
double getRunGain() const
Return the run gain for this track.
Definition: CDCDedxTrack.h:142
double getScaleFactor() const
Return the scale factor for this track.
Definition: CDCDedxTrack.h:145
void saveChiValue(double(&chi)[Const::ChargedStable::c_SetSize], CDCDedxTrack *dedxTrack, double dedx) const
for all particles, save chi values into 'chi' chi array of chi values to be modified
void HadronCorrection(double costheta, double &dedx) const
Function to apply the hadron correction.
void calculateMeans(double *mean, double *truncatedMean, double *truncatedMeanErr, const std::vector< double > &dedx) const
Save arithmetic and truncated mean for the 'dedx' values.
double GetCorrection(int &adc, int layer, int wireID, double doca, double enta, double costheta, double ring, double time) const
Function to get the correction factor.

◆ saveChiValue()

void saveChiValue ( double(&)  chi[Const::ChargedStable::c_SetSize],
CDCDedxTrack dedxTrack,
double  dedx 
) const

for all particles, save chi values into 'chi' chi array of chi values to be modified

Definition at line 665 of file HitLevelInfoWriter.cc.

667{
668 // determine a chi value for each particle type
670 for (const Const::ChargedStable pdgIter : set) {
671
672 // determine the predicted mean and resolution
673 double mean = dedxTrack->getPmean(pdgIter.getIndex());
674 double sigma = dedxTrack->getPreso(pdgIter.getIndex());
675
676 // fill the chi value for this particle type
677 if (sigma != 0) chi[pdgIter.getIndex()] = ((dedx - mean) / (sigma));
678 }
679}
Provides a type-safe way to pass members of the chargedStableSet set.
Definition: Const.h:589
A set of ParticleType objects, with defined order.
Definition: Const.h:517
static const ParticleSet chargedStableSet
set of charged stable particles
Definition: Const.h:618

◆ setAbortLevel()

void setAbortLevel ( int  abortLevel)
inherited

Configure the abort log level.

Definition at line 67 of file Module.cc.

68{
69 m_logConfig.setAbortLevel(static_cast<LogConfig::ELogLevel>(abortLevel));
70}
ELogLevel
Definition of the supported log levels.
Definition: LogConfig.h:26
void setAbortLevel(ELogLevel abortLevel)
Configure the abort level.
Definition: LogConfig.h:112

◆ setDebugLevel()

void setDebugLevel ( int  debugLevel)
inherited

Configure the debug messaging level.

Definition at line 61 of file Module.cc.

62{
63 m_logConfig.setDebugLevel(debugLevel);
64}
void setDebugLevel(int debugLevel)
Configure the debug messaging level.
Definition: LogConfig.h:98

◆ setDescription()

void setDescription ( const std::string &  description)
protectedinherited

Sets the description of the module.

Parameters
descriptionA description of the module.

Definition at line 214 of file Module.cc.

215{
216 m_description = description;
217}

◆ setLogConfig()

void setLogConfig ( const LogConfig logConfig)
inlineinherited

Set the log system configuration.

Definition at line 230 of file Module.h.

230{m_logConfig = logConfig;}

◆ setLogInfo()

void setLogInfo ( int  logLevel,
unsigned int  logInfo 
)
inherited

Configure the printed log information for the given level.

Parameters
logLevelThe log level (one of LogConfig::ELogLevel)
logInfoWhat kind of info should be printed? ORed combination of LogConfig::ELogInfo flags.

Definition at line 73 of file Module.cc.

74{
75 m_logConfig.setLogInfo(static_cast<LogConfig::ELogLevel>(logLevel), logInfo);
76}
void setLogInfo(ELogLevel logLevel, unsigned int logInfo)
Configure the printed log information for the given level.
Definition: LogConfig.h:127

◆ setLogLevel()

void setLogLevel ( int  logLevel)
inherited

Configure the log level.

Definition at line 55 of file Module.cc.

56{
57 m_logConfig.setLogLevel(static_cast<LogConfig::ELogLevel>(logLevel));
58}
void setLogLevel(ELogLevel logLevel)
Configure the log level.
Definition: LogConfig.cc:25

◆ setName()

void setName ( const std::string &  name)
inlineinherited

Set the name of the module.

Note
The module name is set when using the REG_MODULE macro, but the module can be renamed before calling process() using the set_name() function in your steering file.
Parameters
nameThe name of the module

Definition at line 214 of file Module.h.

214{ m_name = name; };

◆ setParamList()

void setParamList ( const ModuleParamList params)
inlineprotectedinherited

Replace existing parameter list.

Definition at line 501 of file Module.h.

501{ m_moduleParamList = params; }

◆ setParamPython()

void setParamPython ( const std::string &  name,
const boost::python::object &  pyObj 
)
privateinherited

Implements a method for setting boost::python objects.

The method supports the following types: list, dict, int, double, string, bool The conversion of the python object to the C++ type and the final storage of the parameter value is done in the ModuleParam class.

Parameters
nameThe unique name of the parameter.
pyObjThe object which should be converted and stored as the parameter value.

Definition at line 234 of file Module.cc.

235{
236 LogSystem& logSystem = LogSystem::Instance();
237 logSystem.updateModule(&(getLogConfig()), getName());
238 try {
240 } catch (std::runtime_error& e) {
241 throw std::runtime_error("Cannot set parameter '" + name + "' for module '"
242 + m_name + "': " + e.what());
243 }
244
245 logSystem.updateModule(nullptr);
246}
Class for logging debug, info and error messages.
Definition: LogSystem.h:46
void updateModule(const LogConfig *moduleLogConfig=nullptr, const std::string &moduleName="")
Sets the log configuration to the given module log configuration and sets the module name This method...
Definition: LogSystem.h:191
static LogSystem & Instance()
Static method to get a reference to the LogSystem instance.
Definition: LogSystem.cc:31
void setParamPython(const std::string &name, const PythonObject &pyObj)
Implements a method for setting boost::python objects.

◆ setParamPythonDict()

void setParamPythonDict ( const boost::python::dict &  dictionary)
privateinherited

Implements a method for reading the parameter values from a boost::python dictionary.

The key of the dictionary has to be the name of the parameter and the value has to be of one of the supported parameter types.

Parameters
dictionaryThe python dictionary from which the parameter values are read.

Definition at line 249 of file Module.cc.

250{
251
252 LogSystem& logSystem = LogSystem::Instance();
253 logSystem.updateModule(&(getLogConfig()), getName());
254
255 boost::python::list dictKeys = dictionary.keys();
256 int nKey = boost::python::len(dictKeys);
257
258 //Loop over all keys in the dictionary
259 for (int iKey = 0; iKey < nKey; ++iKey) {
260 boost::python::object currKey = dictKeys[iKey];
261 boost::python::extract<std::string> keyProxy(currKey);
262
263 if (keyProxy.check()) {
264 const boost::python::object& currValue = dictionary[currKey];
265 setParamPython(keyProxy, currValue);
266 } else {
267 B2ERROR("Setting the module parameters from a python dictionary: invalid key in dictionary!");
268 }
269 }
270
271 logSystem.updateModule(nullptr);
272}
void setParamPython(const std::string &name, const boost::python::object &pyObj)
Implements a method for setting boost::python objects.
Definition: Module.cc:234

◆ setPropertyFlags()

void setPropertyFlags ( unsigned int  propertyFlags)
inherited

Sets the flags for the module properties.

Parameters
propertyFlagsbitwise OR of EModulePropFlags

Definition at line 208 of file Module.cc.

209{
210 m_propertyFlags = propertyFlags;
211}

◆ setReturnValue() [1/2]

void setReturnValue ( bool  value)
protectedinherited

Sets the return value for this module as bool.

The bool value is saved as an integer with the convention 1 meaning true and 0 meaning false. The value can be used in the steering file to divide the analysis chain into several paths.

Parameters
valueThe value of the return value.

Definition at line 227 of file Module.cc.

228{
229 m_hasReturnValue = true;
230 m_returnValue = value;
231}

◆ setReturnValue() [2/2]

void setReturnValue ( int  value)
protectedinherited

Sets the return value for this module as integer.

The value can be used in the steering file to divide the analysis chain into several paths.

Parameters
valueThe value of the return value.

Definition at line 220 of file Module.cc.

221{
222 m_hasReturnValue = true;
223 m_returnValue = value;
224}

◆ setType()

void setType ( const std::string &  type)
protectedinherited

Set the module type.

Only for use by internal modules (which don't use the normal REG_MODULE mechanism).

Definition at line 48 of file Module.cc.

49{
50 if (!m_type.empty())
51 B2FATAL("Trying to change module type from " << m_type << " is not allowed, the value is assumed to be fixed.");
52 m_type = type;
53}

◆ terminate()

void terminate ( void  )
overridevirtual

End of the event processing.

Reimplemented from Module.

Definition at line 244 of file HitLevelInfoWriter.cc.

245{
246
247 for (unsigned int i = 0; i < m_file.size(); i++) {
248 B2INFO("Done writing out the hit level information...\t" << m_tree[i]->GetEntries() << " tracks");
249
250 // write the ttree to a root file
251 m_file[i]->cd();
252 m_tree[i]->Write();
253 m_file[i]->Close();
254 }
255}

Member Data Documentation

◆ h_adccorr

double h_adccorr[kMaxHits] = {}
private

charge per hit corr by nonlinear ADC

Definition at line 261 of file HitLevelInfoWriter.h.

◆ h_adcraw

double h_adcraw[kMaxHits] = {}
private

charge per hit

Definition at line 260 of file HitLevelInfoWriter.h.

◆ h_dedx

double h_dedx[kMaxHits] = {}
private

charge per path length

Definition at line 259 of file HitLevelInfoWriter.h.

◆ h_doca

double h_doca[kMaxHits] = {}
private

distance of closest approach

Definition at line 262 of file HitLevelInfoWriter.h.

◆ h_driftD

double h_driftD[kMaxHits] = {}
private

drift distance

Definition at line 268 of file HitLevelInfoWriter.h.

◆ h_driftT

double h_driftT[kMaxHits] = {}
private

drift time

Definition at line 267 of file HitLevelInfoWriter.h.

◆ h_enta

double h_enta[kMaxHits] = {}
private

entrance angle

Definition at line 265 of file HitLevelInfoWriter.h.

◆ h_entaRS

double h_entaRS[kMaxHits] = {}
private

normalized + RS distance of entrance angle

Definition at line 266 of file HitLevelInfoWriter.h.

◆ h_facnladc

double h_facnladc[kMaxHits] = {}
private

calibration hit gain

Definition at line 269 of file HitLevelInfoWriter.h.

◆ h_foundByTrackFinder

int h_foundByTrackFinder[kMaxHits] = {}
private

the 'found by track finder' flag for the given hit

Definition at line 278 of file HitLevelInfoWriter.h.

◆ h_layer

int h_layer[kMaxHits] = {}
private

layer number

Definition at line 256 of file HitLevelInfoWriter.h.

◆ h_lwire

int h_lwire[kMaxHits] = {}
private

sense wire within layer

Definition at line 254 of file HitLevelInfoWriter.h.

◆ h_ndoca

double h_ndoca[kMaxHits] = {}
private

normalized distance of closest approach

Definition at line 263 of file HitLevelInfoWriter.h.

◆ h_ndocaRS

double h_ndocaRS[kMaxHits] = {}
private

normalized +RS distance of closest approach

Definition at line 264 of file HitLevelInfoWriter.h.

◆ h_nhits

int h_nhits { -1}
private

the number of good hits for this Track

Definition at line 253 of file HitLevelInfoWriter.h.

◆ h_onedCor

double h_onedCor[kMaxHits] = {}
private

calibration 1D cleanup correction

Definition at line 272 of file HitLevelInfoWriter.h.

◆ h_path

double h_path[kMaxHits] = {}
private

path length in cell

Definition at line 258 of file HitLevelInfoWriter.h.

◆ h_twodCor

double h_twodCor[kMaxHits] = {}
private

calibration 2D correction

Definition at line 271 of file HitLevelInfoWriter.h.

◆ h_WeightKaonHypo

double h_WeightKaonHypo[kMaxHits] = {}
private

weight for kaon hypothesis from KalmanFitterInfo

Definition at line 276 of file HitLevelInfoWriter.h.

◆ h_WeightPionHypo

double h_WeightPionHypo[kMaxHits] = {}
private

weight for pion hypothesis from KalmanFitterInfo

Definition at line 275 of file HitLevelInfoWriter.h.

◆ h_WeightProtonHypo

double h_WeightProtonHypo[kMaxHits] = {}
private

weight for proton hypothesis from KalmanFitterInfo

Definition at line 277 of file HitLevelInfoWriter.h.

◆ h_wire

int h_wire[kMaxHits] = {}
private

sense wire ID

Definition at line 255 of file HitLevelInfoWriter.h.

◆ h_wireGain

double h_wireGain[kMaxHits] = {}
private

calibration hit gain

Definition at line 270 of file HitLevelInfoWriter.h.

◆ kMaxHits

const int kMaxHits = 200
staticprivate

default hit level index

Definition at line 242 of file HitLevelInfoWriter.h.

◆ l_dedx

double l_dedx[kMaxHits] = {}
private

dE/dx for this layer

Definition at line 250 of file HitLevelInfoWriter.h.

◆ l_layer

int l_layer[kMaxHits] = {}
private

layer number

Definition at line 248 of file HitLevelInfoWriter.h.

◆ l_nhits

int l_nhits { -1}
private

the total number of layer hits for this Track

Definition at line 244 of file HitLevelInfoWriter.h.

◆ l_nhitscombined

int l_nhitscombined[kMaxHits] = {}
private

the number of hits combined this layer

Definition at line 246 of file HitLevelInfoWriter.h.

◆ l_nhitsused

int l_nhitsused { -1}
private

the total number of layer hits used for this Track

Definition at line 245 of file HitLevelInfoWriter.h.

◆ l_path

double l_path[kMaxHits] = {}
private

distance travelled in this layer

Definition at line 249 of file HitLevelInfoWriter.h.

◆ l_wirelongesthit

int l_wirelongesthit[kMaxHits] = {}
private

the wire number of longest hit in this layer

Definition at line 247 of file HitLevelInfoWriter.h.

◆ m_charge

int m_charge {0}
private

the charge for this Track

Definition at line 176 of file HitLevelInfoWriter.h.

◆ m_chi2

double m_chi2 { -1.}
private

chi^2 from track fit

Definition at line 170 of file HitLevelInfoWriter.h.

◆ m_chid

double m_chid { -1.}
private

modified chi value for deuteron hypothesis

Definition at line 226 of file HitLevelInfoWriter.h.

◆ m_chidOld

double m_chidOld { -1.}
private

chi value for deuteron hypothesis

Definition at line 219 of file HitLevelInfoWriter.h.

◆ m_chie

double m_chie { -1.}
private

modified chi value for electron hypothesis

Definition at line 221 of file HitLevelInfoWriter.h.

◆ m_chieOld

double m_chieOld { -1.}
private

chi value for electron hypothesis

Definition at line 214 of file HitLevelInfoWriter.h.

◆ m_chik

double m_chik { -1.}
private

modified chi value for kaon hypothesis

Definition at line 224 of file HitLevelInfoWriter.h.

◆ m_chikOld

double m_chikOld { -1.}
private

chi value for kaon hypothesis

Definition at line 217 of file HitLevelInfoWriter.h.

◆ m_chimu

double m_chimu { -1.}
private

modified chi value for muon hypothesis

Definition at line 222 of file HitLevelInfoWriter.h.

◆ m_chimuOld

double m_chimuOld { -1.}
private

chi value for muon hypothesis

Definition at line 215 of file HitLevelInfoWriter.h.

◆ m_chip

double m_chip { -1.}
private

modified chi value for proton hypothesis

Definition at line 225 of file HitLevelInfoWriter.h.

◆ m_chipi

double m_chipi { -1.}
private

modified chi value for pion hypothesis

Definition at line 223 of file HitLevelInfoWriter.h.

◆ m_chipiOld

double m_chipiOld { -1.}
private

chi value for pion hypothesis

Definition at line 216 of file HitLevelInfoWriter.h.

◆ m_chipOld

double m_chipOld { -1.}
private

chi value for proton hypothesis

Definition at line 218 of file HitLevelInfoWriter.h.

◆ m_conditions

std::vector<ModuleCondition> m_conditions
privateinherited

Module condition, only non-null if set.

Definition at line 521 of file Module.h.

◆ m_cosCor

double m_cosCor { -1.}
private

calibration cosine correction

Definition at line 207 of file HitLevelInfoWriter.h.

◆ m_cosEdgeCor

double m_cosEdgeCor { -1.}
private

calibration cosine edge correction

Definition at line 208 of file HitLevelInfoWriter.h.

◆ m_cosTheta

double m_cosTheta { -2.}
private

cos(theta) for the track

Definition at line 177 of file HitLevelInfoWriter.h.

◆ m_d0

double m_d0 {0.}
private

Signed distance to the POCA in the r-phi plane.

Definition at line 160 of file HitLevelInfoWriter.h.

◆ m_DB1DCell

DBObjPtr<CDCDedx1DCell> m_DB1DCell
private

1D correction DB object

Definition at line 287 of file HitLevelInfoWriter.h.

◆ m_DB2DCell

DBObjPtr<CDCDedx2DCell> m_DB2DCell
private

2D correction DB object

Definition at line 286 of file HitLevelInfoWriter.h.

◆ m_DBCosEdgeCor

DBObjPtr<CDCDedxCosineEdge> m_DBCosEdgeCor
private

cosine edge calibration

Definition at line 289 of file HitLevelInfoWriter.h.

◆ m_DBCosineCor

DBObjPtr<CDCDedxCosineCor> m_DBCosineCor
private

Electron saturation correction DB object.

Definition at line 285 of file HitLevelInfoWriter.h.

◆ m_DBHadronCor

DBObjPtr<CDCDedxHadronCor> m_DBHadronCor
private

hadron saturation parameters

Definition at line 290 of file HitLevelInfoWriter.h.

◆ m_DBInjectTime

DBObjPtr<CDCDedxInjectionTime> m_DBInjectTime
private

time gain/reso DB object

Definition at line 284 of file HitLevelInfoWriter.h.

◆ m_DBNonlADC

DBObjPtr<CDCDedxADCNonLinearity> m_DBNonlADC
private

hadron saturation non linearity

Definition at line 288 of file HitLevelInfoWriter.h.

◆ m_DBRunGain

DBObjPtr<CDCDedxRunGain> m_DBRunGain
private

Run gain DB object.

Definition at line 283 of file HitLevelInfoWriter.h.

◆ m_DBScaleFactor

DBObjPtr<CDCDedxScaleFactor> m_DBScaleFactor
private

Scale factor to make electrons ~1.

Definition at line 281 of file HitLevelInfoWriter.h.

◆ m_DBWireGains

DBObjPtr<CDCDedxWireGain> m_DBWireGains
private

Wire gain DB object.

Definition at line 282 of file HitLevelInfoWriter.h.

◆ m_dedxTracks

StoreArray<CDCDedxTrack> m_dedxTracks
private

Required array of CDCDedxTracks.

Definition at line 135 of file HitLevelInfoWriter.h.

◆ m_description

std::string m_description
privateinherited

The description of the module.

Definition at line 511 of file Module.h.

◆ m_dphi

double m_dphi { -1.}
private

POCA in degrees in respect to IP.

Definition at line 164 of file HitLevelInfoWriter.h.

◆ m_dr

double m_dr { -1.}
private

track d0 relative to IP

Definition at line 163 of file HitLevelInfoWriter.h.

◆ m_dz

double m_dz { -1.}
private

vertex or POCA in case of tracks z in respect to IPs

Definition at line 162 of file HitLevelInfoWriter.h.

◆ m_e

double m_e { -1.}
private

energy in the calorimeter

Definition at line 199 of file HitLevelInfoWriter.h.

◆ m_e1_9

double m_e1_9 { -1.}
private

ratio of energies of the central 1 crystal vs 3x3 crystals

Definition at line 200 of file HitLevelInfoWriter.h.

◆ m_e9_21

double m_e9_21 { -1.}
private

ratio of energies of the central 3x3 crystal vs 5x5 crystals

Definition at line 201 of file HitLevelInfoWriter.h.

◆ m_eclClusters

StoreArray<ECLCluster> m_eclClusters
private

Required array of input ECLClusters.

Definition at line 138 of file HitLevelInfoWriter.h.

◆ m_eclsnHits

double m_eclsnHits { -1.}
private

of clusters

Definition at line 203 of file HitLevelInfoWriter.h.

◆ m_eop

double m_eop { -1.}
private

energy over momentum in the calorimeter

Definition at line 198 of file HitLevelInfoWriter.h.

◆ m_error

double m_error { -1.}
private

standard deviation of the truncated mean

Definition at line 195 of file HitLevelInfoWriter.h.

◆ m_eventID

int m_eventID { -1}
private

event in which this Track was found

Definition at line 154 of file HitLevelInfoWriter.h.

◆ m_expID

int m_expID { -1}
private

experiment in which this Track was found

Definition at line 152 of file HitLevelInfoWriter.h.

◆ m_file

std::vector<TFile* > m_file
private

output ROOT files

Definition at line 132 of file HitLevelInfoWriter.h.

◆ m_filename

std::vector<std::string> m_filename
private

full names of the output ROOT files

Definition at line 131 of file HitLevelInfoWriter.h.

◆ m_hadronpars

std::vector<double> m_hadronpars
private

hadron saturation parameters

Definition at line 292 of file HitLevelInfoWriter.h.

◆ m_hasReturnValue

bool m_hasReturnValue
privateinherited

True, if the return value is set.

Definition at line 518 of file Module.h.

◆ m_inCDC

int m_inCDC { -1}
private

frack is CDC acceptance or not

Definition at line 173 of file HitLevelInfoWriter.h.

◆ m_injring

double m_injring { -1.0}
private

HER injection status.

Definition at line 156 of file HitLevelInfoWriter.h.

◆ m_injtime

double m_injtime { -1.0}
private

time since last injection in micro seconds

Definition at line 157 of file HitLevelInfoWriter.h.

◆ m_ioasym

double m_ioasym { -1.}
private

asymmetry in increasing vs decreasing layer numbers per track

Definition at line 182 of file HitLevelInfoWriter.h.

◆ m_isCorrection

bool m_isCorrection
private

Flag to switch on/off corrections.

Definition at line 299 of file HitLevelInfoWriter.h.

◆ m_isDeadwire

bool m_isDeadwire
private

write only active wires

Definition at line 294 of file HitLevelInfoWriter.h.

◆ m_isExtraVar

bool m_isExtraVar
private

Flag to switch on/off extra level info and some available w/ release/5 only.

Definition at line 297 of file HitLevelInfoWriter.h.

◆ m_isHitLevel

bool m_isHitLevel
private

Flag to switch on/off hit level info.

Definition at line 296 of file HitLevelInfoWriter.h.

◆ m_isRelative

bool m_isRelative
private

Flag to switch on/off relative constants.

Definition at line 298 of file HitLevelInfoWriter.h.

◆ m_klmClusters

StoreArray<KLMCluster> m_klmClusters
private

Required array of input KLMClusters.

Definition at line 139 of file HitLevelInfoWriter.h.

◆ m_klmLayers

double m_klmLayers { -1.}
private

number of klm layers with hits

Definition at line 202 of file HitLevelInfoWriter.h.

◆ m_length

double m_length { -1.}
private

total path length of the Track

Definition at line 175 of file HitLevelInfoWriter.h.

◆ m_logConfig

LogConfig m_logConfig
privateinherited

The log system configuration of the module.

Definition at line 514 of file Module.h.

◆ m_mean

double m_mean { -1.}
private

dE/dx averaged

Definition at line 192 of file HitLevelInfoWriter.h.

◆ m_moduleParamList

ModuleParamList m_moduleParamList
privateinherited

List storing and managing all parameter of the module.

Definition at line 516 of file Module.h.

◆ m_name

std::string m_name
privateinherited

The name of the module, saved as a string (user-modifiable)

Definition at line 508 of file Module.h.

◆ m_nCDChits

double m_nCDChits { -1.}
private

Number of CDC hits associated to the track.

Definition at line 172 of file HitLevelInfoWriter.h.

◆ m_p

double m_p { -1.}
private

momentum from tracking

Definition at line 179 of file HitLevelInfoWriter.h.

◆ m_package

std::string m_package
privateinherited

Package this module is found in (may be empty).

Definition at line 510 of file Module.h.

◆ m_pCDC

double m_pCDC { -1.}
private

momentum valid in CDC

Definition at line 178 of file HitLevelInfoWriter.h.

◆ m_PDG

double m_PDG { -1.}
private

MC PID.

Definition at line 186 of file HitLevelInfoWriter.h.

◆ m_phi

double m_phi { -1.}
private

phi for the track

Definition at line 181 of file HitLevelInfoWriter.h.

◆ m_phi0

double m_phi0 { -1.}
private

Angle of the transverse momentum in the r-phi plane.

Definition at line 169 of file HitLevelInfoWriter.h.

◆ m_pmeand

double m_pmeand { -1.}
private

pred mean for deuteron hypothesis

Definition at line 240 of file HitLevelInfoWriter.h.

◆ m_pmeane

double m_pmeane { -1.}
private

pred mean for electron hypothesis

Definition at line 235 of file HitLevelInfoWriter.h.

◆ m_pmeank

double m_pmeank { -1.}
private

pred mean for kaon hypothesis

Definition at line 238 of file HitLevelInfoWriter.h.

◆ m_pmeanmu

double m_pmeanmu { -1.}
private

pred mean for muon hypothesis

Definition at line 236 of file HitLevelInfoWriter.h.

◆ m_pmeanp

double m_pmeanp { -1.}
private

pred mean for proton hypothesis

Definition at line 239 of file HitLevelInfoWriter.h.

◆ m_pmeanpi

double m_pmeanpi { -1.}
private

pred mean for pion hypothesis

Definition at line 237 of file HitLevelInfoWriter.h.

◆ m_presd

double m_presd { -1.}
private

pred reso for deuteron hypothesis

Definition at line 233 of file HitLevelInfoWriter.h.

◆ m_prese

double m_prese { -1.}
private

pred reso for electron hypothesis

Definition at line 228 of file HitLevelInfoWriter.h.

◆ m_presk

double m_presk { -1.}
private

pred reso for kaon hypothesis

Definition at line 231 of file HitLevelInfoWriter.h.

◆ m_presmu

double m_presmu { -1.}
private

pred reso for muon hypothesis

Definition at line 229 of file HitLevelInfoWriter.h.

◆ m_presp

double m_presp { -1.}
private

pred reso for proton hypothesis

Definition at line 232 of file HitLevelInfoWriter.h.

◆ m_prespi

double m_prespi { -1.}
private

pred reso for pion hypothesis

Definition at line 230 of file HitLevelInfoWriter.h.

◆ m_propertyFlags

unsigned int m_propertyFlags
privateinherited

The properties of the module as bitwise or (with |) of EModulePropFlags.

Definition at line 512 of file Module.h.

◆ m_pt

double m_pt { -1.}
private

transverse momentum from tracking

Definition at line 180 of file HitLevelInfoWriter.h.

◆ m_returnValue

int m_returnValue
privateinherited

The return value.

Definition at line 519 of file Module.h.

◆ m_runGain

double m_runGain { -1.}
private

calibration run gain

Definition at line 209 of file HitLevelInfoWriter.h.

◆ m_runID

int m_runID { -1}
private

run in which this Track was found

Definition at line 153 of file HitLevelInfoWriter.h.

◆ m_scale

double m_scale { -1.}
private

calibration scale factor

Definition at line 206 of file HitLevelInfoWriter.h.

◆ m_strOutputBaseName

std::string m_strOutputBaseName
private

Base name for the output ROOT files.

Definition at line 129 of file HitLevelInfoWriter.h.

◆ m_strParticleList

std::vector<std::string> m_strParticleList
private

Vector of ParticleLists to write out.

Definition at line 130 of file HitLevelInfoWriter.h.

◆ m_tanlambda

double m_tanlambda { -1.}
private

Slope of the track in the r-z plane.

Definition at line 168 of file HitLevelInfoWriter.h.

◆ m_theta

double m_theta { -2.}
private

cos(theta) for the track

Definition at line 183 of file HitLevelInfoWriter.h.

◆ m_timeGain

double m_timeGain { -1.}
private

calibration injection time gain

Definition at line 210 of file HitLevelInfoWriter.h.

◆ m_timeReso

double m_timeReso { -1.}
private

calibration injection time reso

Definition at line 211 of file HitLevelInfoWriter.h.

◆ m_trackFitResults

StoreArray<TrackFitResult> m_trackFitResults
private

Required array of input TrackFitResults.

Definition at line 137 of file HitLevelInfoWriter.h.

◆ m_trackID

int m_trackID { -1}
private

ID number of the Track.

Definition at line 174 of file HitLevelInfoWriter.h.

◆ m_tracks

StoreArray<Track> m_tracks
private

Required array of input Tracks.

Definition at line 136 of file HitLevelInfoWriter.h.

◆ m_tree

std::vector<TTree* > m_tree
private

output ROOT trees

Definition at line 133 of file HitLevelInfoWriter.h.

◆ m_trunc

double m_trunc { -1.}
private

dE/dx averaged, truncated mean, with corrections

Definition at line 193 of file HitLevelInfoWriter.h.

◆ m_truncNoSat

double m_truncNoSat { -1.}
private

dE/dx averaged, truncated mean, with corrections (not hadron)

Definition at line 194 of file HitLevelInfoWriter.h.

◆ m_TTDInfo

Store Object Ptr: EventLevelTriggerTimeInfo.

Definition at line 140 of file HitLevelInfoWriter.h.

◆ m_type

std::string m_type
privateinherited

The type of the module, saved as a string.

Definition at line 509 of file Module.h.

◆ m_vx0

double m_vx0 {0.}
private

X coordinate of track POCA to origin.

Definition at line 165 of file HitLevelInfoWriter.h.

◆ m_vy0

double m_vy0 {0.}
private

Y coordinate of track POCA to origin.

Definition at line 166 of file HitLevelInfoWriter.h.

◆ m_vz0

double m_vz0 {0.}
private

Z coordinate of track POCA to origin.

Definition at line 167 of file HitLevelInfoWriter.h.

◆ m_z0

double m_z0 {0.}
private

z coordinate of the POCA

Definition at line 161 of file HitLevelInfoWriter.h.


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