ATLAS Offline Software
Tracking
TrkEvent
TrkEventUtils
src
IdentifierExtractor.cxx
Go to the documentation of this file.
1
/*
2
Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
3
*/
4
6
// IdentifierExtractor.cxx, (c) ATLAS Detector software //
8
9
#include "
TrkEventUtils/IdentifierExtractor.h
"
10
#include "
TrkCompetingRIOsOnTrack/CompetingRIOsOnTrack.h
"
11
#include "
TrkMeasurementBase/MeasurementBase.h
"
12
13
void
Trk::IdentifierExtractor::extract
(std::vector<Identifier>&
ids
,
const
std::vector<const Trk::MeasurementBase*>& measurements)
14
{
15
using namespace
std;
16
vector<const Trk::MeasurementBase*>::const_iterator
it
= measurements.begin();
17
vector<const Trk::MeasurementBase*>::const_iterator itEnd = measurements.end();
18
ids
.clear();
19
for
(;
it
!=itEnd ; ++
it
)
20
{
21
Identifier
id
=
extract
(*
it
);
22
if
(
id
.is_valid() ) {
ids
.push_back(
id
);}
23
}
24
}
25
26
Identifier
Trk::IdentifierExtractor::extract
(
const
Trk::MeasurementBase
*
m
)
27
{
28
Identifier
id
;
29
const
Trk::RIO_OnTrack
*rot =
dynamic_cast<
const
Trk::RIO_OnTrack
*
>
(
m
);
30
if
(rot) {
31
id
= rot->
identify
();
32
}
else
{
33
// identify by CompetingROT:
34
const
Trk::CompetingRIOsOnTrack
* comprot =
dynamic_cast<
const
Trk::CompetingRIOsOnTrack
*
>
(
m
);
35
if
(comprot) {
36
id
= comprot->
rioOnTrack
(comprot->
indexOfMaxAssignProb
()).identify();
37
}
else
{
38
id
.clear();
39
}
40
}
41
return
id
;
42
}
43
python.SystemOfUnits.m
int m
Definition:
SystemOfUnits.py:91
MeasurementBase.h
CompetingRIOsOnTrack.h
skel.it
it
Definition:
skel.GENtoEVGEN.py:423
Trk::RIO_OnTrack
Definition:
RIO_OnTrack.h:70
IdentifierExtractor.h
Trk::CompetingRIOsOnTrack::rioOnTrack
virtual const RIO_OnTrack & rioOnTrack(unsigned int) const =0
returns the RIO_OnTrack (also known as ROT) objects depending on the integer.
Trk::CompetingRIOsOnTrack
Base class for all CompetingRIOsOnTack implementations, extends the common MeasurementBase.
Definition:
CompetingRIOsOnTrack.h:64
Trk::MeasurementBase
Definition:
MeasurementBase.h:58
id
SG::auxid_t id
Definition:
Control/AthContainers/Root/debug.cxx:191
python.subdetectors.mmg.ids
ids
Definition:
mmg.py:8
Trk::IdentifierExtractor::extract
static void extract(std::vector< Identifier > &ids, const std::vector< const MeasurementBase * > &measurements)
Definition:
IdentifierExtractor.cxx:13
Trk::RIO_OnTrack::identify
virtual Identifier identify() const final
return the identifier -extends MeasurementBase
Definition:
RIO_OnTrack.h:155
Trk::CompetingRIOsOnTrack::indexOfMaxAssignProb
unsigned int indexOfMaxAssignProb() const
Index of the ROT with the highest assignment probability.
Definition:
CompetingRIOsOnTrack.cxx:101
Generated on Sun Jun 30 2024 21:17:14 for ATLAS Offline Software by
1.8.18