15#include "GeoModelKernel/throwExcept.h"
25 const float time = cluster.
time();
28 Eigen::Matrix<float,3,1> localPosition = Eigen::Matrix<float,3,1>::Zero();
29 localPosition(0, 0) = localPos.x();
30 localPosition(1, 0) = localPos.y();
31 localPosition(2, 0) = time;
33 Eigen::Matrix<float,3,3> localCovariance = Eigen::Matrix<float,3,3>::Zero();
34 localCovariance(0, 0) = localCov(0, 0);
35 localCovariance(1, 1) = localCov(1, 1);
36 localCovariance(2, 2) = timeResolution * timeResolution;
38 return {localPosition, localCovariance};
49 const auto& RDOs = indetCluster.
rdoList();
50 const auto& ToTs = indetCluster.
totList();
52 xaodCluster.
setMeasurement<3>(idHash, localPosition, localCovariance);
57 return StatusCode::SUCCESS;
64 Eigen::Matrix<float,2,1> localPosition(localPos.x(), localPos.y());
66 Eigen::Matrix<float,2,2> localCovariance;
67 localCovariance.setZero();
68 localCovariance(0, 0) = localCov(0, 0);
69 localCovariance(1, 1) = localCov(1, 1);
71 return {localPosition, localCovariance};
83 Eigen::Matrix<float, 3, 1> globalPosition(globalPos.x(), globalPos.y(), globalPos.z());
85 const auto& RDOs = indetCluster.
rdoList();
86 const auto& ToTs = indetCluster.
totList();
87 const auto& charges = indetCluster.
chargeList();
89 auto isSplit = indetCluster.
isSplit();
93 xaodCluster.
setMeasurement<2>(idHash, localPosition, localCovariance);
107 return StatusCode::SUCCESS;
114 float localPosition = 0.f, localCovariance = 0.f;
115 if (element.
isBarrel() or (not isITk)) {
116 localPosition = localPos.x();
121 if ( design ==
nullptr ) {
125 localPosition = localInPolar.
xPhi();
126 localCovariance = design->phiPitchPhi() * design->phiPitchPhi() *
one_over_twelve;
143 Eigen::Matrix<float, 3, 1> globalPosition(globalPos.x(), globalPos.y(), globalPos.z());
145 const auto& RDOs = indetCluster.
rdoList();
148 xaodCluster.
setMeasurement<1>(idHash, localPosition, localCovariance);
154 return StatusCode::SUCCESS;
163 if (design ==
nullptr) {
164 return StatusCode::FAILURE;
174 Amg::Vector3D globalPosition(globalPos(0, 0), globalPos(1, 0), globalPos(2, 0));
177 errorMatrix.setIdentity();
178 errorMatrix.fillSymmetric(0, 0, xaodCluster.
localCovariance<2>()(0, 0));
179 errorMatrix.fillSymmetric(1, 1, xaodCluster.
localCovariance<2>()(1, 1));
181 int colmax = std::numeric_limits<int>::min();
182 int rowmax = std::numeric_limits<int>::min();
183 int colmin = std::numeric_limits<int>::max();
184 int rowmin = std::numeric_limits<int>::max();
191 const std::vector<Identifier>& rod_list_cluster = xaodCluster.
rdoList();
192 const std::vector<float>& charge_list_cluster = xaodCluster.
chargeList();
194 if (rod_list_cluster.size() == charge_list_cluster.size()) {
196 for (std::size_t i(0); i<rod_list_cluster.size(); ++i) {
197 const Identifier& this_rdo = rod_list_cluster[i];
198 const float this_charge = charge_list_cluster[i];
200 const int row = pixelID.
phi_index(this_rdo);
203 qRowMax = this_charge;
204 }
else if (row == rowmax) {
205 qRowMax += this_charge;
210 qRowMin = this_charge;
211 }
else if (row == rowmin) {
212 qRowMin += this_charge;
215 const int col = pixelID.
eta_index(this_rdo);
218 qColMax = this_charge;
219 }
else if (col == colmax) {
220 qColMax += this_charge;
225 qColMin = this_charge;
226 }
else if (col == colmin) {
227 qColMin += this_charge;
237 if(qRowMin + qRowMax > 0) omegax = qRowMax/(qRowMin + qRowMax);
238 if(qColMin + qColMax > 0) omegay = qColMax/(qColMin + qColMax);
248 std::vector<Identifier>(xaodCluster.
rdoList()),
250 std::vector<int>(xaodCluster.
totList()),
254 std::move(errorMatrix),
261 return StatusCode::SUCCESS;
278 if (design ==
nullptr) {
279 return StatusCode::FAILURE;
282 const auto designShape = design->
shape();
285 const auto& rdoList = xaodCluster.
rdoList();
290 double pos_x = localPos(0, 0);
293 const Identifier firstStripId = rdoList.front();
294 int firstStrip = stripID.
strip(firstStripId);
295 int stripRow = stripID.
row(firstStripId);
298 pos_x = clusterPosition.
xPhi() + shift;
299 pos_y = clusterPosition.xEta();
307 const auto& firstStrip = stripID.
strip(rdoList.front());
308 const auto& lastStrip = stripID.
strip(rdoList.back());
309 const auto& row = stripID.
row(rdoList.front());
310 const int firstStrip1D = design->
strip1Dim (firstStrip, row );
311 const int lastStrip1D = design->
strip1Dim( lastStrip, row );
317 const double clusterWidth = design->
stripPitch() * ( lastStrip - firstStrip + 1 );
319 const std::pair<InDetDD::SiLocalPosition, InDetDD::SiLocalPosition> ends( design->
endsOfStrip(centre) );
320 const double stripLength( std::abs(ends.first.xEta() - ends.second.xEta()) );
325 const double col_x =
width.colRow().x();
326 const double col_y =
width.colRow().y();
328 double scale_factor = 1.;
331 else if ( col_x == 2 )
335 errorMatrix.setIdentity();
348 double sn2 = sn * sn;
349 double cs2 = 1. - sn2;
351 double v0 = errorMatrix(0,0) * w * w;
352 double v1 = errorMatrix(1,1);
353 errorMatrix.fillSymmetric( 0, 0, cs2 * v0 + sn2 * v1 );
354 errorMatrix.fillSymmetric( 0, 1, sn * std::sqrt(cs2) * (v0 - v1) );
355 errorMatrix.fillSymmetric( 1, 1, sn2 * v0 + cs2 * v1 );
360 std::vector<Identifier>(rdoList),
363 std::move(errorMatrix));
365 return StatusCode::SUCCESS;
374 float time = locPos(2,0);
380 errorMatrix.setIdentity();
381 errorMatrix.fillSymmetric(0, 0, xaodCluster.
localCovariance<3>()(0, 0));
382 errorMatrix.fillSymmetric(1, 1, xaodCluster.
localCovariance<3>()(1, 1));
383 float time_resolution = std::sqrt(xaodCluster.
localCovariance<3>()(2, 2));
385 double etaWidth = 1.3;
386 double phiWidth = 1.3;
391 indetCluster = new ::HGTD_Cluster(
id,
393 std::vector<Identifier>(xaodCluster.
rdoList()),
396 std::move(errorMatrix),
399 std::vector<int>(xaodCluster.
totList()));
401 return StatusCode::SUCCESS;
static constexpr double one_over_twelve
Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration.
virtual float time() const
virtual const std::vector< int > & totList() const
virtual float timeResolution() const
This is a "hash" representation of an Identifier.
value_type get_compact() const
Get the compact id.
virtual DetectorShape shape() const
Shape of element.
Class to hold geometrical description of an HGTD detector element.
Class used to describe the design of a module (diode segmentation and readout scheme)
double widthFromRowRange(const int rowMin, const int rowMax) const
Method to calculate phi width from a row range.
double widthFromColumnRange(const int colMin, const int colMax) const
Method to calculate eta width from a column range.
Base class for the SCT module side design, extended by the Forward and Barrel module design.
virtual double stripPitch(const SiLocalPosition &chargePos) const =0
give the strip pitch (dependence on position needed for forward)
virtual int strip1Dim(int strip, int row) const override
only relevant for SCT.
virtual SiLocalPosition localPositionOfCluster(const SiCellId &cellId, int cluserSize) const =0
virtual std::pair< SiLocalPosition, SiLocalPosition > endsOfStrip(const SiLocalPosition &position) const override=0
give the ends of strips
Identifier for the strip or pixel cell.
Class to hold geometrical description of a silicon detector element.
virtual const SiDetectorDesign & design() const override final
access to the local description (inline):
double phiPitch() const
Pitch (inline methods)
double sinStereoLocal(const Amg::Vector2D &localPos) const
Angle of strip in local frame with respect to the etaAxis.
Class to represent a position in the natural frame of a silicon sensor, for Pixel and SCT For Pixel: ...
double xPhi() const
position along phi direction:
SiCellId cellIdOfPosition(const Amg::Vector2D &localPos) const
As in previous method but returns SiCellId.
virtual IdentifierHash identifyHash() const override final
identifier hash (inline)
Identifier identifierOfPosition(const Amg::Vector2D &localPos) const
Full identifier of the cell for a given position: assumes a raw local position (no Lorentz shift)
Amg::Vector2D rawLocalPositionOfCell(const SiCellId &cellId) const
Returns position (center) of cell.
double splitProbability1() const
double splitProbability2() const
const std::vector< int > & totList() const
const std::vector< float > & chargeList() const
bool isSplit() const
access mehtods for splitting
const Amg::Vector3D & globalPosition() const
return global position reference
const InDet::SiWidth & width() const
return width class reference
virtual const InDetDD::SiDetectorElement * detectorElement() const override final
return the detector element corresponding to this PRD The pointer will be zero if the det el is not d...
This is an Identifier helper class for the Pixel subdetector.
int eta_index(const Identifier &id) const
int phi_index(const Identifier &id) const
This is an Identifier helper class for the SCT subdetector.
int row(const Identifier &id) const
int strip(const Identifier &id) const
const Amg::Vector2D & localPosition() const
return the local position reference
Identifier identify() const
return the identifier
const Amg::MatrixX & localCovariance() const
return const ref to the error matrix
const std::vector< Identifier > & rdoList() const
return the List of rdo identifiers (pointers)
const std::vector< int > & totList() const
Returns the list of Time Over Threshold of the channels building the cluster.
void setToTlist(const std::vector< int > &tots)
Sets the list of ToT of the channels building the cluster.
const std::vector< Identifier > rdoList() const
Returns the list of identifiers of the channels building the cluster.
void setRDOlist(const std::vector< Identifier > &rdolist)
Sets the list of identifiers of the channels building the cluster.
const std::vector< float > & chargeList() const
Returns the list of charges of the channels building the cluster.
void setTotalCharge(float totalCharge)
Sets the total charge.
const std::vector< int > & totList() const
Returns the list of ToT of the channels building the cluster.
void setChannelsInPhiEta(int channelsInPhi, int channelsInEta)
Sets the dimensions of the cluster in numbers of channels in phi (x) and eta (y) directions.
int channelsInPhi() const
Returns the dimensions of the cluster in numbers of channels in phi (x) and eta (y) directions,...
void setTotalToT(int totalToT)
Sets the total ToT.
void setSplitProbabilities(float prob1, float prob2)
Sets the splitting probabilities for the cluster.
const std::vector< Identifier > rdoList() const
Returns the list of identifiers of the channels building the cluster.
ConstVectorMap< 3 > globalPosition() const
Returns the global position of the pixel cluster.
int lvl1a() const
Return the LVL1 accept.
void setChargelist(const std::vector< float > &charges)
Sets the list of charges of the channels building the cluster.
int channelsInEta() const
void setToTlist(const std::vector< int > &tots)
Sets the list of ToT of the channels building the cluster.
void setLVL1A(int lvl1a)
Sets the LVL1 accept.
float splitProbability1() const
Returns the splitting probabilities for the cluster.
bool isSplit() const
Returns if the cluster is split or not.
void setRDOlist(const std::vector< Identifier > &rdolist)
Sets the list of identifiers of the channels building the cluster.
float splitProbability2() const
void setIsSplit(bool isSplit)
Sets if the cluster is split or not.
void setWidthInEta(float widthInEta)
Sets the width of the cluster in eta (y) direction.
ConstVectorMap< 3 > globalPosition() const
Returns the global position of the strip cluster.
void setRDOlist(const std::vector< Identifier > &rdolist)
Sets the list of identifiers of the channels building the cluster.
int channelsInPhi() const
Returns the dimensions of the cluster in numbers of channels in phi (x), respectively.
const std::vector< Identifier > rdoList() const
Returns the list of identifiers of the channels building the cluster.
void setChannelsInPhi(int channelsInPhi)
Sets the dimensions of the cluster in numbers of channels in phi (x)
void setMeasurement(const DetectorIDHashType idHash, MeasVector< N > locPos, MeasMatrix< N > locCov)
Sets IdentifierHash, local position and local covariance of the measurement.
ConstMatrixMap< N > localCovariance() const
Returns the local covariance of the measurement.
ConstVectorMap< N > localPosition() const
Returns the local position of the measurement.
void setIdentifier(const DetectorIdentType measId)
Sets the full Identifier of the measurement.
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic > MatrixX
Dynamic Matrix - dynamic allocation.
Eigen::Matrix< double, 2, 1 > Vector2D
Eigen::Matrix< double, 3, 1 > Vector3D
std::pair< xAOD::MeasVector< 1 >, xAOD::MeasMatrix< 1 > > convertSCT_LocalPosCov(const InDet::SCT_Cluster &cluster, bool isITk=true)
std::pair< xAOD::MeasVector< 2 >, xAOD::MeasMatrix< 2 > > convertPix_LocalPosCov(const InDet::PixelCluster &cluster)
StatusCode convertXaodToInDetCluster(const xAOD::PixelCluster &xaodCluster, const InDetDD::SiDetectorElement &element, const PixelID &pixelID, InDet::PixelCluster *&indetCluster)
StatusCode convertInDetToXaodCluster(const InDet::PixelCluster &indetCluster, const InDetDD::SiDetectorElement &element, xAOD::PixelCluster &xaodCluster)
std::pair< xAOD::MeasVector< 3 >, xAOD::MeasMatrix< 3 > > convertHGTD_LocalPosCov(const HGTD_Cluster &cluster)
float computeTotalCharge(const SG::AuxElement &cluster)
int computeTotalToT(const SG::AuxElement &cluster)
StripCluster_v1 StripCluster
Define the version of the strip cluster class.
Eigen::Matrix< float, N, N > MeasMatrix
Eigen::Matrix< float, N, 1 > MeasVector
Abrivation of the Matrix & Covariance definitions.
PixelCluster_v1 PixelCluster
Define the version of the pixel cluster class.
HGTDCluster_v1 HGTDCluster
Define the version of the pixel cluster class.
#define THROW_EXCEPTION(MESSAGE)