ATLAS Offline Software
Classes | Typedefs | Functions | Variables
MuonValR4 Namespace Reference

Lightweight algorithm to read xAOD MDT sim hits and (fast-digitised) drift circles from SG and fill a validation NTuple with identifier and drift circle info. More...

Classes

class  IPatternVisualizationTool
 Helper tool to visualize a pattern recogntion incident or a certain stage of the segment fit. More...
 
class  ITrackVisualizationTool
 Helper tool to visualize a pattern recogntion incident or a certain stage of the segment fit. More...
 
class  MdtCalibDbAlgTest
 
class  MdtDriftCircleVariables
 
class  MdtTwinDriftCircleVariables
 
class  MmClusterVariables
 
class  MsTrackTester
 
class  MuonHitTesterAlg
 
class  MuonHoughTransformTester
 
class  MuonRecoChainTester
 
class  MuonSPCalibrationTest
 
class  PatternVisualizationTool
 
class  RpcMeasurementVariables
 
class  SegmentExtpTest
 
class  SegmentRefitTest
 Simple tester class to refit the Mdt segments with the Acts global chi2 fitter In the ideal case, the Acts fit should return the same parameters as the Muon segment fitter with the same measurements to be included on the fit. More...
 
class  SimHitTester
 
class  SpacePointTesterModule
 
class  TesterModuleBase
 
class  TgcStripVariables
 
class  TrackContainerModule
 
class  TrackVisualizationTool
 
class  xMuonHitAnalysis
 

Typedefs

using ObjectMatching = MuonHoughTransformTester::ObjectMatching
 
using simHitSet = std::unordered_set< const xAOD::MuonSimHit * >
 
using LabeledSegmentSet = PatternVisualizationTool::LabeledSegmentSet
 

Functions

unsigned int countMatched (const simHitSet &truthHits, const simHitSet &recoHits)
 
unsigned int countMatched (const xAOD::MuonSegment *truthSeg, const MuonR4::SegmentSeed *seed)
 
unsigned int countMatched (const xAOD::MuonSegment *truthSeg, const MuonR4::Segment *segment)
 
template<class SpType >
bool isPrecHit (const SpType &sp)
 Define a spacepoint as precision hit if it's a Mdt or NSW eta hit. More...
 
std::unique_ptr< TEllipse > drawDriftCircle (const Amg::Vector3D &center, const double radius, const int color=kViolet, const int fillStyle=hollowFilling)
 Create a TEllipse for drawing a drift circle. More...
 
std::unique_ptr< TBox > drawBox (const Amg::Vector3D &boxCenter, const double boxWidth, const double boxHeight, const int color=kGreen+2, const int fillStyle=hollowFilling, const int view=objViewEta)
 Creates a box for drawing, e.g strip measurements. More...
 
std::unique_ptr< TBox > drawBox (const double x1, const double y1, const double x2, const double y2, const int color=kGreen+2, const int fillStyle=hollowFilling)
 Creates a box for drawing, e.g strip measurements. More...
 
std::unique_ptr< TLine > drawLine (const MuonR4::SegmentFit::Parameters &pars, const double lowEnd, const double highEnd, const int color=kRed+1, const int lineStyle=kDashed, const int view=objViewEta)
 Draws a line from the segment fit parameters. More...
 
std::unique_ptr< TArrow > drawArrow (const Amg::Vector3D &start, const Amg::Vector3D &dir, const int color=kRed+1, const int lineStyle=kDashed, const int view=objViewEta)
 
std::unique_ptr< TLatex > drawLabel (const std::string &text, const double xPos, const double yPos, const unsigned int fontSize=18)
 Create a TLatex label,. More...
 
std::unique_ptr< TLatex > drawAtlasLabel (const double xPos, const double yPos, const std::string &status="Internal")
 Create a ATLAS label. More...
 
std::unique_ptr< TLatex > drawLumiSqrtS (const double xPos, const double yPos, const std::string_view sqrtS="14", const std::string_view lumi="")
 Create a luminosity sqrtS label. More...
 

Variables

constexpr int hollowFilling = 0
 Filling codes for hollow / fullFilling / hatched filling. More...
 
constexpr int fullFilling = 1001
 
constexpr int hatchedFilling = 3344
 
constexpr int objViewEta = Acts::toUnderlying(MuonR4::SegmentFit::AxisDefs::etaCov)
 ObjectView. More...
 
constexpr int objViewPhi = Acts::toUnderlying(MuonR4::SegmentFit::AxisDefs::phiCov)
 

Detailed Description

Lightweight algorithm to read xAOD MDT sim hits and (fast-digitised) drift circles from SG and fill a validation NTuple with identifier and drift circle info.

