9 #include <tracking/modules/pxdDataReduction/PXDROIFinderModule.h>
10 #include <framework/datastore/StoreArray.h>
11 #include <framework/datastore/RelationArray.h>
12 #include <genfit/MaterialEffects.h>
28 setDescription(
"This module performs the reduction of the PXD data output");
39 "Tolerance by finding sensor in phi coordinate (radians). Will only be used if overrideDBROICalculation is set to True.",
42 "Tolerance by finding sensor in Z coordinate (cm). Will only be used if overrideDBROICalculation is set to True.",
45 "Systematic sigma in the u local coordinate. Will only be used if overrideDBROICalculation is set to True.",
48 "Systematic sigma in the V local coordinate. Will only be used if overrideDBROICalculation is set to True.",
51 "Number of sigmas (total) in the U local coordinate. Will only be used if overrideDBROICalculation is set to True.",
54 "Number of sigmas (total) in the V local coordinate. Will only be used if overrideDBROICalculation is set to True.",
57 "Upper limit on width of the ROI in the U local coordinate (cm). Will only be used if overrideDBROICalculation is set to True.",
60 "Upper limit on width of the ROI in the V local coordinate (cm). Will only be used if overrideDBROICalculation is set to True.",
63 "Override the parameters from DB for testing or debugging. Required to be True to use the other ROI calculation parameters.",
77 if (!genfit::MaterialEffects::getInstance()->isInitialized()) {
78 B2FATAL(
"Material effects not set up. Please use SetupGenfitExtrapolationModule.");
87 B2WARNING(
"ROI calculation parameters from DB are valid, but they are overridden by the module parameters.\n"
88 " --> Using module parameters instead of parameters from DB.");
101 B2FATAL(
"No ROI configuration for the current run found (missing ROICalculationParameters payload).");
104 B2DEBUG(29,
"||| PXDROIFinder Parameters:");
136 recoTrackToPXDIntercepts.
create();
139 PXDInterceptsToROIids.
create();
@ c_ErrorIfAlreadyRegistered
If the object/array was already registered, produce an error (aborting initialisation).
void setDescription(const std::string &description)
Sets the description of the module.
void setPropertyFlags(unsigned int propertyFlags)
Sets the flags for the module properties.
@ c_ParallelProcessingCertified
This module can be run in parallel processing mode safely (All I/O must be done through the data stor...
The PXDInterceptor class fills a StoreArray of PXDIntercepts that will be used to define the PXD ROIs...
void fillInterceptList(StoreArray< PXDIntercept > *listToBeFilled, const StoreArray< RecoTrack > &trackList, RelationArray *recoTrackToPXDIntercepts)
Fill the list of PXD intecepts corresponding to the list of track candidates.
double m_maxWidthV
maximum V width of the ROI
bool m_overrideDBROICalculation
Override DB parameters for ROI calculation for debugging and testing.
std::string m_recoTracksListName
track list name
std::string m_ROIListName
ROI list name.
ROIPixelTranslator * m_thePixelTranslator
the pixel translator object
void initialize() override
Initializes the module.
std::string m_PXDInterceptListName
intercept list name
double m_maxWidthU
maximum U width of the ROI
void event() override
This method is called for each event.
void endRun() override
This method is called at the end of the event processing.
double m_tolerancePhi
tolerance for finding sensor in phi coordinate (radians)
PXDROIFinderModule()
Constructor of the module.
double m_sigmaSystV
fixed width to add in quadrature to the extrapolation error and obtain the ROI V width
double m_numSigmaTotV
number of sigma (stat+syst) determining the U width of the ROI
void beginRun() override
Called when entering a new run.
DBObjPtr< ROICalculationParameters > m_ROICalculationParameters
Configuration parameters for ROIs.
double m_sigmaSystU
fixed width to add in quadrature to the extrapolation error and obtain the ROI U width
StoreArray< PXDIntercept > m_PXDIntercepts
PXDIntercepts StoreArray.
ROIinfo m_ROIinfo
contains the parameters that can be changed by the user
double m_numSigmaTotU
number of sigma (stat+syst) determining the U width of the ROI
StoreArray< RecoTrack > m_RecoTracks
RecoTracks StoreArray.
double m_toleranceZ
tolerance for finding sensor in Z coordinate (cm)
PXDInterceptor * m_thePXDInterceptor
the pxd interceptor object
StoreArray< ROIid > m_ROIs
ROIs StoreArray.
Translator for ROI-geometry-information into a list of pixels.
void fillRoiIDList(StoreArray< PXDIntercept > *listOfIntercepts, StoreArray< ROIid > *ROIidList)
Append the ROIid to the list listToBeFilled.
Low-level class to create/modify relations between StoreArrays.
bool create(bool replace=false)
Create an empty relation array in the data store.
bool isOptional(const std::string &name="")
Tell the DataStore about an optional input.
int getEntries() const
Get the number of objects in the array.
bool registerRelationTo(const StoreArray< TO > &toArray, DataStore::EDurability durability=DataStore::c_Event, DataStore::EStoreFlags storeFlags=DataStore::c_WriteOut, const std::string &namedRelation="") const
Register a relation to the given StoreArray.
REG_MODULE(arichBtest)
Register the Module.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
Abstract base class for different kinds of events.
double sigmaSystV
fixed width to add in quadrature to the extrapolation error and obtain the ROI V width
double numSigmaTotU
number of sigma (stat+syst) determining the U width of the ROI
double maxWidthU
maximum U width of the ROI
std::string PXDInterceptListName
Intercept list name.
double sigmaSystU
fixed width to add in quadrature to the extrapolation error and obtain the ROI U width
std::string recoTracksListName
track list name
double numSigmaTotV
number of sigma (stat+syst) determining the U width of the ROI
std::string ROIListName
ROI list name.
double maxWidthV
maximum U width of the ROI