|
|
Go to the documentation of this file.
164 moduleName_(parameters_.getUntrackedParameter<
std::
string>(
"moduleName",
"StandaloneTrackMonitor")),
165 folderName_(parameters_.getUntrackedParameter<
std::
string>(
"folderName",
"highPurityTracks")),
166 trackTag_(parameters_.getUntrackedParameter<
edm::
InputTag>(
"trackInputTag",
edm::
InputTag(
"generalTracks"))),
167 bsTag_(parameters_.getUntrackedParameter<
edm::
InputTag>(
"offlineBeamSpot",
edm::
InputTag(
"offlineBeamSpot"))),
171 clusterTag_(parameters_.getUntrackedParameter<
edm::
InputTag>(
"clusterTag",
edm::
InputTag(
"siStripClusters"))),
177 trackQuality_(parameters_.getUntrackedParameter<
std::
string>(
"trackQuality",
"highPurity")),
178 siStripClusterInfo_(consumesCollector()),
179 doPUCorrection_(parameters_.getUntrackedParameter<
bool>(
"doPUCorrection",
false)),
180 isMC_(parameters_.getUntrackedParameter<
bool>(
"isMC",
false)),
181 haveAllHistograms_(parameters_.getUntrackedParameter<
bool>(
"haveAllHistograms",
false)),
183 parameters_.getUntrackedParameter<
std::
string>(
"puScaleFactorFile",
"PileupScaleFactor_run203002.root")),
184 verbose_(parameters_.getUntrackedParameter<
bool>(
"verbose",
false)),
257 TH1F* h1 = dynamic_cast<TH1F*>(
f1->Get(
"pileupweight"));
258 for (
int i = 1;
i <= h1->GetNbinsX(); ++
i)
259 vpu_.push_back(h1->GetBinContent(
i));
297 trackPH_ = iBook.
book1D(
"trackP",
"Track 4-momentum", 50, 0.0, 10.0);
301 TrackPtHistoPar.getParameter<int32_t>(
"Xbins"),
302 TrackPtHistoPar.getParameter<
double>(
"Xmin"),
303 TrackPtHistoPar.getParameter<
double>(
"Xmax"));
338 iBook.
book1D(
"pixelLayerwithMeasurement",
"No. of Pixel Layers per Track", 10, 0.0, 10.0);
341 iBook.
book1D(
"stripLayerwithMeasurement",
"No. of Strip Layers per Track", 20, 0.0, 20.0);
362 nPixBarrelH_ = iBook.
book1D(
"nHitPixelBarrel",
"No. of hits in Pixel Barrel per Track", 20, 0, 20.0);
364 nPixEndcapH_ = iBook.
book1D(
"nHitPixelEndcap",
"No. of hits in Pixel Endcap per Track", 20, 0, 20.0);
366 nStripTIBH_ = iBook.
book1D(
"nHitStripTIB",
"No. of hits in Strip TIB per Track", 30, 0, 30.0);
368 nStripTOBH_ = iBook.
book1D(
"nHitStripTOB",
"No. of hits in Strip TOB per Track", 30, 0, 30.0);
370 nStripTECH_ = iBook.
book1D(
"nHitStripTEC",
"No. of hits in Strip TEC per Track", 30, 0, 30.0);
372 nStripTIDH_ = iBook.
book1D(
"nHitStripTID",
"No. of hits in Strip TID per Tracks", 30, 0, 30.0);
375 nTracksH_ = iBook.
book1D(
"nTracks",
"No. of Tracks", 100, -0.5, 999.5);
381 nPUH_ = iBook.
book1D(
"nPU",
"No of Pileup", 60, 0, 60.0);
383 trueNIntH_ = iBook.
book1D(
"trueNInt",
"True no of Interactions", 60, 0, 60.0);
388 "Number of Hits Vs pT",
389 TrackPtHistoPar.getParameter<int32_t>(
"Xbins"),
390 TrackPtHistoPar.getParameter<
double>(
"Xmin"),
391 TrackPtHistoPar.getParameter<
double>(
"Xmax"),
396 nHitsVsnVtxH_ = iBook.
bookProfile(
"nHitsVsnVtx",
"Number of Hits Vs Number of Vertex", 100, 0.0, 50, 0.0, 0.0,
"g");
399 "Number of Hits Vs Eta",
408 iBook.
bookProfile(
"nHitsVsCosTheta",
"Number of Hits Vs Cos(Theta)", 50, -1.0, 1.0, 0.0, 0.0,
"g");
414 "Number of Lost Hits Vs pT",
415 TrackPtHistoPar.getParameter<int32_t>(
"Xbins"),
416 TrackPtHistoPar.getParameter<
double>(
"Xmin"),
417 TrackPtHistoPar.getParameter<
double>(
"Xmax"),
423 "Number of Lost Hits Vs Eta",
432 iBook.
bookProfile(
"nLostHitsVsCosTheta",
"Number of Lost Hits Vs Cos(Theta)", 50, -1.0, 1.0, 0.0, 0.0,
"g");
439 iBook.
book1D(
"hOnTrkClusChargeThin",
"On-track Cluster Charge (Thin Sensor)", 100, 0, 1000);
444 iBook.
book1D(
"hOnTrkClusChargeThick",
"On-track Cluster Charge (Thick Sensor)", 100, 0, 1000);
447 iBook.
book1D(
"hOnTrkClusWidthThick",
"On-track Cluster Width (Thick Sensor)", 20, -0.5, 19.5);
451 iBook.
book1D(
"hOffTrkClusChargeThin",
"Off-track Cluster Charge (Thin Sensor)", 100, 0, 1000);
454 iBook.
book1D(
"hOffTrkClusWidthThin",
"Off-track Cluster Width (Thin Sensor)", 20, -0.5, 19.5);
457 iBook.
book1D(
"hOffTrkClusChargeThick",
"Off-track Cluster Charge (Thick Sensor)", 100, 0, 1000);
460 iBook.
book1D(
"hOffTrkClusWidthThick",
"Off-track Cluster Width (Thick Sensor)", 20, -0.5, 19.5);
481 if (!
iEvent.isRealData()) {
486 edm::LogInfo(
"StandaloneTrackMonitor") <<
"nPUColl = " << PupInfo->size();
487 for (
auto const&
v : *PupInfo) {
488 int bx =
v.getBunchCrossing();
494 int ntrueInt =
v.getTrueNumInteractions();
498 if (ntrueInt > -1 && ntrueInt <
int(
vpu_.size()))
499 wfac =
vpu_.at(ntrueInt);
504 edm::LogInfo(
"StandaloneTrackMonitor") <<
"PU reweight factor = " << wfac;
509 int nvtx = (vertexColl.
isValid() ? vertexColl->size() : 0);
538 int nLostHits =
track.numberOfLostHits();
551 double thetaError =
track.thetaError();
554 double ptError =
track.ptError();
555 double qoverp =
track.qoverp();
556 double qoverpError =
track.qoverpError();
562 double dxyError =
track.dxyError();
564 double dzError =
track.dzError();
566 double trkd0 =
track.d0();
569 double vx =
track.vx();
570 double vy =
track.vy();
571 double vz =
track.vz();
613 int nPixBarrel = 0, nPixEndcap = 0, nStripTIB = 0, nStripTOB = 0, nStripTEC = 0, nStripTID = 0;
614 for (
auto it =
track.recHitsBegin(); it !=
track.recHitsEnd(); ++it) {
618 int subdetId =
hit.geographicalId().subdetId();
639 <<
" >>> HITs: nPixBarrel: " << nPixBarrel <<
" nPixEndcap: " << nPixEndcap <<
" nStripTIB: " << nStripTIB
640 <<
" nStripTOB: " << nStripTOB <<
" nStripTEC: " << nStripTEC <<
" nStripTID: " << nStripTID;
667 dsvit != clusterHandle->end();
669 uint32_t detId = dsvit->id();
670 std::map<uint32_t, std::set<const SiStripCluster*> >::iterator jt =
clusterMap_.find(detId);
671 bool detid_found = (jt !=
clusterMap_.end()) ?
true :
false;
676 std::set<const SiStripCluster*>&
s = jt->second;
677 if (
s.find(&*clusit) !=
s.end())
701 uint32_t detid =
recHit.geographicalId();
705 auto const& thit = static_cast<BaseTrackerRecHit const&>(
recHit);
709 auto const& clus = thit.firstClusterRef();
715 if (thit.isMatched()) {
740 auto& cluster = clus.stripCluster();
753 std::map<uint32_t, std::set<const SiStripCluster*> >::iterator it =
clusterMap_.find(detid);
755 std::set<const SiStripCluster*>
s;
757 clusterMap_.insert(std::pair<uint32_t, std::set<const SiStripCluster*> >(detid,
s));
759 std::set<const SiStripCluster*>&
s = it->second;
SiStripClusterInfo siStripClusterInfo_
MonitorElement * nHitsVsEtaH_
void processClusters(edm::Event const &iEvent, edm::EventSetup const &iSetup, double wfac=1)
MonitorElement * beamSpotZposH_
MonitorElement * nPixEndcapH_
MonitorElement * nHitsVsCosThetaH_
MonitorElement * nVertexH_
MonitorElement * nTracksH_
edm::ParameterSet parameters_
MonitorElement * nvalidPixelHitsH_
SiStripCluster const & stereoCluster() const
void processHit(const TrackingRecHit &recHit, edm::EventSetup const &iSetup, double wfac=1)
MonitorElement * trackChargeH_
MonitorElement * trackPtUpto2GeVH_
MonitorElement * tracknDOFH_
void dqmBeginRun(const edm::Run &iRun, const edm::EventSetup &iSetup) override
MonitorElement * vertexXposH_
const edm::InputTag clusterTag_
MonitorElement * hOffTrkClusChargeThinH_
virtual void setCurrentFolder(std::string const &fullpath)
MonitorElement * trackPterrH_
boost::transform_iterator< IterHelp, const_IdIter > const_iterator
MonitorElement * trueNIntH_
TrackQuality
track quality
MonitorElement * trackPhiH_
MonitorElement * trackThetaerrH_
MonitorElement * stripLayerwithMeasurementH_
const TrackerGeometry * tkGeom_
MonitorElement * vertexZposH_
MonitorElement * trackChi2bynDOFH_
Log< level::Info, false > LogInfo
MonitorElement * trackCosThetaH_
MonitorElement * nPixBarrelH_
MonitorElement * nStripTIBH_
const std::string puScaleFactorFile_
MonitorElement * trackPhierrH_
void addClusterToMap(uint32_t detid, const SiStripCluster *cluster)
MonitorElement * trackd0H_
const edm::ESGetToken< TrackerGeometry, TrackerDigiGeometryRecord > geomToken_
int pixelLayersWithMeasurement() const
MonitorElement * nStripTOBH_
MonitorElement * trackEtaH_
const uint32_t *__restrict__ Quality * quality
const TrackerGeomDet * idToDetUnit(DetId) const override
Return the pointer to the GeomDetUnit corresponding to a given DetId.
MonitorElement * hOffTrkClusWidthThinH_
const Plane & surface() const
The nominal surface of the GeomDet.
const edm::EDGetTokenT< std::vector< PileupSummaryInfo > > puSummaryToken_
int stripLayersWithMeasurement() const
void analyze(edm::Event const &iEvent, edm::EventSetup const &iSetup) override
Cos< T >::type cos(const T &t)
#define DEFINE_FWK_MODULE(type)
int trackerLayersWithMeasurement() const
MonitorElement * hOffTrkClusWidthThickH_
MonitorElement * nStripTIDH_
const edm::EDGetTokenT< reco::BeamSpot > bsToken_
std::vector< float > vpu_
MonitorElement * nHitsVsPhiH_
MonitorElement * nvalidTrackerHitsH_
const Bounds & bounds() const
MonitorElement * bookProfile(TString const &name, TString const &title, int nchX, double lowX, double highX, int, double lowY, double highY, char const *option="s", FUNC onbooking=NOOP())
MonitorElement * trackChi2H_
Geom::Theta< T > theta() const
static constexpr auto TIB
MonitorElement * nLostHitsVsEtaH_
MonitorElement * hOnTrkClusChargeThinH_
MonitorElement * hOffTrkClusChargeThickH_
MonitorElement * hOnTrkClusWidthThinH_
void setCluster(const SiStripCluster &cluster, int detId)
MonitorElement * nStripTECH_
MonitorElement * trackPtH_
virtual float thickness() const =0
MonitorElement * beamSpotXYposH_
MonitorElement * trackPH_
const edm::EDGetTokenT< reco::TrackCollection > trackToken_
const uint32_t *__restrict__ const HitContainer *__restrict__ TkSoA *__restrict__ tracks
MonitorElement * nLostHitsVsCosThetaH_
MonitorElement * trackqOverperrH_
MonitorElement * vertexYposH_
StandaloneTrackMonitor(const edm::ParameterSet &)
const edm::InputTag puSummaryTag_
MonitorElement * nvalidStripHitsH_
Log< level::Error, false > LogError
MonitorElement * bunchCrossingH_
MonitorElement * beamSpotXYposerrH_
MonitorElement * beamSpotZposerrH_
std::map< uint32_t, std::set< const SiStripCluster * > > clusterMap_
const edm::InputTag bsTag_
bool getData(T &iHolder) const
const bool doPUCorrection_
static TrackQuality qualityByName(const std::string &name)
void initEvent(const edm::EventSetup &iSetup)
MonitorElement * trackPtOver10GeVH_
static constexpr auto TEC
MonitorElement * nLostHitsVsPhiH_
int numberOfValidStripHits() const
int numberOfValidTrackerHits() const
MonitorElement * hOnTrkClusChargeThickH_
MonitorElement * trackqOverpH_
MonitorElement * hOnTrkClusWidthThickH_
SiStripCluster const & monoCluster() const
unsigned long long m_cacheID_
MonitorElement * pixelLayerwithMeasurementH_
const edm::EDGetTokenT< edmNew::DetSetVector< SiStripCluster > > clusterToken_
std::vector< Vertex > VertexCollection
const edm::InputTag trackTag_
MonitorElement * trackEtaerrH_
static constexpr auto TOB
const std::string trackQuality_
T getParameter(std::string const &) const
MonitorElement * nLostHitsVspTH_
int numberOfValidPixelHits() const
const edm::EDGetTokenT< reco::VertexCollection > vertexToken_
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
MonitorElement * nlostHitsH_
MonitorElement * nHitsVsnVtxH_
std::vector< Track > TrackCollection
collection of Tracks
MonitorElement * trkLayerwithMeasurementH_
static constexpr auto TID
MonitorElement * book1D(TString const &name, TString const &title, int const nchX, double const lowX, double const highX, FUNC onbooking=NOOP())
const edm::InputTag vertexTag_
MonitorElement * nHitsVspTH_
const data_type * const_iterator
const bool haveAllHistograms_