ATLAS Offline Software
Loading...
Searching...
No Matches
ITkPixelDecodingAlg.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
5#ifndef ITKPIXEL_DECODINGALG_H
6#define ITKPIXEL_DECODINGALG_H
7
10#include "GaudiKernel/MsgStream.h"
14#include "Identifier/Identifier.h"
18#include "itksw/pix/endec/DecCore.hpp"
19#include <chrono>
20
21
22using namespace itksw::pix::endec;
23
24//class PixelID;
25
27{
28 public:
29
30 ITkPixelDecodingAlg(const std::string &name, ISvcLocator *pSvcLocator);
31
32 virtual StatusCode initialize() override;
33
34 virtual StatusCode execute (const EventContext& ctx) const override;
35
36 virtual StatusCode finalize() override;
37
38
39 private:
40
41 typedef std::vector< std::vector<uint32_t >> ITkPacketCollection;
42
43 ServiceHandle<IROBDataProviderSvc> m_robDataProviderSvc{ this, "ROBDataProvider", "ROBDataProviderSvc" };
44
45 SG::ReadCondHandleKey<ITkPixelCablingData> m_pixelCablingKey{this, "PixelCablingKey", "ITkPixelCablingData", "Cond Key of Pixel Cabling"};
46
47 SG::WriteHandleKey<PixelRDO_Container> m_pixelRDOKey{this, "pixelRDOKey", "PixelRDOs", "StoreGate Key of Pixel RDOs"};
48
49 std::vector<uint32_t> m_sourceIDs;
50
52
53};
54
56 struct ScopedTimer {
57 std::string m_label;
58 std::chrono::time_point<std::chrono::high_resolution_clock> m_start;
59 MsgStream& m_msg_source;
60
61 ScopedTimer(std::string lbl, MsgStream& src) : m_label(std::move(lbl)), m_start(std::chrono::high_resolution_clock::now()), m_msg_source(src) {}
63 auto end = std::chrono::high_resolution_clock::now();
64 auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(end - m_start).count();
65 m_msg_source << MSG::DEBUG << m_label << " took " << ms << " ms" << endmsg;
66 }
67
68 };
69}
70
72 //Forms pixel RDOs from the decoded hits & fills them into a container
74
75 public:
76 explicit RDOCallback(PixelRDO_Container* rdoContainer, const PixelID* idHelper) :
77 m_rdoContainer(rdoContainer),
78 m_idHelper(idHelper)
79 {};
80
81 ~RDOCallback() = default;
82
83 //non-negotiable concepts
84 inline void evt_init([[maybe_unused]] uint8_t tag) {
86 const auto waferHash = m_idHelper->wafer_hash(m_identifier);
87 if (m_rdoContainer->indexFind(waferHash) == m_rdoContainer->end()){
88 m_rdoCollection = std::make_unique<PixelRDO_Collection>(waferHash);
89 m_rdoCollection->reserve(1000);
90 }
91 else {
92 m_rdoCollection.reset(m_rdoContainer->removeCollection(waferHash));
93 }
94
95 };
96
97 inline void evt_next([[maybe_unused]] uint8_t tag) {};
98
99 inline void evt_done() {
100 m_rdoContainer->addCollection(m_rdoCollection.release(), m_idHelper->wafer_hash(m_identifier)).ignore();
101 };
102
103 inline void add_hit(uint16_t col, uint16_t row, uint16_t tot){
104 //Translate the col, row into module coordinates
106 m_rdoCollection->emplace_back(new Pixel1RawData(m_idHelper->pixel_id(m_identifier, row, col), tot, 0, 0, 0));
107 };
108
109 inline void add_hmap([[maybe_unused]] uint8_t qcol, [[maybe_unused]] uint8_t qrow, [[maybe_unused]] uint16_t hmap, [[maybe_unused]] uint64_t tots) {};
110
111 inline void add_qcore([[maybe_unused]] uint8_t qcol, [[maybe_unused]] uint8_t qrow, [[maybe_unused]] uint64_t qtot) {};
112
113 inline uint8_t on_error([[maybe_unused]] itksw::pix::endec::intf::EventError error) {return 0;};
114 //end of non-negotiable concepts
115
116 //extra members
117
118 //this is needed to properly identify the module.
119 inline void setOfflineID(const uint32_t& offlineID){
120 m_offlineID = offlineID;
121 };
122
123 //this is needed to properly translate hits on a quad
124 inline void setChipID(const uint8_t& chipID){
125 m_chipID = chipID;
126 }
127
128 //translate
130 m_transform = transform;
131 }
132
133 private:
135 uint32_t m_offlineID = 0;
136 uint8_t m_chipID = 0;
139 std::unique_ptr<PixelRDO_Collection> m_rdoCollection;
141 };
142
143 //This prints the decoded hits on the screen,
144 //useful for testing purposes
146 public:
147 TestEventCallback(MsgStream& src): m_msg_source(src) {};
149
150 inline void evt_init(uint8_t tag) {
151 m_msg_source << MSG::DEBUG << "evt_init(" << tag << ")" << std::endl;
152 }
153
154 inline void evt_next(uint8_t tag) {
155 m_msg_source << MSG::DEBUG << "evt_next(" << tag << ")" << std::endl;
156 }
157
158 inline void evt_done() {
159 m_msg_source << MSG::DEBUG << "evt_done()" << std::endl;
160 }
161
162 inline void add_hit(uint16_t col, uint16_t row, uint16_t tot) {
163 m_msg_source << MSG::DEBUG << "add_hit(" << col << "," << row << "," << tot << ")" << std::endl;
164 }
165
166 inline void add_hmap(uint8_t qcol, uint8_t qrow, uint16_t hmap, uint64_t tots) {
167 m_msg_source << MSG::DEBUG << "add_hmap(qcol=" << qcol << ",qrow=" << qrow
168 << ",hmap=" << hmap << ",tots=" << tots << ")" << std::endl;
169 }
170
171 inline void add_qcore(uint8_t qcol, uint8_t qrow, uint64_t qtot) {
172 m_msg_source << MSG::DEBUG << "add_qcore(qcol=" << qcol << ",qrow=" << qrow
173 << ",qtot=" << qtot << ")" << std::endl;
174 }
175
176 inline uint8_t on_error(itksw::pix::endec::intf::EventError error) {
177 m_msg_source << MSG::DEBUG << "on_error(" << error.code << ")" << std::endl;
178 return 0;
179 }
180
181 MsgStream& m_msg_source;
182
183 };
184}
185
186
187#endif
188
#define endmsg
This is an Identifier helper class for the Pixel subdetector.
InDetRawDataContainer< InDetRawDataCollection< PixelRDORawData > > PixelRDO_Container
Property holding a SG store/key/clid from which a ReadHandle is made.
An algorithm that can be simultaneously executed in multiple threads.
virtual StatusCode initialize() override
ServiceHandle< IROBDataProviderSvc > m_robDataProviderSvc
std::vector< uint32_t > m_sourceIDs
virtual StatusCode finalize() override
virtual StatusCode execute(const EventContext &ctx) const override
SG::WriteHandleKey< PixelRDO_Container > m_pixelRDOKey
const PixelID * m_idHelper
SG::ReadCondHandleKey< ITkPixelCablingData > m_pixelCablingKey
std::vector< std::vector< uint32_t > > ITkPacketCollection
ITkPixelDecodingAlg(const std::string &name, ISvcLocator *pSvcLocator)
void add_hmap(uint8_t qcol, uint8_t qrow, uint16_t hmap, uint64_t tots)
uint8_t on_error(itksw::pix::endec::intf::EventError error)
PixelRDO_Container * m_rdoContainer
ITkPixelCabling::TransformType m_transform
void add_hit(uint16_t col, uint16_t row, uint16_t tot)
void setChipID(const uint8_t &chipID)
void setOfflineID(const uint32_t &offlineID)
void setTransformType(const ITkPixelCabling::TransformType &transform)
void add_qcore(uint8_t qcol, uint8_t qrow, uint64_t qtot)
std::unique_ptr< PixelRDO_Collection > m_rdoCollection
RDOCallback(PixelRDO_Container *rdoContainer, const PixelID *idHelper)
void add_hit(uint16_t col, uint16_t row, uint16_t tot)
void add_hmap(uint8_t qcol, uint8_t qrow, uint16_t hmap, uint64_t tots)
uint8_t on_error(itksw::pix::endec::intf::EventError error)
void add_qcore(uint8_t qcol, uint8_t qrow, uint64_t qtot)
This is an Identifier helper class for the Pixel subdetector.
Definition PixelID.h:67
Property holding a SG store/key/clid from which a WriteHandle is made.
static void chipToModuleTransform(const TransformType &transform, const uint8_t &chipID, uint16_t &col, uint16_t &row)
STL namespace.
ScopedTimer(std::string lbl, MsgStream &src)
std::chrono::time_point< std::chrono::high_resolution_clock > m_start