CMS 3D CMS Logo

MuonDxyCut.cc
Go to the documentation of this file.
6 
8 public:
10 
11  result_type operator()(const reco::MuonPtr&) const final;
12  CandidateType candidateType() const final { return MUON; }
13  double value(const reco::CandidatePtr&) const final;
14 
16  void getEventContent(const edm::EventBase&) final;
17 
18 private:
20  const double maxDxy_;
22 };
24 
25 // Define constructors and initialization routines
27  : CutApplicatorWithEventContentBase(c), maxDxy_(c.getParameter<double>("maxDxy")) {
28  const std::string trackTypeName = c.getParameter<std::string>("trackType");
29  trackType_ = NONE;
30  if (trackTypeName == "muonBestTrack")
32  else if (trackTypeName == "innerTrack")
34  else {
35  edm::LogError("MuonDxyCut") << "Wrong cut id name, " << trackTypeName
36  << "Choose among \"muonBestTrack\", \"innerTrack\"";
37  trackType_ = NONE;
38  }
39 
40  contentTags_.emplace("vertices", c.getParameter<edm::InputTag>("vertexSrc"));
41  contentTags_.emplace("verticesMiniAOD", c.getParameter<edm::InputTag>("vertexSrcMiniAOD"));
42 }
43 
45  contentTokens_.emplace("vertices", cc.consumes<reco::VertexCollection>(contentTags_["vertices"]));
46  contentTokens_.emplace("verticesMiniAOD", cc.consumes<reco::VertexCollection>(contentTags_["verticesMiniAOD"]));
47 }
48 
50  ev.getByLabel(contentTags_["vertices"], vtxs_);
51  if (!vtxs_.isValid())
52  ev.getByLabel(contentTags_["verticesMiniAOD"], vtxs_);
53 }
54 
55 // Functors for evaluation
57  const auto& vtxPos = vtxs_->at(0).position();
58 
59  reco::TrackRef trackRef;
60  if (trackType_ == INNERTRACK)
61  trackRef = cand->innerTrack();
62  else if (trackType_ == MUONBESTTRACK)
63  trackRef = cand->muonBestTrack();
64 
65  return trackRef.isNonnull() and std::abs(trackRef->dxy(vtxPos)) <= maxDxy_;
66 }
67 
69  const reco::MuonPtr muon(cand);
70  reco::TrackRef trackRef;
71  if (trackType_ == INNERTRACK)
72  trackRef = muon->innerTrack();
73  else if (trackType_ == MUONBESTTRACK)
74  trackRef = muon->muonBestTrack();
75  if (trackRef.isNull())
76  return -1;
77 
78  const auto& vtxPos = vtxs_->at(0).position();
79  return std::abs(trackRef->dxy(vtxPos));
80 }
MuonDxyCut::BestTrackType
BestTrackType
Definition: MuonDxyCut.cc:21
MuonDxyCut::vtxs_
edm::Handle< reco::VertexCollection > vtxs_
Definition: MuonDxyCut.cc:19
Muon.h
MessageLogger.h
MuonDxyCut::maxDxy_
const double maxDxy_
Definition: MuonDxyCut.cc:20
muon
Definition: MuonCocktails.h:17
edm::Ref::isNull
bool isNull() const
Checks for null.
Definition: Ref.h:235
reco::VertexCollection
std::vector< Vertex > VertexCollection
collection of Vertex objects
Definition: VertexFwd.h:9
MuonDxyCut::MUONBESTTRACK
Definition: MuonDxyCut.cc:21
MuonDxyCut::operator()
result_type operator()(const reco::MuonPtr &) const final
Definition: MuonDxyCut.cc:56
watchdog.const
const
Definition: watchdog.py:83
edm::Handle< reco::VertexCollection >
edm::Ref< TrackCollection >
CutApplicatorWithEventContentBase::contentTags_
std::unordered_map< std::string, edm::InputTag > contentTags_
Definition: CutApplicatorWithEventContentBase.h:35
candidate_functions::CandidateCut::result_type
bool result_type
Definition: CandidateCut.h:11
MuonDxyCut::setConsumes
void setConsumes(edm::ConsumesCollector &) final
Definition: MuonDxyCut.cc:44
MuonDxyCut::INNERTRACK
Definition: MuonDxyCut.cc:21
HLT_FULL_cff.muon
muon
Definition: HLT_FULL_cff.py:11725
MuonSelectors.h
CutApplicatorWithEventContentBase.h
DEFINE_EDM_PLUGIN
#define DEFINE_EDM_PLUGIN(factory, type, name)
Definition: PluginFactory.h:124
CutApplicatorBase::MUON
Definition: CutApplicatorBase.h:47
MuonDxyCut
Definition: MuonDxyCut.cc:7
edm::ParameterSet
Definition: ParameterSet.h:47
CutApplicatorBase::CandidateType
CandidateType
Definition: CutApplicatorBase.h:47
edmplugin::PluginFactory
Definition: PluginFactory.h:34
edm::Ref::isNonnull
bool isNonnull() const
Checks for non-null.
Definition: Ref.h:238
cand
Definition: decayParser.h:32
MuonDxyCut::value
double value(const reco::CandidatePtr &) const final
Definition: MuonDxyCut.cc:68
MuonDxyCut::NONE
Definition: MuonDxyCut.cc:21
edm::LogError
Log< level::Error, false > LogError
Definition: MessageLogger.h:123
cc
MuonDxyCut::getEventContent
void getEventContent(const edm::EventBase &) final
Definition: MuonDxyCut.cc:49
AlCaHLTBitMon_QueryRunRegistry.string
string string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
edm::Ptr< reco::Muon >
ev
bool ev
Definition: Hydjet2Hadronizer.cc:97
CutApplicatorWithEventContentBase::contentTokens_
std::unordered_map< std::string, edm::EDGetToken > contentTokens_
Definition: CutApplicatorWithEventContentBase.h:40
edm::EventBase
Definition: EventBase.h:46
MuonDxyCut::MuonDxyCut
MuonDxyCut(const edm::ParameterSet &c)
Definition: MuonDxyCut.cc:26
funct::abs
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
CutApplicatorBase.h
c
auto & c
Definition: CAHitNtupletGeneratorKernelsImpl.h:56
edm::HandleBase::isValid
bool isValid() const
Definition: HandleBase.h:70
edm::InputTag
Definition: InputTag.h:15
edm::ConsumesCollector
Definition: ConsumesCollector.h:45
MuonDxyCut::trackType_
enum MuonDxyCut::BestTrackType trackType_
CutApplicatorWithEventContentBase
Definition: CutApplicatorWithEventContentBase.h:19
MuonDxyCut::candidateType
CandidateType candidateType() const final
Definition: MuonDxyCut.cc:12