Module to dump the basic properties of the TgcStrip collection.

Module to dump the basic properties of the RpcMeasurement collection.

Module to dump the basic properties of the MmCluster collection.

Module to dump the basic properties of the MdtTwinDriftCircle collection.

Module to dump the basic properties of the MdtDriftCircle collection.

Typedef Documentation

◆ LabeledSegmentSet

Definition at line 51 of file PatternVisualizationTool.cxx.

◆ ObjectMatching

Definition at line 28 of file MuonHoughTransformTester.cxx.

◆ simHitSet

using MuonValR4::simHitSet = typedef std::unordered_set<const xAOD::MuonSimHit*>

Definition at line 29 of file MuonHoughTransformTester.cxx.

Function Documentation

◆ countMatched() [1/3]

unsigned int MuonValR4::countMatched ( const simHitSet truthHits,
const simHitSet recoHits 
)

Definition at line 30 of file MuonHoughTransformTester.cxx.

31  {
32  unsigned int matched{0};
33  for (const xAOD::MuonSimHit* reco : recoHits) {
34  matched += truthHits.count(reco);
35  }
36  return matched;
37  }

◆ countMatched() [2/3]

unsigned int MuonValR4::countMatched ( const xAOD::MuonSegment truthSeg,
const MuonR4::Segment segment 
)

Definition at line 42 of file MuonHoughTransformTester.cxx.

43  {
44  return truthSeg ? countMatched(getMatchingSimHits(*truthSeg), getMatchingSimHits(*segment)) : 0;
45  }

◆ countMatched() [3/3]

unsigned int MuonValR4::countMatched ( const xAOD::MuonSegment truthSeg,
const MuonR4::SegmentSeed seed 
)

Definition at line 38 of file MuonHoughTransformTester.cxx.

39  {
40  return truthSeg ? countMatched(getMatchingSimHits(*truthSeg), getMatchingSimHits(*seed)) : 0;
41  }

◆ drawArrow()

std::unique_ptr< TArrow > MuonValR4::drawArrow ( const Amg::Vector3D start,
const Amg::Vector3D dir,
const int  color = kRed +1,
const int  lineStyle = kDashed,
const int  view = objViewEta 
)

Definition at line 22 of file VisualizationHelpers.cxx.

23  {
24  constexpr double arrowLength = 2.*Gaudi::Units::cm;
25  const Amg::Vector3D end = start + (arrowLength / std::hypot(dir[view], dir.z()) ) * dir;
26  auto arrow = std::make_unique<TArrow>(start[view], start.z(), end[view], end.z(),0.01);
27  arrow->SetLineColor(color);
28  arrow->SetLineWidth(2);
29  arrow->SetLineStyle(lineStyle);
30  return arrow;
31  }

◆ drawAtlasLabel()

std::unique_ptr< TLatex > MuonValR4::drawAtlasLabel ( const double  xPos,
const double  yPos,
const std::string &  status = "Internal" 
)

Create a ATLAS label.

Parameters
xPosx-position of the label on the Canvas
yPosy-position of the label on the Canvas
statusATLAS label status to be drawn

Definition at line 72 of file VisualizationHelpers.cxx.

73  {
74  return drawLabel( "#font[72]{ATLAS} "+status, xPos, yPos);
75  }

◆ drawBox() [1/2]

std::unique_ptr< TBox > MuonValR4::drawBox ( const Amg::Vector3D boxCenter,
const double  boxWidth,
const double  boxHeight,
const int  color = kGreen +2,
const int  fillStyle = hollowFilling,
const int  view = objViewEta 
)

Creates a box for drawing, e.g strip measurements.

Parameters
boxCenterCenter of the box to be placed expressed in chamber frame coordinates
boxWidthWidth of the drawn box
boxHeightHeight of the drawn box
colorColor of the surrounding line & filling
fillStyleBox fill style
viewIs the box placed in the y-z or in the x-z plane

Definition at line 41 of file VisualizationHelpers.cxx.

44  {
45  return drawBox(boxCenter[view] - 0.5*boxWidth, boxCenter.z() - 0.5*boxHeight,
46  boxCenter[view] + 0.5*boxWidth, boxCenter.z() + 0.5*boxHeight,
47  color, fillStyle);
48  }

◆ drawBox() [2/2]

std::unique_ptr< TBox > MuonValR4::drawBox ( const double  x1,
const double  y1,
const double  x2,
const double  y2,
const int  color = kGreen +2,
const int  fillStyle = hollowFilling 
)

Creates a box for drawing, e.g strip measurements.

