Skip to content

Commit

Permalink
migrate HitEff to use esconsumes
Browse files Browse the repository at this point in the history
  • Loading branch information
mmusich committed Oct 13, 2020
1 parent 0da1310 commit ab9b012
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 26 deletions.
13 changes: 13 additions & 0 deletions CalibTracker/SiStripHitEfficiency/interface/HitEff.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
#include "Geometry/TrackerGeometryBuilder/interface/TrackerGeometry.h"
#include "TrackingTools/MaterialEffects/interface/PropagatorWithMaterial.h"
#include "TrackingTools/KalmanUpdators/interface/KFUpdator.h"
#include "RecoTracker/Record/interface/CkfComponentsRecord.h"
#include "RecoLocalTracker/Records/interface/TkStripCPERecord.h"
#include "TrackingTools/KalmanUpdators/interface/Chi2MeasurementEstimator.h"
#include "TrackingTools/TransientTrackingRecHit/interface/TransientTrackingRecHitBuilder.h"
#include "DataFormats/TrackingRecHit/interface/TrackingRecHit.h"
Expand Down Expand Up @@ -82,6 +84,17 @@ class HitEff : public edm::EDAnalyzer {
const edm::EDGetTokenT<DetIdCollection> digis_token_;
const edm::EDGetTokenT<MeasurementTrackerEvent> trackerEvent_token_;

// ES tokens

const edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> topoToken_;
const edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> geomToken_;
const edm::ESGetToken<StripClusterParameterEstimator, TkStripCPERecord> cpeToken_;
const edm::ESGetToken<SiStripQuality, SiStripQualityRcd> siStripQualityToken_;
const edm::ESGetToken<MagneticField, IdealMagneticFieldRecord> magFieldToken_;
const edm::ESGetToken<MeasurementTracker, CkfComponentsRecord> measurementTkToken_;
const edm::ESGetToken<Chi2MeasurementEstimatorBase, TrackingComponentsRecord> chi2MeasurementEstimatorToken_;
const edm::ESGetToken<Propagator, TrackingComponentsRecord> propagatorToken_;

edm::ParameterSet conf_;

TTree* traj;
Expand Down
43 changes: 17 additions & 26 deletions CalibTracker/SiStripHitEfficiency/src/HitEff.cc
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,6 @@
#include "TrackingTools/DetLayers/interface/DetLayer.h"
#include "RecoTracker/MeasurementDet/interface/MeasurementTracker.h"
#include "RecoTracker/MeasurementDet/interface/MeasurementTrackerEvent.h"

#include "RecoTracker/Record/interface/CkfComponentsRecord.h"
#include "CalibTracker/Records/interface/SiStripDetCablingRcd.h"
#include "CalibFormats/SiStripObjects/interface/SiStripDetCabling.h"
#include "CalibTracker/Records/interface/SiStripQualityRcd.h"
Expand Down Expand Up @@ -81,6 +79,14 @@ HitEff::HitEff(const edm::ParameterSet& conf)
consumes<edmNew::DetSetVector<SiStripCluster> >(conf.getParameter<edm::InputTag>("siStripClusters"))),
digis_token_(consumes<DetIdCollection>(conf.getParameter<edm::InputTag>("siStripDigis"))),
trackerEvent_token_(consumes<MeasurementTrackerEvent>(conf.getParameter<edm::InputTag>("trackerEvent"))),
topoToken_(esConsumes()),
geomToken_(esConsumes()),
cpeToken_(esConsumes(edm::ESInputTag("", "StripCPEfromTrackAngle"))),
siStripQualityToken_(esConsumes()),
magFieldToken_(esConsumes()),
measurementTkToken_(esConsumes()),
chi2MeasurementEstimatorToken_(esConsumes(edm::ESInputTag("", "Chi2"))),
propagatorToken_(esConsumes(edm::ESInputTag("", "PropagatorWithMaterial"))),
conf_(conf) {
compSettings = conf_.getUntrackedParameter<int>("CompressionSettings", -1);
layers = conf_.getParameter<int>("Layer");
Expand Down Expand Up @@ -159,8 +165,7 @@ void HitEff::beginJob() {

void HitEff::analyze(const edm::Event& e, const edm::EventSetup& es) {
//Retrieve tracker topology from geometry
edm::ESHandle<TrackerTopology> tTopoHandle;
es.get<TrackerTopologyRcd>().get(tTopoHandle);
edm::ESHandle<TrackerTopology> tTopoHandle = es.getHandle(topoToken_);
const TrackerTopology* const tTopo = tTopoHandle.product();

siStripClusterInfo_.initEvent(es);
Expand Down Expand Up @@ -213,47 +218,33 @@ void HitEff::analyze(const edm::Event& e, const edm::EventSetup& es) {
e.getByToken(clusters_token_, theClusters);

//get tracker geometry
edm::ESHandle<TrackerGeometry> tracker;
es.get<TrackerDigiGeometryRecord>().get(tracker);
edm::ESHandle<TrackerGeometry> tracker = es.getHandle(geomToken_);
const TrackerGeometry* tkgeom = &(*tracker);

//get Cluster Parameter Estimator
//std::string cpe = conf_.getParameter<std::string>("StripCPE");
edm::ESHandle<StripClusterParameterEstimator> parameterestimator;
es.get<TkStripCPERecord>().get("StripCPEfromTrackAngle", parameterestimator);
edm::ESHandle<StripClusterParameterEstimator> parameterestimator = es.getHandle(cpeToken_);
const StripClusterParameterEstimator& stripcpe(*parameterestimator);

// get the SiStripQuality records
edm::ESHandle<SiStripQuality> SiStripQuality_;
//LQ commenting the try/catch that causes problem in 74X calibTree production
// try {
// es.get<SiStripQualityRcd>().get("forCluster",SiStripQuality_);
// }
// catch (...) {
es.get<SiStripQualityRcd>().get(SiStripQuality_);
// }

edm::ESHandle<MagneticField> magFieldHandle;
es.get<IdealMagneticFieldRecord>().get(magFieldHandle);
edm::ESHandle<SiStripQuality> SiStripQuality_ = es.getHandle(siStripQualityToken_);

edm::ESHandle<MagneticField> magFieldHandle = es.getHandle(magFieldToken_);
const MagneticField* magField_ = magFieldHandle.product();

// get the list of module IDs with FED-detected errors
edm::Handle<DetIdCollection> fedErrorIds;
//e.getByLabel("siStripDigis", fedErrorIds );
e.getByToken(digis_token_, fedErrorIds);

ESHandle<MeasurementTracker> measurementTrackerHandle;
es.get<CkfComponentsRecord>().get(measurementTrackerHandle);
ESHandle<MeasurementTracker> measurementTrackerHandle = es.getHandle(measurementTkToken_);

edm::Handle<MeasurementTrackerEvent> measurementTrackerEvent;
//e.getByLabel("MeasurementTrackerEvent", measurementTrackerEvent);
e.getByToken(trackerEvent_token_, measurementTrackerEvent);

edm::ESHandle<Chi2MeasurementEstimatorBase> est;
es.get<TrackingComponentsRecord>().get("Chi2", est);

edm::ESHandle<Propagator> prop;
es.get<TrackingComponentsRecord>().get("PropagatorWithMaterial", prop);
edm::ESHandle<Chi2MeasurementEstimatorBase> est = es.getHandle(chi2MeasurementEstimatorToken_);
edm::ESHandle<Propagator> prop = es.getHandle(propagatorToken_);
const Propagator* thePropagator = prop.product();

events++;
Expand Down

0 comments on commit ab9b012

Please sign in to comment.