CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
CandidateSelector.cc
Go to the documentation of this file.
2 
3 using namespace edm;
4 using namespace reco;
5 using namespace susybsm;
6 
7 
8 
9 
11  isTrack = iConfig.getParameter<bool> ("onlyConsiderTrack");
12  isMuon = iConfig.getParameter<bool> ("onlyConsiderMuon");
13  isMuonSTA = iConfig.getParameter<bool> ("onlyConsiderMuonSTA");
14  isMuonGB = iConfig.getParameter<bool> ("onlyConsiderMuonGB");
15  isMuonTK = iConfig.getParameter<bool> ("onlyConsiderMuonTK");
16  isRpc = iConfig.getParameter<bool> ("onlyConsiderRpc");
17  isEcal = iConfig.getParameter<bool> ("onlyConsiderEcal");
18 
19  minTrackHits = iConfig.getParameter<int> ("minTrackHits");
20  minTrackP = iConfig.getParameter<double> ("minTrackP");
21  minTrackPt = iConfig.getParameter<double> ("minTrackPt");
22 
23  minDedx = iConfig.getParameter<double> ("minDedx");
24 
25  minMuonP = iConfig.getParameter<double> ("minMuonP");
26  minMuonPt = iConfig.getParameter<double> ("minMuonPt");
27 
28  maxMuTimeDtBeta = iConfig.getParameter<double> ("maxMuTimeDtBeta");
29  minMuTimeDtNdof = iConfig.getParameter<double> ("minMuTimeDtNdof");
30  maxMuTimeCscBeta = iConfig.getParameter<double> ("maxMuTimeCscBeta");
31  minMuTimeCscNdof = iConfig.getParameter<double> ("minMuTimeCscNdof");
32  maxMuTimeCombinedBeta = iConfig.getParameter<double> ("maxMuTimeCombinedBeta");
33  minMuTimeCombinedNdof = iConfig.getParameter<double> ("minMuTimeCombinedNdof");
34 
35  maxBetaRpc = iConfig.getParameter<double> ("maxBetaRpc");
36  maxBetaEcal = iConfig.getParameter<double> ("maxBetaEcal");
37 }
38 
39 
41 {
42  if(isTrack && !candidate.hasTrackRef()){return false;}
43  if(isMuon && !candidate.hasMuonRef() ){return false;}
44  if(isMuonSTA && (!candidate.hasMuonRef() || candidate.muonRef()->standAloneMuon().isNull()) ){return false;}
45  if(isMuonGB && (!candidate.hasMuonRef() || candidate.muonRef()->combinedMuon ().isNull()) ){return false;}
46  if(isMuonTK && (!candidate.hasMuonRef() || candidate.muonRef()->innerTrack ().isNull()) ){return false;}
47  if(isRpc && !candidate.hasRpcInfo() ){return false;}
48  if(isEcal && !candidate.hasCaloInfo()){return false;}
49 
50  if(candidate.hasTrackRef()){
51  if(candidate.trackRef()->found() < minTrackHits){return false;}
52  if(candidate.trackRef()->p() < minTrackP ){return false;}
53  if(candidate.trackRef()->pt() < minTrackPt ){return false;}
54 
55 // Need to be implemented using external dE/dx object
56 // if(candidate.hasDedxEstim1() && minDedxEstimator1>=0 && candidate.dedxEstimator1 ().dEdx()<minDedxEstimator1) {return false;}
57 // if(candidate.hasDedxDiscrim1() && minDedxDiscriminator1>=0 && candidate.dedxDiscriminator1().dEdx()<minDedxDiscriminator1){return false;}
58  }
59 
60  if(candidate.hasMuonRef()){
61  if(candidate.muonRef()->p() < minMuonP ){return false;}
62  if(candidate.muonRef()->pt() < minMuonPt ){return false;}
63 
64 // Need to be implemented using external timing object
65 // if(maxMuTimeDtBeta >=0 && 1.0/candidate.muonTimeDt().inverseBeta() > maxMuTimeDtBeta ){return false;}
66 // if(minMuTimeDtNdof >=0 && 1.0/candidate.muonTimeDt().nDof() < minMuTimeDtNdof ){return false;}
67 // if(maxMuTimeCscBeta >=0 && 1.0/candidate.muonTimeCsc().inverseBeta() > maxMuTimeCscBeta ){return false;}
68 // if(minMuTimeCscNdof >=0 && 1.0/candidate.muonTimeCsc().nDof() < minMuTimeCscNdof ){return false;}
69 // if(maxMuTimeCombinedBeta>=0 && 1.0/candidate.muonTimeCombined().inverseBeta() > maxMuTimeCombinedBeta){return false;}
70 // if(minMuTimeCombinedNdof>=0 && 1.0/candidate.muonTimeCombined().nDof() < minMuTimeCombinedNdof){return false;}
71  }
72 
73  if(candidate.hasRpcInfo() && maxBetaRpc>=0 && candidate.rpc ().beta > maxBetaRpc ){return false;}
74 
75 // Need to be implemented using external dE/dx object
76 // if(candidate.hasCaloInfo() && maxBetaEcal>=0 && candidate.calo().ecalBeta > maxBetaEcal){return false;}
77 
78  return true;
79 }
80 
T getParameter(std::string const &) const
bool isMuon(const Candidate &part)
Definition: pdgIdUtils.h:11
const RPCBetaMeasurement & rpc() const
Definition: HSCParticle.h:77
bool hasTrackRef() const
Definition: HSCParticle.h:57
bool isNull() const
Checks for null.
Definition: Ref.h:247
tuple minTrackPt
Definition: align_cfg.py:22
reco::MuonRef muonRef() const
Definition: HSCParticle.h:74
CandidateSelector(const edm::ParameterSet &iConfig)
reco::TrackRef trackRef() const
Definition: HSCParticle.h:72
bool hasRpcInfo() const
Definition: HSCParticle.h:59
tuple minTrackP
Definition: align_cfg.py:24
bool hasMuonRef() const
Definition: HSCParticle.h:55
bool hasCaloInfo() const
Definition: HSCParticle.h:60
bool isSelected(susybsm::HSCParticle &candidate)