Parameters
x1Left edge location
y1Bottom edge location
x2Right edge location
y2TopEdgeLocation
colorColor of the surrounding line & filling
fillStyleBox fill style
viewIs the box placed in the y-z or in the x-z plane

Definition at line 49 of file VisualizationHelpers.cxx.

51  {
52  auto box = std::make_unique<TBox>(x1,y1,x2,y2);
53  box->SetFillColor(color);
54  box->SetLineColor(color);
55  box->SetFillStyle(fillStyle);
56  box->SetFillColorAlpha(color, 0.8);
57  return box;
58  }

◆ drawDriftCircle()

std::unique_ptr< TEllipse > MuonValR4::drawDriftCircle ( const Amg::Vector3D center,
const double  radius,
const int  color = kViolet,
const int  fillStyle = hollowFilling 
)

Create a TEllipse for drawing a drift circle.

Parameters
centerPosition of the drift cirle expressed in the chambers frame y-coordinate corresponds to the tube layer z-coordinate corresponds to the tube in the layer
radiusRadius of the drift circle to draw
colorColor of the circle to draw
fillStyleStyle to pick the filling of the circle

Definition at line 12 of file VisualizationHelpers.cxx.

14  {
15  auto ellipse = std::make_unique<TEllipse>(center.y(), center.z(), radius);
16  ellipse->SetLineColor(color);
17  ellipse->SetFillStyle(fillStyle);
18  ellipse->SetLineWidth(1);
19  ellipse->SetFillColorAlpha(color, 0.2);
20  return ellipse;
21  }

◆ drawLabel()

std::unique_ptr< TLatex > MuonValR4::drawLabel ( const std::string &  text,
const double  xPos,
const double  yPos,
const unsigned int  fontSize = 18 
)

Create a TLatex label,.

Parameters
textLabel text
xPosx-position of the label on the Canvas
yPosy-position of the label on the Canvas
fontSizeSize of the label font

Definition at line 32 of file VisualizationHelpers.cxx.

34  {
35  auto tl = std::make_unique<TLatex>(xPos, yPos, text.c_str());
36  tl->SetNDC();
37  tl->SetTextFont(43);
38  tl->SetTextSize(fontSize);
39  return tl;
40  }

◆ drawLine()

std::unique_ptr<TLine> MuonValR4::drawLine ( const MuonR4::SegmentFit::Parameters pars,
const double  lowEnd,
const double  highEnd,
const int  color = kRed +1,
const int  lineStyle = kDashed,
const int  view = objViewEta 
)

Draws a line from the segment fit parameters.

Parameters
parsSegment fit parameters to extract position & direction from
lowEndLower boundary in Canvas-y of the line
highEndUpper boundaty in Canbas-y of the line
colorColor of the line (Cf. TColor documentation)
lineStyleStyle of the drawn line (cf. TAttLine documentation)
viewIs the line placed in the y-z or in the x-z plane

Definition at line 59 of file VisualizationHelpers.cxx.

62  {
63  const auto [pos, dir] = makeLine(pars);
64  const double x1 = (pos + Amg::intersect<3>(pos,dir,Amg::Vector3D::UnitZ(), lowEnd).value_or(0.)* dir)[view];
65  const double x2 = (pos + Amg::intersect<3>(pos,dir,Amg::Vector3D::UnitZ(), highEnd).value_or(0.)* dir)[view];
66  auto seedLine = std::make_unique<TLine>(x1, lowEnd, x2, highEnd);
67  seedLine->SetLineColor(color);
68  seedLine->SetLineWidth(2);
69  seedLine->SetLineStyle(lineStyle);
70  return seedLine;
71  }

◆ drawLumiSqrtS()

std::unique_ptr< TLatex > MuonValR4::drawLumiSqrtS ( const double  xPos,
const double  yPos,
const std::string_view  sqrtS = "14",
const std::string_view  lumi = "" 
)

Create a luminosity sqrtS label.

Parameters
xPosx-position of the label on the Canvas
yPosy-position of the label on the Canvas
sqrtSCentre of mass energy [TeV]
lumiLuminosity [fb^{-1}]. If less <0 not drawn

Definition at line 76 of file VisualizationHelpers.cxx.

79  {
80  return drawLabel(std::format("#sqrt{{s}}={0} TeV {1}{2}", sqrtS, lumi, lumi.empty() ? "" : "fb^{-1}"), xPos, yPos);
81  }

◆ isPrecHit()

template<class SpType >
bool MuonValR4::isPrecHit ( const SpType &  sp)

Define a spacepoint as precision hit if it's a Mdt or NSW eta hit.

Definition at line 48 of file MuonHoughTransformTester.cxx.

