|
ATLAS Offline Software
|
Go to the documentation of this file.
27 const float time = indetCluster.
time();
30 const auto& RDOs = indetCluster.
rdoList();
31 const auto& ToTs = indetCluster.
totList();
35 localPosition(0, 0) = localPos.x();
36 localPosition(1, 0) = localPos.y();
37 localPosition(2, 0) = time;
40 localCovariance(0, 0) = localCov(0, 0);
41 localCovariance(1, 1) = localCov(1, 1);
42 localCovariance(2, 2) = timeResolution * timeResolution;
44 xaodCluster.
setMeasurement<3>(idHash, localPosition, localCovariance);
49 return StatusCode::SUCCESS;
61 Eigen::Matrix<float,2,1> localPosition(localPos.x(), localPos.y());
63 Eigen::Matrix<float,2,2> localCovariance;
64 localCovariance.setZero();
65 localCovariance(0, 0) = localCov(0, 0);
66 localCovariance(1, 1) = localCov(1, 1);
69 Eigen::Matrix<float, 3, 1> globalPosition(globalPos.x(), globalPos.y(), globalPos.z());
71 const auto& RDOs = indetCluster.
rdoList();
72 const auto& ToTs = indetCluster.
totList();
73 const auto& charges = indetCluster.
chargeList();
75 auto omegaX = indetCluster.
omegax();
76 auto omegaY = indetCluster.
omegay();
81 xaodCluster.
setMeasurement<2>(idHash, localPosition, localCovariance);
96 return StatusCode::SUCCESS;
104 static const double one_over_twelve = 1. / 12.;
109 Eigen::Matrix<float,1,1> localPosition;
110 Eigen::Matrix<float,1,1> localCovariance;
111 localCovariance.setZero();
114 localPosition(0, 0) = localPos.x();
115 localCovariance(0, 0) = element.
phiPitch() * element.
phiPitch() * one_over_twelve;
119 if ( design ==
nullptr ) {
120 return StatusCode::FAILURE;
123 localPosition(0, 0) = localInPolar.
xPhi();
128 Eigen::Matrix<float, 3, 1> globalPosition(globalPos.x(), globalPos.y(), globalPos.z());
130 const auto& RDOs = indetCluster.
rdoList();
133 xaodCluster.
setMeasurement<1>(idHash, localPosition, localCovariance);
139 return StatusCode::SUCCESS;
148 if (design ==
nullptr) {
149 return StatusCode::FAILURE;
159 Amg::Vector3D globalPosition(globalPos(0, 0), globalPos(1, 0), globalPos(2, 0));
162 errorMatrix.setIdentity();
163 errorMatrix.fillSymmetric(0, 0, xaodCluster.
localCovariance<2>()(0, 0));
164 errorMatrix.fillSymmetric(1, 1, xaodCluster.
localCovariance<2>()(1, 1));
171 const std::vector<Identifier>& rod_list_cluster = xaodCluster.
rdoList();
172 for (
const auto& this_rdo : rod_list_cluster) {
194 std::vector<Identifier>(xaodCluster.
rdoList()),
196 std::vector<int>(xaodCluster.
totList()),
200 std::move(errorMatrix),
207 return StatusCode::SUCCESS;
216 static const double one_over_twelve = 1. / 12.;
226 if (design ==
nullptr) {
227 return StatusCode::FAILURE;
230 const auto designShape = design->
shape();
233 const auto& rdoList = xaodCluster.
rdoList();
238 double pos_x = localPos(0, 0);
241 const Identifier firstStripId = rdoList.front();
243 int stripRow = stripID.
row(firstStripId);
246 pos_x = clusterPosition.
xPhi() + shift;
247 pos_y = clusterPosition.xEta();
257 const auto&
row = stripID.
row(rdoList.front());
267 const std::pair<InDetDD::SiLocalPosition, InDetDD::SiLocalPosition> ends( design->
endsOfStrip(centre) );
268 const double stripLength( std::abs(ends.first.xEta() - ends.second.xEta()) );
273 const double col_x =
width.colRow().x();
274 const double col_y =
width.colRow().y();
276 double scale_factor = 1.;
279 else if ( col_x == 2 )
283 errorMatrix.setIdentity();
284 errorMatrix.fillSymmetric(0, 0, scale_factor * scale_factor *
width.phiR() *
width.phiR() * one_over_twelve);
285 errorMatrix.fillSymmetric(1, 1,
width.z() *
width.z() / col_y / col_y * one_over_twelve);
296 double sn2 = sn * sn;
297 double cs2 = 1. - sn2;
299 double v0 = errorMatrix(0,0) *
w *
w;
300 double v1 = errorMatrix(1,1);
301 errorMatrix.fillSymmetric( 0, 0, cs2 *
v0 + sn2 * v1 );
302 errorMatrix.fillSymmetric( 0, 1, sn * std::sqrt(cs2) * (
v0 - v1) );
303 errorMatrix.fillSymmetric( 1, 1, sn2 *
v0 + cs2 * v1 );
308 std::vector<Identifier>(rdoList),
311 std::move(errorMatrix));
313 return StatusCode::SUCCESS;
322 float time = locPos(2,0);
328 errorMatrix.setIdentity();
329 errorMatrix.fillSymmetric(0, 0, xaodCluster.
localCovariance<3>()(0, 0));
330 errorMatrix.fillSymmetric(1, 1, xaodCluster.
localCovariance<3>()(1, 1));
331 float time_resolution = std::sqrt(xaodCluster.
localCovariance<3>()(2, 2));
333 double etaWidth = 1.3;
341 std::vector<Identifier>(xaodCluster.
rdoList()),
344 std::move(errorMatrix),
347 std::vector<int>(xaodCluster.
totList()));
349 return StatusCode::SUCCESS;
Identifier identifierOfPosition(const Amg::Vector2D &localPos) const
Full identifier of the cell for a given position: assumes a raw local position (no Lorentz shift)
const std::vector< float > & chargeList() const
Returns the list of charges of the channels building the cluster.
virtual double stripPitch(const SiLocalPosition &chargePos) const =0
give the strip pitch (dependence on position needed for forward)
StatusCode convertInDetToXaodCluster(const InDet::PixelCluster &indetCluster, const InDetDD::SiDetectorElement &element, xAOD::PixelCluster &xaodCluster)
void setTotalCharge(float totalCharge)
Sets the total charge.
int phi_index(const Identifier &id) const
SiCellId cellIdOfPosition(const Amg::Vector2D &localPos) const
As in previous method but returns SiCellId.
void setChannelsInPhi(int channelsInPhi)
Sets the dimensions of the cluster in numbers of channels in phi (x)
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic > MatrixX
Dynamic Matrix - dynamic allocation.
double widthFromRowRange(const int rowMin, const int rowMax) const
Method to calculate phi width from a row range.
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.
Eigen::Matrix< double, 2, 1 > Vector2D
virtual DetectorShape shape() const
Shape of element.
bool isSplit() const
access mehtods for splitting
const Amg::MatrixX & localCovariance() const
return const ref to the error matrix
void setRDOlist(const std::vector< Identifier > &rdolist)
Sets the list of identifiers of the channels building the cluster.
int computeTotalToT(const SG::AuxElement &cluster)
double splitProbability1() const
const std::vector< Identifier > & rdoList() const
return the List of rdo identifiers (pointers)
value_type get_compact() const
Get the compact id.
void setRDOlist(const std::vector< Identifier > &rdolist)
Sets the list of identifiers of the channels building the cluster.
void setChargelist(const std::vector< float > &charges)
Sets the list of charges of the channels building the cluster.
StatusCode convertXaodToInDetCluster(const xAOD::PixelCluster &xaodCluster, const InDetDD::SiDetectorElement &element, const PixelID &pixelID, InDet::PixelCluster *&indetCluster)
void setIsSplit(bool isSplit)
Sets if the cluster is split or not.
bool isSplit(int matchInfo)
void setWidthInEta(float widthInEta)
Sets the width of the cluster in eta (y) direction.
const std::vector< int > & totList() const
void setTotalToT(int totalToT)
Sets the total ToT.
virtual IdentifierHash identifyHash() const override final
identifier hash (inline)
const std::vector< Identifier > rdoList() const
Returns the list of identifiers of the channels building the cluster.
float splitProbability2() const
Copyright (C) 2002-2023 CERN for the benefit of the ATLAS collaboration.
void setSplitProbabilities(float prob1, float prob2)
Sets the splitting probabilities for the cluster.
double xPhi() const
position along phi direction:
double phiPitch() const
Pitch (inline methods)
double splitProbability2() const
void setIdentifier(const DetectorIdentType measId)
Sets the full Identifier of the measurement.
double widthFromColumnRange(const int colMin, const int colMax) const
Method to calculate eta width from a column range.
::StatusCode StatusCode
StatusCode definition for legacy code.
int row(const Identifier &id) const
void setToTlist(const std::vector< int > &tots)
Sets the list of ToT of the channels building the cluster.
int eta_index(const Identifier &id) const
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.
ConstMatrixMap< N > localCovariance() const
Returns the local covariance of the measurement.
virtual float timeResolution() const
ConstVectorMap< N > localPosition() const
Returns the local position of the measurement.
void setLVL1A(int lvl1a)
Sets the LVL1 accept.
float computeTotalCharge(const SG::AuxElement &cluster)
Identifier identify() const
return the identifier
ConstVectorMap< 3 > globalPosition() const
Returns the global position of the pixel cluster.
double phiPitchPhi(const SiLocalPosition &localPosition) const
const Amg::Vector2D & localPosition() const
return the local position reference
void setOmegas(float omegax, float omegay)
Sets omegax and omegay, i.e.
float omegaX() const
Returns omegax and omegay, i.e.
const std::vector< int > & totList() const
Returns the list of ToT of the channels building the cluster.
Eigen::Matrix< double, 3, 1 > Vector3D
virtual SiLocalPosition localPositionOfCluster(const SiCellId &cellId, int cluserSize) const =0
const Amg::Vector3D & globalPosition() const
return global position reference
const InDet::SiWidth & width() const
return width class reference
void setRDOlist(const std::vector< Identifier > &rdolist)
Sets the list of identifiers of the channels building the cluster.
Amg::Vector2D rawLocalPositionOfCell(const SiCellId &cellId) const
Returns position (center) of cell.
void setMeasurement(const DetectorIDHashType idHash, MeasVector< N > locPos, MeasMatrix< N > locCov)
Sets IdentifierHash, local position and local covariance of the measurement.
virtual int strip1Dim(int strip, int row) const override
only relevant for SCT.
int strip(const Identifier &id) const
void setChannelsInPhiEta(int channelsInPhi, int channelsInEta)
Sets the dimensions of the cluster in numbers of channels in phi (x) and eta (y) directions.
double sinStereoLocal(const Amg::Vector2D &localPos) const
Angle of strip in local frame with respect to the etaAxis.
virtual const std::vector< int > & totList() const
ConstVectorMap< 3 > globalPosition() const
Returns the global position of the strip cluster.
This is a "hash" representation of an Identifier. This encodes a 32 bit index which can be used to lo...
int channelsInEta() const
virtual const SiDetectorDesign & design() const override final
access to the local description (inline):
SiLocalPosition localPositionOfCellPC(const SiCellId &cellId) const
This is for debugging only.
const std::vector< Identifier > rdoList() const
Returns the list of identifiers of the channels building the cluster.
virtual std::pair< SiLocalPosition, SiLocalPosition > endsOfStrip(const SiLocalPosition &position) const override=0
give the ends of strips
virtual float time() const
Vertex centroid(const Polygon &p)
int channelsInPhi() const
Returns the dimensions of the cluster in numbers of channels in phi (x) and eta (y) directions,...
float splitProbability1() const
Returns the splitting probabilities for the cluster.
int lvl1a() const
Return the LVL1 accept.
const std::vector< float > & chargeList() const
bool isSplit() const
Returns if the cluster is split or not.