CMS 3D CMS Logo

AnalyticalTrackSelector.cc
Go to the documentation of this file.
1 
11 #include <utility>
12 #include <vector>
13 #include <memory>
14 #include <algorithm>
15 #include <map>
20 
31 
32 #include "MultiTrackSelector.h"
33 
34 using namespace reco;
35 
37  private:
38  public:
40  explicit AnalyticalTrackSelector( const edm::ParameterSet & cfg ) ;
42  ~AnalyticalTrackSelector() override ;
43 
44  private:
47  void run( edm::Event& evt, const edm::EventSetup& es ) const override;
48 
54  double minEta_;
55  double maxEta_;
56 
59 
60 
61  };
62 
63 
64 
65 
67 
69 #include <Math/DistFunc.h>
70 #include "TMath.h"
71 
72 
74 {
75  //Spoof the pset for each track selector!
76  //Size is always 1!!!
77  qualityToSet_.reserve(1);
78  vtxNumber_.reserve(1);
79  vertexCut_.reserve(1);
80  res_par_.reserve(1);
81  chi2n_par_.reserve(1);
82  chi2n_no1Dmod_par_.reserve(1);
83  d0_par1_.reserve(1);
84  dz_par1_.reserve(1);
85  d0_par2_.reserve(1);
86  dz_par2_.reserve(1);
87  applyAdaptedPVCuts_.reserve(1);
88  max_d0_.reserve(1);
89  max_z0_.reserve(1);
90  nSigmaZ_.reserve(1);
91  min_layers_.reserve(1);
92  min_3Dlayers_.reserve(1);
93  max_lostLayers_.reserve(1);
94  min_hits_bypass_.reserve(1);
95  applyAbsCutsIfNoPV_.reserve(1);
96  max_d0NoPV_.reserve(1);
97  max_z0NoPV_.reserve(1);
98  preFilter_.reserve(1);
99  max_relpterr_.reserve(1);
100  min_nhits_.reserve(1);
101  max_minMissHitOutOrIn_.reserve(1);
102  max_lostHitFraction_.reserve(1);
103  min_eta_.reserve(1);
104  max_eta_.reserve(1);
105  forest_.reserve(1);
106  mvaType_.reserve(1);
107  useMVA_.reserve(1);
108 
109  produces<edm::ValueMap<float> >("MVAVals");
110  //foward compatibility
111  produces<MVACollection>("MVAValues");
112  useAnyMVA_ = false;
113  forest_[0] = nullptr;
114  if(cfg.exists("useAnyMVA")) useAnyMVA_ = cfg.getParameter<bool>("useAnyMVA");
115 
116  src_ = consumes<reco::TrackCollection>(cfg.getParameter<edm::InputTag>( "src" ));
117  hSrc_ = consumes<TrackingRecHitCollection>(cfg.getParameter<edm::InputTag>( "src" ));
118  beamspot_ = consumes<reco::BeamSpot>(cfg.getParameter<edm::InputTag>( "beamspot" ));
119  useVertices_ = cfg.getParameter<bool>( "useVertices" );
120  useVtxError_ = cfg.getParameter<bool>( "useVtxError" );
121  if (useVertices_) vertices_ = consumes<reco::VertexCollection>(cfg.getParameter<edm::InputTag>( "vertices" ));
122  copyExtras_ = cfg.getUntrackedParameter<bool>("copyExtras", false);
123  copyTrajectories_ = cfg.getUntrackedParameter<bool>("copyTrajectories", false);
124  if (copyTrajectories_) {
125  srcTraj_ = consumes<std::vector<Trajectory> >(cfg.getParameter<edm::InputTag>( "src" ));
126  srcTass_ = consumes<TrajTrackAssociationCollection>(cfg.getParameter<edm::InputTag>( "src" ));
127  }
128 
129  qualityToSet_.push_back( TrackBase::undefQuality );
130  // parameters for vertex selection
131  vtxNumber_.push_back( useVertices_ ? cfg.getParameter<int32_t>("vtxNumber") : 0 );
132  vertexCut_.push_back( useVertices_ ? cfg.getParameter<std::string>("vertexCut") : "");
133  // parameters for adapted optimal cuts on chi2 and primary vertex compatibility
134  res_par_.push_back(cfg.getParameter< std::vector<double> >("res_par") );
135  chi2n_par_.push_back( cfg.getParameter<double>("chi2n_par") );
136  chi2n_no1Dmod_par_.push_back( cfg.getParameter<double>("chi2n_no1Dmod_par") );
137  d0_par1_.push_back(cfg.getParameter< std::vector<double> >("d0_par1"));
138  dz_par1_.push_back(cfg.getParameter< std::vector<double> >("dz_par1"));
139  d0_par2_.push_back(cfg.getParameter< std::vector<double> >("d0_par2"));
140  dz_par2_.push_back(cfg.getParameter< std::vector<double> >("dz_par2"));
141 
142  // Boolean indicating if adapted primary vertex compatibility cuts are to be applied.
143  applyAdaptedPVCuts_.push_back(cfg.getParameter<bool>("applyAdaptedPVCuts"));
144  // Impact parameter absolute cuts.
145  max_d0_.push_back(cfg.getParameter<double>("max_d0"));
146  max_z0_.push_back(cfg.getParameter<double>("max_z0"));
147  nSigmaZ_.push_back(cfg.getParameter<double>("nSigmaZ"));
148  // Cuts on numbers of layers with hits/3D hits/lost hits.
149  min_layers_.push_back(cfg.getParameter<uint32_t>("minNumberLayers") );
150  min_3Dlayers_.push_back(cfg.getParameter<uint32_t>("minNumber3DLayers") );
151  max_lostLayers_.push_back(cfg.getParameter<uint32_t>("maxNumberLostLayers"));
152  min_hits_bypass_.push_back(cfg.getParameter<uint32_t>("minHitsToBypassChecks"));
153  max_relpterr_.push_back(cfg.getParameter<double>("max_relpterr"));
154  min_nhits_.push_back(cfg.getParameter<uint32_t>("min_nhits"));
155  max_minMissHitOutOrIn_.push_back(
156  cfg.existsAs<int32_t>("max_minMissHitOutOrIn") ?
157  cfg.getParameter<int32_t>("max_minMissHitOutOrIn") : 99);
158  max_lostHitFraction_.push_back(
159  cfg.existsAs<double>("max_lostHitFraction") ?
160  cfg.getParameter<double>("max_lostHitFraction") : 1.0);
161  min_eta_.push_back(cfg.getParameter<double>("min_eta"));
162  max_eta_.push_back(cfg.getParameter<double>("max_eta"));
163 
164  // Flag to apply absolute cuts if no PV passes the selection
165  applyAbsCutsIfNoPV_.push_back(cfg.getParameter<bool>("applyAbsCutsIfNoPV"));
166  keepAllTracks_.push_back( cfg.exists("keepAllTracks") ?
167  cfg.getParameter<bool>("keepAllTracks") :
168  false );
169 
170  setQualityBit_.push_back( false );
171  std::string qualityStr = cfg.getParameter<std::string>("qualityBit");
172 
173  if(d0_par1_[0].size()!=2 || dz_par1_[0].size()!=2 || d0_par2_[0].size()!=2 || dz_par2_[0].size()!=2)
174  {
175  edm::LogError("MisConfiguration")<<"vector of size less then 2";
176  throw;
177  }
178 
179  if (cfg.exists("qualityBit")) {
180  std::string qualityStr = cfg.getParameter<std::string>("qualityBit");
181  if (qualityStr != "") {
182  setQualityBit_[0] = true;
183  qualityToSet_ [0] = TrackBase::qualityByName(cfg.getParameter<std::string>("qualityBit"));
184  }
185  }
186 
187  if (keepAllTracks_[0] && !setQualityBit_[0]) throw cms::Exception("Configuration") <<
188  "If you set 'keepAllTracks' to true, you must specify which qualityBit to set.\n";
189  if (setQualityBit_[0] && (qualityToSet_[0] == TrackBase::undefQuality)) throw cms::Exception("Configuration") <<
190  "You can't set the quality bit " << cfg.getParameter<std::string>("qualityBit") << " as it is 'undefQuality' or unknown.\n";
191  if (applyAbsCutsIfNoPV_[0]) {
192  max_d0NoPV_.push_back(cfg.getParameter<double>("max_d0NoPV"));
193  max_z0NoPV_.push_back(cfg.getParameter<double>("max_z0NoPV"));
194  }
195  else{//dummy values
196  max_d0NoPV_.push_back(0.);
197  max_z0NoPV_.push_back(0.);
198  }
199 
200  if(useAnyMVA_){
201  bool thisMVA = false;
202  if(cfg.exists("useMVA"))thisMVA = cfg.getParameter<bool>("useMVA");
203  useMVA_.push_back(thisMVA);
204  if(thisMVA){
205  double minVal = -1;
206  if(cfg.exists("minMVA"))minVal = cfg.getParameter<double>("minMVA");
207  min_MVA_.push_back(minVal);
208  mvaType_.push_back(cfg.exists("mvaType") ? cfg.getParameter<std::string>("mvaType") : "Detached");
209  forestLabel_.push_back(cfg.exists("GBRForestLabel") ? cfg.getParameter<std::string>("GBRForestLabel") : "MVASelectorIter0");
210  useMVAonly_.push_back(cfg.exists("useMVAonly") ? cfg.getParameter<bool>("useMVAonly") : false);
211  }else{
212  min_MVA_.push_back(-9999.0);
213  useMVAonly_.push_back(false);
214  mvaType_.push_back("Detached");
215  forestLabel_.push_back("MVASelectorIter0");
216  }
217  }else{
218  useMVA_.push_back(false);
219  useMVAonly_.push_back(false);
220  min_MVA_.push_back(-9999.0);
221  mvaType_.push_back("Detached");
222  forestLabel_.push_back("MVASelectorIter0");
223  }
224 
225  std::string alias( cfg.getParameter<std::string>( "@module_label" ) );
226  produces<reco::TrackCollection>().setBranchAlias( alias + "Tracks");
227  if (copyExtras_) {
228  produces<reco::TrackExtraCollection>().setBranchAlias( alias + "TrackExtras");
229  produces<TrackingRecHitCollection>().setBranchAlias( alias + "RecHits");
230  }
231  if (copyTrajectories_) {
232  produces< std::vector<Trajectory> >().setBranchAlias( alias + "Trajectories");
233  produces< TrajTrackAssociationCollection >().setBranchAlias( alias + "TrajectoryTrackAssociations");
234  }
235 }
236 
238 }
239 
240 
242 {
243 
244  // storage....
245  std::unique_ptr<reco::TrackCollection> selTracks_;
246  std::unique_ptr<reco::TrackExtraCollection> selTrackExtras_;
247  std::unique_ptr<TrackingRecHitCollection> selHits_;
248  std::unique_ptr<std::vector<Trajectory> > selTrajs_;
249  std::unique_ptr<std::vector<const Trajectory *> > selTrajPtrs_;
250  std::unique_ptr<TrajTrackAssociationCollection > selTTAss_;
251  reco::TrackRefProd rTracks_;
252  reco::TrackExtraRefProd rTrackExtras_;
253  TrackingRecHitRefProd rHits_;
254  edm::RefProd< std::vector<Trajectory> > rTrajectories_;
255  std::vector<reco::TrackRef> trackRefs_;
256 
257 
258  using namespace std;
259  using namespace edm;
260  using namespace reco;
261 
262  Handle<TrackCollection> hSrcTrack;
266 
267  // looking for the beam spot
269  evt.getByToken(beamspot_, hBsp);
270  reco::BeamSpot vertexBeamSpot;
271  vertexBeamSpot = *hBsp;
272 
273  // Select good primary vertices for use in subsequent track selection
275  std::vector<Point> points;
276  std::vector<float> vterr, vzerr;
277  if (useVertices_) {
278  evt.getByToken(vertices_, hVtx);
279  selectVertices(0,*hVtx, points, vterr, vzerr);
280  // Debug
281  LogDebug("SelectVertex") << points.size() << " good pixel vertices";
282  }
283 
284  // Get tracks
285  evt.getByToken( src_, hSrcTrack );
286  // get hits in track..
288  evt.getByToken( hSrc_, hSrcHits );
289  const TrackingRecHitCollection & srcHits(*hSrcHits);
290 
291 
292 
293  selTracks_ = std::make_unique<TrackCollection>();
294  rTracks_ = evt.getRefBeforePut<TrackCollection>();
295  if (copyExtras_) {
296  selTrackExtras_ = std::make_unique<TrackExtraCollection>();
297  selHits_ = std::make_unique<TrackingRecHitCollection>();
299  rTrackExtras_ = evt.getRefBeforePut<TrackExtraCollection>();
300  }
301 
302  if (copyTrajectories_) trackRefs_.resize(hSrcTrack->size());
303 
304  std::vector<float> mvaVals_(hSrcTrack->size(),-99.f);
305  processMVA(evt,es,vertexBeamSpot,*(hVtx.product()),0,mvaVals_,true);
306 
307  // Loop over tracks
308  size_t current = 0;
309  for (TrackCollection::const_iterator it = hSrcTrack->begin(), ed = hSrcTrack->end(); it != ed; ++it, ++current) {
310  const Track & trk = * it;
311  // Check if this track passes cuts
312 
313  LogTrace("TrackSelection") << "ready to check track with pt="<< trk.pt() ;
314 
315  float mvaVal = 0;
316  if(useAnyMVA_)mvaVal = mvaVals_[current];
317  bool ok = select(0,vertexBeamSpot, srcHits, trk, points, vterr, vzerr,mvaVal);
318  if (!ok) {
319 
320  LogTrace("TrackSelection") << "track with pt="<< trk.pt() << " NOT selected";
321 
322  if (copyTrajectories_) trackRefs_[current] = reco::TrackRef();
323  if (!keepAllTracks_[0]) continue;
324  }
325  LogTrace("TrackSelection") << "track with pt="<< trk.pt() << " selected";
326  selTracks_->push_back( Track( trk ) ); // clone and store
327  if (ok && setQualityBit_[0]) {
328  selTracks_->back().setQuality(qualityToSet_[0]);
329  if (qualityToSet_[0]==TrackBase::tight) {
330  selTracks_->back().setQuality(TrackBase::loose);
331  }
332  else if (qualityToSet_[0]==TrackBase::highPurity) {
333  selTracks_->back().setQuality(TrackBase::loose);
334  selTracks_->back().setQuality(TrackBase::tight);
335  }
336  if (!points.empty()) {
337  if (qualityToSet_[0]==TrackBase::loose) {
338  selTracks_->back().setQuality(TrackBase::looseSetWithPV);
339  }
340  else if (qualityToSet_[0]==TrackBase::highPurity) {
341  selTracks_->back().setQuality(TrackBase::looseSetWithPV);
342  selTracks_->back().setQuality(TrackBase::highPuritySetWithPV);
343  }
344  }
345  }
346  if (copyExtras_) {
347  // TrackExtras
348  selTrackExtras_->push_back( TrackExtra( trk.outerPosition(), trk.outerMomentum(), trk.outerOk(),
349  trk.innerPosition(), trk.innerMomentum(), trk.innerOk(),
350  trk.outerStateCovariance(), trk.outerDetId(),
351  trk.innerStateCovariance(), trk.innerDetId(),
352  trk.seedDirection(), trk.seedRef() ) );
353  selTracks_->back().setExtra( TrackExtraRef( rTrackExtras_, selTrackExtras_->size() - 1) );
354  TrackExtra & tx = selTrackExtras_->back();
355  tx.setResiduals(trk.residuals());
356  // TrackingRecHits
357  auto const firstHitIndex = selHits_->size();
358  for( trackingRecHit_iterator hit = trk.recHitsBegin(); hit != trk.recHitsEnd(); ++ hit ) {
359  selHits_->push_back( (*hit)->clone() );
360  }
361  tx.setHits( rHits_, firstHitIndex, selHits_->size() - firstHitIndex);
362  tx.setTrajParams(trk.extra()->trajParams(),trk.extra()->chi2sX5());
363  }
364  if (copyTrajectories_) {
365  trackRefs_[current] = TrackRef(rTracks_, selTracks_->size() - 1);
366  }
367  }
368  if ( copyTrajectories_ ) {
371  evt.getByToken(srcTass_, hTTAss);
372  evt.getByToken(srcTraj_, hTraj);
373  selTrajs_ = std::make_unique<std::vector<Trajectory>>();
374  rTrajectories_ = evt.getRefBeforePut< vector<Trajectory> >();
375  selTTAss_ = std::make_unique<TrajTrackAssociationCollection>(rTrajectories_, rTracks_);
376  for (size_t i = 0, n = hTraj->size(); i < n; ++i) {
377  Ref< vector<Trajectory> > trajRef(hTraj, i);
379  if (match != hTTAss->end()) {
380  const Ref<TrackCollection> &trkRef = match->val;
381  short oldKey = static_cast<short>(trkRef.key());
382  if (trackRefs_[oldKey].isNonnull()) {
383  selTrajs_->push_back( Trajectory(*trajRef) );
384  selTTAss_->insert ( Ref< vector<Trajectory> >(rTrajectories_, selTrajs_->size() - 1), trackRefs_[oldKey] );
385  }
386  }
387  }
388  }
389 
390  evt.put(std::move(selTracks_));
391  if (copyExtras_ ) {
392  evt.put(std::move(selTrackExtras_));
393  evt.put(std::move(selHits_));
394  }
395  if ( copyTrajectories_ ) {
396  evt.put(std::move(selTrajs_));
397  evt.put(std::move(selTTAss_));
398  }
399 }
400 
401 
404 
405 
407 
#define LogDebug(id)
size
Write out results.
std::vector< double > chi2n_no1Dmod_par_
const edm::RefToBase< TrajectorySeed > & seedRef() const
Definition: Track.h:213
T getParameter(std::string const &) const
std::vector< uint32_t > min_nhits_
#define dso_hidden
T getUntrackedParameter(std::string const &, T const &) const
std::vector< double > chi2n_par_
std::vector< std::vector< double > > d0_par1_
std::vector< double > max_d0NoPV_
std::vector< double > max_z0_
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:137
std::vector< uint32_t > min_layers_
Cuts on numbers of layers with hits/3D hits/lost hits.
bool existsAs(std::string const &parameterName, bool trackiness=true) const
checks if a parameter exists as a given type
Definition: ParameterSet.h:186
std::vector< double > max_z0NoPV_
const TrackExtraRef & extra() const
reference to "extra" object
Definition: Track.h:189
std::vector< bool > useMVA_
const_iterator end() const
last iterator over the map (read only)
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:579
std::vector< bool > keepAllTracks_
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
void setHits(TrackingRecHitRefProd const &prod, unsigned firstH, unsigned int nH)
std::vector< uint32_t > min_hits_bypass_
bool select(unsigned tsNum, const reco::BeamSpot &vertexBeamSpot, const TrackingRecHitCollection &recHits, const reco::Track &tk, const std::vector< Point > &points, std::vector< float > &vterr, std::vector< float > &vzerr, double mvaVal) const
return class, or -1 if rejected
bool copyTrajectories_
copy also trajectories and trajectory->track associations
double minEta_
eta restrictions
const_iterator find(const key_type &k) const
find element with specified reference key
size_type size() const
Definition: OwnVector.h:264
std::vector< Track > TrackCollection
collection of Tracks
Definition: TrackFwd.h:15
bool exists(std::string const &parameterName) const
checks if a parameter exists
std::vector< bool > applyAdaptedPVCuts_
bool innerOk() const
return true if the innermost hit is valid
Definition: Track.h:50
edm::Ref< TrackExtraCollection > TrackExtraRef
persistent reference to a TrackExtra
Definition: TrackExtraFwd.h:17
std::vector< double > nSigmaZ_
std::vector< std::string > mvaType_
std::vector< unsigned int > preFilter_
key_type key() const
Accessor for product key.
Definition: Ref.h:265
const math::XYZPoint & outerPosition() const
position of the outermost hit
Definition: Track.h:65
edm::EDGetTokenT< TrackingRecHitCollection > hSrc_
edm::EDGetTokenT< std::vector< Trajectory > > srcTraj_
edm::EDGetTokenT< reco::VertexCollection > vertices_
std::vector< uint32_t > min_3Dlayers_
const math::XYZPoint & innerPosition() const
position of the innermost hit
Definition: Track.h:55
std::vector< uint32_t > max_lostLayers_
std::vector< int32_t > max_lostHitFraction_
edm::EDGetTokenT< reco::BeamSpot > beamspot_
std::vector< double > min_eta_
std::vector< bool > setQualityBit_
do I have to set a quality bit?
CovarianceMatrix outerStateCovariance() const
outermost trajectory state curvilinear errors
Definition: Track.h:75
double pt() const
track transverse momentum
Definition: TrackBase.h:621
unsigned int outerDetId() const
DetId of the detector on which surface the outermost state is located.
Definition: Track.h:94
std::vector< std::vector< double > > dz_par1_
~AnalyticalTrackSelector() override
destructor
std::vector< std::vector< double > > dz_par2_
std::vector< std::vector< double > > res_par_
trackingRecHit_iterator recHitsBegin() const
Iterator to first hit on the track.
Definition: Track.h:104
#define LogTrace(id)
std::vector< double > max_relpterr_
RefProd< PROD > getRefBeforePut()
Definition: Event.h:167
void run(edm::Event &evt, const edm::EventSetup &es) const override
process one event
AnalyticalTrackSelector(const edm::ParameterSet &cfg)
constructor
std::vector< TrackExtra > TrackExtraCollection
collection of TrackExtra objects
Definition: TrackExtraFwd.h:11
std::vector< int32_t > vtxNumber_
vertex cuts
const math::XYZVector & outerMomentum() const
momentum vector at the outermost hit position
Definition: Track.h:70
void selectVertices(unsigned int tsNum, const reco::VertexCollection &vtxs, std::vector< Point > &points, std::vector< float > &vterr, std::vector< float > &vzerr) const
T const * product() const
Definition: Handle.h:81
bool outerOk() const
return true if the outermost hit is valid
Definition: Track.h:45
const PropagationDirection & seedDirection() const
direction of how the hits were sorted in the original seed
Definition: Track.h:204
std::vector< reco::TrackBase::TrackQuality > qualityToSet_
edm::EDGetTokenT< TrajTrackAssociationCollection > srcTass_
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
edm::Ref< TrackCollection > TrackRef
persistent reference to a Track
Definition: TrackFwd.h:21
CovarianceMatrix innerStateCovariance() const
innermost trajectory state curvilinear errors
Definition: Track.h:80
std::vector< std::string > forestLabel_
fixed size matrix
HLT enums.
bool copyExtras_
copy only the tracks, not extras and rechits (for AOD)
const math::XYZVector & innerMomentum() const
momentum vector at the innermost hit position
Definition: Track.h:60
std::vector< StringCutObjectSelector< reco::Vertex > > vertexCut_
const TrackResiduals & residuals() const
get the residuals
Definition: Track.h:218
std::vector< bool > applyAbsCutsIfNoPV_
std::pair< typename Association::data_type::first_type, double > match(Reference key, Association association, bool bestMatchByMaxValue)
Generic matching function.
Definition: Utils.h:10
std::vector< int32_t > max_minMissHitOutOrIn_
std::vector< double > min_MVA_
edm::EDGetTokenT< reco::TrackCollection > src_
source collection label
std::vector< std::vector< double > > d0_par2_
std::vector< double > max_d0_
Impact parameter absolute cuts.
std::vector< bool > useMVAonly_
unsigned int innerDetId() const
DetId of the detector on which surface the innermost state is located.
Definition: Track.h:99
void processMVA(edm::Event &evt, const edm::EventSetup &es, const reco::BeamSpot &beamspot, const reco::VertexCollection &vertices, int selIndex, std::vector< float > &mvaVals_, bool writeIt=false) const
def move(src, dest)
Definition: eostools.py:510
void setTrajParams(TrajParams tmps, Chi2sFive chi2s)
std::vector< double > max_eta_
std::vector< GBRForest * > forest_
trackingRecHit_iterator recHitsEnd() const
Iterator to last hit on the track.
Definition: Track.h:109
void setResiduals(const TrackResiduals &r)
set the residuals
Definition: TrackExtra.h:174