ATLAS Offline Software
Loading...
Searching...
No Matches
ITkPixelDecodingAlg.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 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
22//class PixelID;
23
25{
26 public:
27
28 ITkPixelDecodingAlg(const std::string &name, ISvcLocator *pSvcLocator);
29
30 virtual StatusCode initialize() override;
31
32 virtual StatusCode execute (const EventContext& ctx) const override;
33
34 virtual StatusCode finalize() override;
35
36
37 private:
38
39 typedef std::vector< std::vector<uint32_t >> ITkPacketCollection;
40
41 ServiceHandle<IROBDataProviderSvc> m_robDataProviderSvc{ this, "ROBDataProvider", "ROBDataProviderSvc" };
42
43 SG::ReadCondHandleKey<ITkPixelCablingData> m_pixelCablingKey{this, "PixelCablingKey", "ITkPixelCablingData", "Cond Key of Pixel Cabling"};
44
45 SG::WriteHandleKey<PixelRDO_Container> m_pixelRDOKey{this, "pixelRDOKey", "ITkPixelRDOs", "StoreGate Key of Pixel RDOs"};
46
47 std::vector<uint32_t> m_sourceIDs;
48
50
51};
52
54 struct ScopedTimer {
55 std::string m_label;
56 std::chrono::time_point<std::chrono::high_resolution_clock> m_start;
57 MsgStream& m_msg_source;
58
59 ScopedTimer(std::string lbl, MsgStream& src) : m_label(std::move(lbl)), m_start(std::chrono::high_resolution_clock::now()), m_msg_source(src) {}
61 auto end = std::chrono::high_resolution_clock::now();
62 auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(end - m_start).count();
63 m_msg_source << MSG::DEBUG << m_label << " took " << ms << " ms" << endmsg;
64 }
65
66 };
67}
68
70 //Forms pixel RDOs from the decoded hits & fills them into a container
72
73 public:
74 explicit RDOCallback(PixelRDO_Container* rdoContainer, const PixelID* idHelper) :
75 m_rdoContainer(rdoContainer),
76 m_idHelper(idHelper)
77 {};
78
79 ~RDOCallback() = default;
80
81 //non-negotiable concepts
82 inline void evt_init([[maybe_unused]] uint8_t tag) {
84 const auto waferHash = m_idHelper->wafer_hash(m_identifier);
85 if (m_rdoContainer->indexFind(waferHash) == m_rdoContainer->end()){
86 m_rdoCollection = std::make_unique<PixelRDO_Collection>(waferHash);
87 m_rdoCollection->setIdentifier(m_identifier);
88 m_rdoCollection->reserve(1000);
89 }
90 else {
91 m_rdoCollection.reset(m_rdoContainer->removeCollection(waferHash));
92 }
93
94 };
95
96 inline void evt_next([[maybe_unused]] uint8_t tag) {};
97
98 inline void evt_done() {
99 m_rdoContainer->addCollection(m_rdoCollection.release(), m_idHelper->wafer_hash(m_identifier)).ignore();
100 };
101
102 inline void add_hit(uint16_t col, uint16_t row, uint16_t tot){
103 //Translate the col, row into module coordinates
105 m_rdoCollection->emplace_back(new Pixel1RawData(m_idHelper->pixel_id(m_identifier, row, col), tot, 0, 0, 0));
106 };
107
108 inline void add_hmap([[maybe_unused]] uint8_t qcol, [[maybe_unused]] uint8_t qrow, [[maybe_unused]] uint16_t hmap, [[maybe_unused]] uint64_t tots) {};
109
110 inline void add_qcore([[maybe_unused]] uint8_t qcol, [[maybe_unused]] uint8_t qrow, [[maybe_unused]] uint64_t qtot) {};
111
112 inline uint8_t on_error([[maybe_unused]] itksw::pix::endec::intf::EventError error) {return 0;};
113 //end of non-negotiable concepts
114
115 //extra members
116
117 //this is needed to properly identify the module.
118 inline void setOfflineID(const uint32_t& offlineID){
119 m_offlineID = offlineID;
120 };
121
122 //this is needed to properly translate hits on a quad
123 inline void setChipID(const uint8_t& chipID){
124 m_chipID = chipID;
125 }
126
127 //translate
129 m_transform = transform;
130 }
131
132 private:
134 uint32_t m_offlineID = 0;
135 uint8_t m_chipID = 0;
138 std::unique_ptr<PixelRDO_Collection> m_rdoCollection;
140 };
141
142 //This prints the decoded hits on the screen,
143 //useful for testing purposes
145 public:
146 TestEventCallback(MsgStream& src): m_msg_source(src) {};
148
149 inline void evt_init(uint8_t tag) {
150 m_msg_source << MSG::DEBUG << "evt_init(" << tag << ")" << std::endl;
151 }
152
153 inline void evt_next(uint8_t tag) {
154 m_msg_source << MSG::DEBUG << "evt_next(" << tag << ")" << std::endl;
155 }
156
157 inline void evt_done() {
158 m_msg_source << MSG::DEBUG << "evt_done()" << std::endl;
159 }
160
161 inline void add_hit(uint16_t col, uint16_t row, uint16_t tot) {
162 m_msg_source << MSG::DEBUG << "add_hit(" << col << "," << row << "," << tot << ")" << std::endl;
163 }
164
165 inline void add_hmap(uint8_t qcol, uint8_t qrow, uint16_t hmap, uint64_t tots) {
166 m_msg_source << MSG::DEBUG << "add_hmap(qcol=" << qcol << ",qrow=" << qrow
167 << ",hmap=" << hmap << ",tots=" << tots << ")" << std::endl;
168 }
169
170 inline void add_qcore(uint8_t qcol, uint8_t qrow, uint64_t qtot) {
171 m_msg_source << MSG::DEBUG << "add_qcore(qcol=" << qcol << ",qrow=" << qrow
172 << ",qtot=" << qtot << ")" << std::endl;
173 }
174
175 inline uint8_t on_error(itksw::pix::endec::intf::EventError error) {
176 m_msg_source << MSG::DEBUG << "on_error(" << error.code << ")" << std::endl;
177 return 0;
178 }
179
180 MsgStream& m_msg_source;
181
182 };
183}
184
185
186#endif
187
#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:69
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