9 #include <tracking/modules/pxdDataReduction/PXDdigiFilterModule.h> 
   26   setDescription(
"The module produce a StoreArray of PXDDigit inside the ROIs. A second StoreArray with PXDDigits outside the ROI can be created on demand.");
 
   30   addParam(
"PXDDigitsName", 
m_PXDDigitsName, 
"The name of the StoreArray of PXDDigits to be filtered", std::string(
""));
 
   32            std::string(
"PXDDigitsIN"));
 
   34            std::string(
"PXDDigitsOUT"));
 
   38   addParam(
"overrideDB", 
m_overrideDB, 
"If set, ROI-filtering settings in DB are overwritten", 
false);
 
   71     B2ERROR(
"No configuration for the current run found");
 
   83       B2ERROR(
"No configuration for the current run found");
 
  114   std::multimap< VxdID, ROIid > ROIids;
 
  117     ROIids.insert(std::pair<VxdID, ROIid> (ROI.getSensorID(), ROI));
 
  120     auto ROIidsRange = ROIids.equal_range(thePxdDigit->
getSensorID()) ;
 
  121     for (
auto theROI = ROIidsRange.first ; theROI != ROIidsRange.second; theROI ++)
 
  122       if (theROI->second.Contains(*thePxdDigit))
 
  130       auto ROIidsRange = ROIids.equal_range(thePxdDigit->
getSensorID()) ;
 
  131       for (
auto theROI = ROIidsRange.first ; theROI != ROIidsRange.second; theROI ++)
 
  132         if (theROI->second.Contains(*thePxdDigit))
 
@ c_WriteOut
Object/array should be saved by output modules.
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...
VxdID getSensorID() const
Get the sensor ID.
void initialize() override final
Initializer.
bool m_overrideDB
if set, overwrites ROI-finding settings in DB
int m_countNthEvent
Event counter to be able to disable data reduction for every Nth event.
int m_skipEveryNth
Parameter from DB for how many events to skip data reduction.
void copyDigits()
all the actual work is done here
DBObjPtr< ROISimulationParameters > m_ROISimulationParameters
Configuration parameters for ROIs.
SelectSubset< PXDDigit > m_selectorIN
selector of the subset of PXDDigits contained in the ROIs
bool m_usePXDDataReduction
enables/disables ROI-finding if overwriteDB=True
void event() override final
This method is called for each event.
std::string m_PXDDigitsOutsideROIName
The name of the StoreArray of Filtered PXDDigits.
std::string m_ROIidsName
The name of the StoreArray of ROIs.
StoreArray< PXDDigit > m_PXDDigits
StoreArray containing the input PXDDigits.
void beginRun() override final
Called when entering a new run.
std::string m_PXDDigitsName
The name of the StoreArray of PXDDigits to be filtered.
void filterDigits()
all the actual work is done here
PXDdigiFilterModule()
Constructor: Sets the description, the properties and the parameters of the module.
bool m_CreateOutside
if set, create list of outside pixels, too
std::string m_PXDDigitsInsideROIName
The name of the StoreArray of Filtered PXDDigits.
SelectSubset< PXDDigit > m_selectorOUT
selector of the subset of PXDDigits NOT contained in the ROIs
StoreArray< ROIid > m_ROIs
StoreArray containing the ROIs.
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.