48  {
49  return sp.type() == xAOD::UncalibMeasType::MdtDriftCircleType ||
51  (sp.type() == xAOD::UncalibMeasType::sTgcStripType && sp.measuresEta());
52  }

Variable Documentation

◆ fullFilling

constexpr int MuonValR4::fullFilling = 1001
constexpr

Definition at line 21 of file VisualizationHelpers.h.

◆ hatchedFilling

constexpr int MuonValR4::hatchedFilling = 3344
constexpr

Definition at line 22 of file VisualizationHelpers.h.

◆ hollowFilling

constexpr int MuonValR4::hollowFilling = 0
constexpr

Filling codes for hollow / fullFilling / hatched filling.

Definition at line 20 of file VisualizationHelpers.h.

◆ objViewEta

constexpr int MuonValR4::objViewEta = Acts::toUnderlying(MuonR4::SegmentFit::AxisDefs::etaCov)
constexpr

ObjectView.

Definition at line 25 of file VisualizationHelpers.h.

◆ objViewPhi

constexpr int MuonValR4::objViewPhi = Acts::toUnderlying(MuonR4::SegmentFit::AxisDefs::phiCov)
constexpr

Definition at line 26 of file VisualizationHelpers.h.

make_hlt_rep.pars
pars
Definition: make_hlt_rep.py:90
plotBeamSpotCompare.x1
x1
Definition: plotBeamSpotCompare.py:215
xAOD::MuonSimHit_v1
Definition: MuonSimHit_v1.h:18
color
Definition: jFexInputByteStreamTool.cxx:25
vtune_athena.format
format
Definition: vtune_athena.py:14
mergePhysValFiles.start
start
Definition: DataQuality/DataQualityUtils/scripts/mergePhysValFiles.py:13
plotBeamSpotCompare.x2
x2
Definition: plotBeamSpotCompare.py:217
xAOD::UncalibMeasType::MMClusterType
@ MMClusterType
MuonValR4::drawBox
std::unique_ptr< TBox > drawBox(const Amg::Vector3D &boxCenter, const double boxWidth, const double boxHeight, const int color=kGreen+2, const int fillStyle=hollowFilling, const int view=objViewEta)
Creates a box for drawing, e.g strip measurements.
Definition: VisualizationHelpers.cxx:41
xAOD::UncalibMeasType::sTgcStripType
@ sTgcStripType
MuonR4::SegmentFit::makeLine
std::pair< Amg::Vector3D, Amg::Vector3D > makeLine(const Parameters &pars)
Returns the parsed parameters into an Eigen line parametrization.
Definition: SegmentFitterEventData.cxx:35
MuonValR4::drawLabel
std::unique_ptr< TLatex > drawLabel(const std::string &text, const double xPos, const double yPos, const unsigned int fontSize=18)
Create a TLatex label,.
Definition: VisualizationHelpers.cxx:32
makeTRTBarrelCans.y1
tuple y1
Definition: makeTRTBarrelCans.py:15
mergePhysValFiles.end
end
Definition: DataQuality/DataQualityUtils/scripts/mergePhysValFiles.py:92
cm
const double cm
Definition: Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimParametrization/tools/FCAL_ChannelMap.cxx:25
MuonValR4::countMatched
unsigned int countMatched(const xAOD::MuonSegment *truthSeg, const MuonR4::Segment *segment)
Definition: MuonHoughTransformTester.cxx:42
makeTRTBarrelCans.y2
tuple y2
Definition: makeTRTBarrelCans.py:18
beamspotman.dir
string dir
Definition: beamspotman.py:619
python.ElectronD3PDObject.matched
matched
Definition: ElectronD3PDObject.py:138
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
ParticleGun_SamplingFraction.radius
radius
Definition: ParticleGun_SamplingFraction.py:96
python.LumiBlobConversion.pos
pos
Definition: LumiBlobConversion.py:16
lumiFormat.lumi
lumi
Definition: lumiFormat.py:106
makeTransCanvas.text
text
Definition: makeTransCanvas.py:11
merge.status
status
Definition: merge.py:16
dqt_zlumi_alleff_HIST.tl
tl
Definition: dqt_zlumi_alleff_HIST.py:73
xAOD::UncalibMeasType::MdtDriftCircleType
@ MdtDriftCircleType
MuonR4::getMatchingSimHits
std::unordered_set< const xAOD::MuonSimHit * > getMatchingSimHits(const xAOD::MuonSegment &segment)
: Returns all sim hits matched to a xAOD::MuonSegment
Definition: MuonSimHitHelpers.cxx:38
MuonSegmentReaderConfig.reco
reco
Definition: MuonSegmentReaderConfig.py:133
drawFromPickle.view
view
Definition: drawFromPickle.py:294