src
RecoParticleFlow
PFProducer
plugins
importers
NuclearInteractionTrackImporter.cc
Go to the documentation of this file.
1
#include "
TrackFromParentImporter.h
"
2
#include "
DataFormats/ParticleFlowReco/interface/PFDisplacedTrackerVertex.h
"
3
4
namespace
{
5
class
NuclAdaptor {
6
public
:
7
static
bool
check_importable(
const
reco::PFDisplacedTrackerVertexCollection::value_type
&
t
) {
8
const
auto
&
vtx
=
t
.displacedVertexRef();
9
return
(
vtx
->isNucl() &&
vtx
->position().rho() > 2.7);
10
}
11
static
const
reco::PFRecTrackRefVector
& get_track_refs(
12
const
reco::PFDisplacedTrackerVertexCollection::value_type
&
t
) {
13
return
t
.pfRecTracks();
14
}
15
static
void
set_element_info(
reco::PFBlockElement
* elem,
16
const
edm::Ref<reco::PFDisplacedTrackerVertexCollection>
& parref) {
17
const
reco::PFBlockElementTrack
* tkelem =
static_cast<
const
reco::PFBlockElementTrack
*
>
(elem);
18
const
reco::PFRecTrackRef
& reftrack = tkelem->
trackRefPF
();
19
reco::PFBlockElement::TrackType
tkType =
reco::PFBlockElement::DEFAULT
;
20
if
(parref->isIncomingTrack(reftrack))
21
tkType =
reco::PFBlockElement::T_TO_DISP
;
22
else
if
(parref->isOutgoingTrack(reftrack))
23
tkType =
reco::PFBlockElement::T_FROM_DISP
;
24
elem->
setDisplacedVertexRef
(parref, tkType);
25
}
26
};
27
}
// namespace
28
29
typedef
pflow::importers::TrackFromParentImporter<reco::PFDisplacedTrackerVertexCollection, NuclAdaptor>
30
NuclearInteractionTrackImporter
;
31
32
DEFINE_EDM_PLUGIN
(
BlockElementImporterFactory
,
NuclearInteractionTrackImporter
,
"NuclearInteractionTrackImporter"
);
reco::PFBlockElement
Abstract base class for a PFBlock element (track, cluster...)
Definition:
PFBlockElement.h:26
pflow::importers::TrackFromParentImporter
Definition:
TrackFromParentImporter.h:27
submitPVValidationJobs.t
string t
Definition:
submitPVValidationJobs.py:650
edm::Ref
Definition:
AssociativeIterator.h:58
reco::PFBlockElement::TrackType
TrackType
Definition:
PFBlockElement.h:47
L1BJetProducer_cff.vtx
vtx
Definition:
L1BJetProducer_cff.py:10
TrackFromParentImporter.h
reco::JetExtendedAssociation::value_type
Container::value_type value_type
Definition:
JetExtendedAssociation.h:30
PFDisplacedTrackerVertex.h
edmplugin::PluginFactory
Definition:
PluginFactory.h:35
reco::PFBlockElement::T_TO_DISP
Definition:
PFBlockElement.h:47
reco::PFBlockElement::setDisplacedVertexRef
virtual void setDisplacedVertexRef(const PFDisplacedTrackerVertexRef &niref, TrackType trType)
Definition:
PFBlockElement.h:95
NuclearInteractionTrackImporter
pflow::importers::TrackFromParentImporter< reco::PFDisplacedTrackerVertexCollection, NuclAdaptor > NuclearInteractionTrackImporter
Definition:
NuclearInteractionTrackImporter.cc:30
edm::RefVector< PFRecTrackCollection >
reco::PFBlockElement::T_FROM_DISP
Definition:
PFBlockElement.h:47
DEFINE_EDM_PLUGIN
#define DEFINE_EDM_PLUGIN(factory, type, name)
Definition:
PluginFactory.h:123
reco::PFBlockElementTrack::trackRefPF
const PFRecTrackRef & trackRefPF() const override
Definition:
PFBlockElementTrack.h:46
reco::PFBlockElement::DEFAULT
Definition:
PFBlockElement.h:47
reco::PFBlockElementTrack
Track Element.
Definition:
PFBlockElementTrack.h:17
Generated for CMSSW Reference Manual by
1.8.14