9 #include <pxd/modules/pxdDQM/PXDRawDQMModule.h> 
   10 #include <vxd/geometry/GeoCache.h> 
   12 #include <TDirectory.h> 
   13 #include <boost/format.hpp> 
   32 PXDRawDQMModule::PXDRawDQMModule() : 
HistoModule(), m_storeRawPxdrarray(), m_storeRawHits(), m_storeRawAdcs()
 
   38            std::string(
"pxdraw"));
 
   48   TDirectory* oldDir = gDirectory;
 
   54   hrawPxdPackets = 
new TH1F(
"hrawPxdPackets", 
"Pxd Raw Packet Nr;Nr per Event", 16, 0, 16);
 
   55   hrawPxdPacketSize = 
new TH1F(
"hrawPxdPacketSize", 
"Pxd Raw Packetsize;Words per packet", 1024, 0, 1024);
 
   57                               "Pxd Raw Hit Map Overview;column+(ladder-1)*300+100;row+850*((layer-1)*2+(sensor-1))", 3700 / 50, 0, 3700, 3500 / 50, 0, 3500);
 
   62   hrawPxdHitsCount = 
new TH1F(
"hrawPxdCount", 
"Pxd Raw Count ;Nr per Event", 8192, 0, 8192);
 
   63   for (
auto i = 0; i < 64; i++) {
 
   64     auto layer = (((i >> 5) & 0x1) + 1);
 
   65     auto ladder = ((i >> 1) & 0xF);
 
   66     auto sensor = ((i & 0x1) + 1);
 
   70       string s = str(format(
"Sensor %d:%d:%d (DHH ID %02Xh)") % layer % ladder % sensor % i);
 
   71       string s2 = str(format(
"_%d.%d.%d") % layer % ladder % sensor);
 
   74                                   (
"Pxd Raw Hit Map, " + s + 
";column;row").c_str(), 250,
 
   77                                      (
"Pxd Raw Charge Map, " + s + 
";column;row").c_str(), 250, 0, 250, 768, 0, 768);
 
   79                                       (
"Pxd Raw Hit Charge, " + s + 
";Charge").c_str(), 256, 0, 256);
 
   81                                          (
"Pxd Raw Hit Time Window (framenr*192-gate_of_hit), " + s + 
";Time [a.u.]").c_str(), 2048, -256, 2048 - 256);
 
   83                                           (
"Pxd Raw Gate Time Window (framenr*192-triggergate_of_hit), " + s + 
";Time [a.u.]").c_str(), 2048, -256, 2048 - 256);
 
  114   for (
int i = 0; i < 64; i++) {
 
  135     VxdID currentVxdId = it.getSensorID();
 
  141     const PXDDAQDHEStatus* dhe = (*m_storeDAQEvtStats).findDHE(currentVxdId);
 
  142     if (dhe == 
nullptr) {
 
  143       B2ERROR(
"No DHE found for SensorId: " << currentVxdId);
 
  150     if (dhh_id == 0 || dhh_id >= 64) {
 
  151       B2ERROR(
"SensorId (DHH ID) out of range: " << dhh_id);
 
  156                                                    100 + it.getRow() + 850 * (layer + layer + sensor - 3));
 
  169       unsigned int layer, ladder, sensor;
 
  171       currentVxdId = it.getSensorID();
 
  176       dhh_id = ((layer - 1) << 5) | ((ladder) << 1) | (sensor - 1);
 
  177       if (dhh_id <= 0 || dhh_id >= 64) {
 
  178         B2ERROR(
"SensorId (DHH ID) out of range: " << dhh_id);
 
  182       unsigned int chip_offset;
 
  183       chip_offset = it.getChip() * 64;
 
  184       const unsigned char* data = &it.getData()[0];
 
  185       for (
int row = 0; row < 768; row++) {
 
  186         for (
int col = 0; col < 64; col++) {
 
  187           hrawPxdAdcMapAll->Fill(col + chip_offset + ladder * 300 - 200, 100 + row + 850 * (layer + layer + sensor - 3), *(data++));
 
HistoModule.h is supposed to be used instead of Module.h for the modules with histogram definitions t...
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 PXD DAQ DHE Status class.
unsigned short getTriggerGate(void) const
get Trigger Gate
unsigned short getDHEID(void) const
Get DHE ID of sensor.
TH2F * hrawPxdAdcMapAll
Histogram Adc 2d hitmap (full frames only) (all pxd)
void initialize() override final
Initialize.
std::string m_storeRawAdcsName
RawAdcs StoreArray name.
TH1F * hrawPxdGateTimeWindow[64]
Histogram raw pixel trigger gate window.
TH1F * hrawPxdPacketSize
Histogram raw packet size.
StoreObjPtr< PXDDAQStatus > m_storeDAQEvtStats
Input array for DAQ Status.
StoreArray< RawPXD > m_storeRawPxdrarray
Storearray for raw data packets
TH1F * hrawPxdHitsCharge[64]
Histogram raw pixel charge.
void defineHisto() override final
Define histograms.
std::string m_storeRawHitsName
PXDRawHits StoreArray name.
std::string m_storeRawPxdrarrayName
RawPXD StoreArray name.
void event() override final
Event.
TH1F * hrawPxdHitsCount
Histogram pixelcount/???
TH2F * hrawPxdHitMapAll
Histogram 2d hitmap (all)
StoreArray< PXDRawAdc > m_storeRawAdcs
Storearray for ADC from full frames
std::string m_histogramDirectoryName
Name of the histogram directory in ROOT file.
TH1F * hrawPxdPackets
Histogram number of raw packets.
TH2F * hrawPxdHitMap[64]
Histogram 2d hitmap.
void beginRun() override final
Begin run.
TH1F * hrawPxdHitTimeWindow[64]
Histogram raw pixel hit "time" window.
StoreArray< PXDRawHit > m_storeRawHits
Storearray for raw pixels
TH2F * hrawPxdChargeMap[64]
Histogram 2d chargemap.
static GeoCache & getInstance()
Return a reference to the singleton instance.
bool validSensorID(Belle2::VxdID id) const
Check that id is a valid sensor number.
Class to uniquely identify a any structure of the PXD and SVD.
baseType getSensorNumber() const
Get the sensor id.
baseType getLadderNumber() const
Get the ladder id.
baseType getLayerNumber() const
Get the layer id.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
Namespace to encapsulate code needed for simulation and reconstrucion of the PXD.
Namespace to provide code needed by both Vertex Detectors, PXD and SVD, and also testbeam telescopes.
Abstract base class for different kinds of events.