10 #include <arich/modules/arichFillHits/ARICHFillHitsModule.h>
13 #include <framework/datastore/StoreArray.h>
14 #include <framework/datastore/StoreObjPtr.h>
15 #include <framework/dataobjects/EventMetaData.h>
17 #include <framework/logging/Logger.h>
20 #include <arich/dataobjects/ARICHDigit.h>
21 #include <arich/dataobjects/ARICHHit.h>
23 #include <framework/geometry/BFieldManager.h>
47 addParam(
"maxApdHits",
m_maxApdHits,
"Remove hits with more than MaxApdHits per APD chip", (uint8_t)18);
48 addParam(
"maxHapdHits",
m_maxHapdHits,
"Remove hits with more than MaxHapdHits per HAPD", (uint8_t)100);
49 addParam(
"MagFieldCorrection",
m_bcorrect,
"Apply hit position correction due to non-perp. mag. field", 0);
50 addParam(
"fillAll",
m_fillall,
"Make hits for all active channels (useful for likelihood PDF studies)", 0);
64 arichHits.registerInDataStore();
66 arichHits.registerRelationTo(digits);
77 std::vector<uint8_t> apdHits(420 * 4, 0);
78 std::vector<uint8_t> hapdHits(420, 0);
79 for (
const auto& digit : digits) {
80 uint8_t bits = digit.getBitmap();
83 int moduleID = digit.getModuleID();
84 if (moduleID > 420 || moduleID < 1)
continue;
86 int channelID = digit.getChannelID();
87 if (channelID > 143 || channelID < 0)
continue;
88 int chipID = moduleID * 4 + channelID / 36;
94 for (
const auto& digit : digits) {
95 int asicCh = digit.getChannelID();
96 int modID = digit.getModuleID();
97 if (modID > 420 || modID < 1)
continue;
98 if (asicCh > 143 || asicCh < 0)
continue;
99 uint8_t hitBitmap = digit.getBitmap();
103 if (!
m_chnMask->isActive(modID, asicCh))
continue;
105 int chipID = (modID - 1) * 4 + asicCh / 36;
112 if (not
m_chnMap->getXYFromAsic(asicCh, xCh, yCh)) {
113 B2ERROR(
"Invalid ARICH hit! This hit will be ignored.");
117 TVector2 hitpos2D =
m_geoPar->getChannelPosition(modID, xCh, yCh);
118 TVector3 hitpos3D(hitpos2D.X(), hitpos2D.Y(),
m_geoPar->getDetectorZPosition() +
m_geoPar->getHAPDGeometry().getWinThickness());
119 hitpos3D =
m_geoPar->getMasterVolume().pointToGlobal(hitpos3D);
122 ARICHHit* hh = arichHits.appendNew(hitpos3D, modID, asicCh);
126 for (
int imod = 1; imod < 421; imod++) {
127 for (
int ichn = 0; ichn < 144; ichn++) {
130 if (!
m_chnMask->isActive(imod, ichn))
continue;
131 int chipID = (imod - 1) * 4 + ichn / 36;
137 if (not
m_chnMap->getXYFromAsic(ichn, xCh, yCh)) {
138 B2ERROR(
"Invalid ARICH hit! This hit will be ignored.");
142 TVector2 hitpos2D =
m_geoPar->getChannelPosition(imod, xCh, yCh);
143 TVector3 hitpos3D(hitpos2D.X(), hitpos2D.Y(),
m_geoPar->getDetectorZPosition() +
m_geoPar->getHAPDGeometry().getWinThickness());
144 hitpos3D =
m_geoPar->getMasterVolume().pointToGlobal(hitpos3D);
146 arichHits.appendNew(hitpos3D, imod, ichn);
156 ROOT::Math::XYZVector shift =
m_geoPar->getHAPDGeometry().getPhotocathodeApdDistance() / abs(Bfield.Z()) * Bfield;
157 hitpos.SetX(hitpos.X() - shift.X());
158 hitpos.SetY(hitpos.Y() - shift.Y());
int m_fillall
make hit for all active channels (usefull for likelihood PDF studies)
uint8_t m_maxApdHits
reject hits with more than number of hits in Apd
uint8_t m_bitMask
hit bit mask (only convert digits with hit in bitmask bits)
DBObjPtr< ARICHGeometryConfig > m_geoPar
geometry configuration parameters from the DB
int m_bcorrect
apply hit position correction for the non-perp.
DBObjPtr< ARICHChannelMapping > m_chnMap
(x,y) to asic channel mapping
uint8_t m_maxHapdHits
reject hits with more than number of hits in Hapd
DBObjPtr< ARICHChannelMask > m_chnMask
list of dead channels from the DB
Datastore class that holds photon hits. Input to the reconstruction.
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...
void addRelationTo(const RelationsInterface< BASE > *object, float weight=1.0, const std::string &namedRelation="") const
Add a relation from this object to another object (with caching).
Accessor to arrays stored in the data store.
Type-safe access to single objects in the data store.
virtual void initialize() override
Initialize the Module.
virtual void event() override
Event processor.
void magFieldCorrection(TVector3 &hitpos)
Corrects hit position for distorsion due to non-perpendicular magnetic field component.
virtual ~ARICHFillHitsModule()
Destructor.
ARICHFillHitsModule()
Constructor.
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.
static void getField(const double *pos, double *field)
return the magnetic field at a given position.
Abstract base class for different kinds of events.