15 #include "TLorentzVector.h" 30 m_tau = tauL1tPair.
m_tau;
33 m_eta = tauL1tPair.
m_eta;
49 AntiMuWP_(ps.getUntrackedParameter<
std::
string>(
"antiMuWP")),
52 AntiEleWP_(ps.getUntrackedParameter<
std::
string>(
"antiEleWP")),
53 DecayModeFindingInputTag_(
57 comb3TWP_(ps.getUntrackedParameter<
std::
string>(
"comb3TWP")),
63 trigProcess_(ps.getUntrackedParameter<
string>(
"trigProcess")),
65 triggerPath_(ps.getUntrackedParameter<
vector<
std::
string>>(
"triggerNames")),
66 histFolder_(ps.getParameter<
std::
string>(
"histFolder")),
67 efficiencyFolder_(histFolder_ +
"/efficiency_raw"),
69 tauEfficiencyThresholds_(ps.getParameter<
std::
vector<
int>>(
"tauEfficiencyThresholds")),
70 tauEfficiencyBins_(ps.getParameter<
std::
vector<double>>(
"tauEfficiencyBins")),
86 h_L1TauETvsTauET_EB_(),
87 h_L1TauETvsTauET_EE_(),
88 h_L1TauETvsTauET_EB_EE_(),
89 h_L1TauPhivsTauPhi_EB_(),
90 h_L1TauPhivsTauPhi_EE_(),
91 h_L1TauPhivsTauPhi_EB_EE_(),
92 h_L1TauEtavsTauEta_(),
93 h_resolutionTauET_EB_(),
94 h_resolutionTauET_EE_(),
95 h_resolutionTauET_EB_EE_(),
96 h_resolutionTauPhi_EB_(),
97 h_resolutionTauPhi_EE_(),
98 h_resolutionTauPhi_EB_EE_(),
99 h_resolutionTauEta_(),
100 h_efficiencyIsoTauET_EB_pass_(),
101 h_efficiencyIsoTauET_EE_pass_(),
102 h_efficiencyIsoTauET_EB_EE_pass_(),
103 h_efficiencyNonIsoTauET_EB_pass_(),
104 h_efficiencyNonIsoTauET_EE_pass_(),
105 h_efficiencyNonIsoTauET_EB_EE_pass_(),
106 h_efficiencyIsoTauET_EB_total_(),
107 h_efficiencyIsoTauET_EE_total_(),
108 h_efficiencyIsoTauET_EB_EE_total_(),
109 h_efficiencyNonIsoTauET_EB_total_(),
110 h_efficiencyNonIsoTauET_EE_total_(),
111 h_efficiencyNonIsoTauET_EB_EE_total_() {
113 <<
"L1TTauOffline::L1TTauOffline " << std::endl;
121 edm::LogInfo(
"L1TTauOffline") <<
"Destructor L1TTauOffline::~L1TTauOffline " << std::endl;
133 edm::LogInfo(
"L1TTauOffline") <<
"L1TTauOffline::beginRun" << std::endl;
140 edm::LogInfo(
"L1TTauOffline") <<
"L1TTauOffline::bookHistograms" << std::endl;
148 std::size_t found0 = tNameTmp.find(
'*');
149 if (found0 != std::string::npos)
150 tNamePattern = tNameTmp.substr(0, tNameTmp.size() - 1);
152 tNamePattern = tNameTmp;
159 std::size_t
found = tmpName.find(tNamePattern);
160 if (
found != std::string::npos) {
179 if (!
taus.isValid()) {
180 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::PFTauCollection " << std::endl;
187 if (!
muons.isValid()) {
188 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::MuonCollection " << std::endl;
196 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::BeamSpot " << std::endl;
204 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::VertexCollection " << std::endl;
212 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: l1t::TauBxCollection " << std::endl;
220 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: edm::TriggerResults " << std::endl;
228 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: trigger::TriggerEvent " << std::endl;
235 if (!
mets.isValid()) {
236 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::PFMETCollection " << std::endl;
248 vector<l1t::Tau> l1tContainer;
249 l1tContainer.reserve(l1tCands->
size() + 1);
252 l1tContainer.push_back(*
tau);
256 float eta = tauL1tPairsIt->eta();
257 float phi = tauL1tPairsIt->phi();
258 float pt = tauL1tPairsIt->pt();
261 float l1tPt = tauL1tPairsIt->l1tPt();
269 bool l1tAboveCut = (l1tPt >= l1tPtCut);
271 stringstream ptCutToTag;
272 ptCutToTag << l1tPtCut;
273 string ptTag = ptCutToTag.str();
277 if (fabs(
eta) < 1.5) {
298 if (fabs(
eta) < 1.5) {
315 if (tauL1tPairsIt->l1tIso() > 0.5) {
343 "L1 Tau E_{T} vs PFTau E_{T} (EB); PFTau E_{T} (GeV); L1 Tau E_{T} (GeV)",
345 &templateETvsET.
binsX[0],
347 &templateETvsET.
binsY[0]);
349 "L1 Tau E_{T} vs PFTau E_{T} (EE); PFTau E_{T} (GeV); L1 Tau E_{T} (GeV)",
351 &templateETvsET.
binsX[0],
353 &templateETvsET.
binsY[0]);
355 "L1 Tau E_{T} vs PFTau E_{T} (EB+EE); PFTau E_{T} (GeV); L1 Tau E_{T} (GeV)",
357 &templateETvsET.
binsX[0],
359 &templateETvsET.
binsY[0]);
363 ibooker.
book2D(
"L1TauPhivsTauPhi_EB",
364 "#phi_{tau}^{L1} vs #phi_{tau}^{offline} (EB); #phi_{tau}^{offline}; #phi_{tau}^{L1}",
366 templatePHIvsPHI.
xmin,
367 templatePHIvsPHI.
xmax,
369 templatePHIvsPHI.
ymin,
370 templatePHIvsPHI.
ymax);
372 ibooker.
book2D(
"L1TauPhivsTauPhi_EE",
373 "#phi_{tau}^{L1} vs #phi_{tau}^{offline} (EE); #phi_{tau}^{offline}; #phi_{tau}^{L1}",
375 templatePHIvsPHI.
xmin,
376 templatePHIvsPHI.
xmax,
378 templatePHIvsPHI.
ymin,
379 templatePHIvsPHI.
ymax);
381 ibooker.
book2D(
"L1TauPhivsTauPhi_EB_EE",
382 "#phi_{tau}^{L1} vs #phi_{tau}^{offline} (EB+EE); #phi_{tau}^{offline}; #phi_{tau}^{L1}",
384 templatePHIvsPHI.
xmin,
385 templatePHIvsPHI.
xmax,
387 templatePHIvsPHI.
ymin,
388 templatePHIvsPHI.
ymax);
391 ibooker.
book2D(
"L1TauEtavsTauEta",
"L1 Tau #eta vs PFTau #eta; PFTau #eta; L1 Tau #eta", 100, -3, 3, 100, -3, 3);
395 "resolutionTauET_EB",
"tau ET resolution (EB); (L1 Tau E_{T} - PFTau E_{T})/PFTau E_{T}; events", 50, -1, 1.5);
397 "resolutionTauET_EE",
"tau ET resolution (EE); (L1 Tau E_{T} - PFTau E_{T})/PFTau E_{T}; events", 50, -1, 1.5);
399 ibooker.
book1D(
"resolutionTauET_EB_EE",
400 "tau ET resolution (EB+EE); (L1 Tau E_{T} - PFTau E_{T})/PFTau E_{T}; events",
406 "#phi_{tau} resolution (EB); #phi_{tau}^{L1} - #phi_{tau}^{offline}; events",
411 "resolutionTauPhi_EE",
"tau #phi resolution (EE); #phi_{tau}^{L1} - #phi_{tau}^{offline}; events", 120, -0.3, 0.3);
413 ibooker.
book1D(
"resolutionTauPhi_EB_EE",
414 "tau #phi resolution (EB+EE); #phi_{tau}^{L1} - #phi_{tau}^{offline}; events",
420 ibooker.
book1D(
"resolutionTauEta",
"tau #eta resolution (EB); L1 Tau #eta - PFTau #eta; events", 120, -0.3, 0.3);
425 int nBins = tauBins.size() - 1;
426 float* tauBinArray = &(tauBins[0]);
431 ibooker.
book1D(
"efficiencyIsoTauET_EB_threshold_" + str_threshold +
"_Num",
432 "iso tau efficiency (EB); PFTau E_{T} (GeV); events",
436 ibooker.
book1D(
"efficiencyIsoTauET_EE_threshold_" + str_threshold +
"_Num",
437 "iso tau efficiency (EE); PFTau E_{T} (GeV); events",
441 ibooker.
book1D(
"efficiencyIsoTauET_EB_EE_threshold_" + str_threshold +
"_Num",
442 "iso tau efficiency (EB+EE); PFTau E_{T} (GeV); events",
447 ibooker.
book1D(
"efficiencyIsoTauET_EB_threshold_" + str_threshold +
"_Den",
448 "iso tau efficiency (EB); PFTau E_{T} (GeV); events",
452 ibooker.
book1D(
"efficiencyIsoTauET_EE_threshold_" + str_threshold +
"_Den",
453 "iso tau efficiency (EE); PFTau E_{T} (GeV); events",
457 ibooker.
book1D(
"efficiencyIsoTauET_EB_EE_threshold_" + str_threshold +
"_Den",
458 "iso tau efficiency (EB+EE); PFTau E_{T} (GeV); events",
464 ibooker.
book1D(
"efficiencyNonIsoTauET_EB_threshold_" + str_threshold +
"_Num",
465 "inclusive tau efficiency (EB); PFTau E_{T} (GeV); events",
469 ibooker.
book1D(
"efficiencyNonIsoTauET_EE_threshold_" + str_threshold +
"_Num",
470 "inclusive tau efficiency (EE); PFTau E_{T} (GeV); events",
474 ibooker.
book1D(
"efficiencyNonIsoTauET_EB_EE_threshold_" + str_threshold +
"_Num",
475 "inclusive tau efficiency (EB+EE); PFTau E_{T} (GeV); events",
480 ibooker.
book1D(
"efficiencyNonIsoTauET_EB_threshold_" + str_threshold +
"_Den",
481 "inclusive tau efficiency (EB); PFTau E_{T} (GeV); events",
485 ibooker.
book1D(
"efficiencyNonIsoTauET_EE_threshold_" + str_threshold +
"_Den",
486 "inclusive tau efficiency (EE); PFTau E_{T} (GeV); events",
490 ibooker.
book1D(
"efficiencyNonIsoTauET_EB_EE_threshold_" + str_threshold +
"_Den",
491 "inclusive tau efficiency (EB+EE); PFTau E_{T} (GeV); events",
506 bool hasPrimaryVertex =
false;
509 for (
auto vertexIt =
vertex->begin(); vertexIt !=
vertex->end(); ++vertexIt) {
510 if (vertexIt->isValid() && !vertexIt->isFake()) {
512 errVtx = vertexIt->error();
513 hasPrimaryVertex =
true;
519 if (!hasPrimaryVertex) {
521 errVtx(0, 0) =
beamSpot->BeamWidthX();
522 errVtx(1, 1) =
beamSpot->BeamWidthY();
532 double matchDeltaR = 9999;
539 int moduleIndex = 999999;
540 for (
int ii = moduleLabels.size() - 1;
ii > 0;
ii--) {
541 if (moduleLabels[
ii] ==
"hltBoolEnd") {
542 moduleIndex =
ii - 1;
546 if (moduleIndex == 999999) {
547 edm::LogError(
"L1TMuonDQMOffline") <<
"Found no module label in trigger " << trigIndex;
552 if (hltFilterIndex < triggerEvent->sizeFilters()) {
556 const unsigned nTriggers = triggerVids.size();
557 for (
size_t iTrig = 0; iTrig < nTriggers; ++iTrig) {
561 if (dRtmp < matchDeltaR)
572 vector<l1t::Tau> l1tContainer;
573 l1tContainer.reserve(l1tCands->
size() + 1);
576 l1tContainer.push_back(*
tau);
580 TauL1TPair pairBestCand((*probeTauIt),
nullptr);
582 for (
auto l1tIt = l1tContainer.begin(); l1tIt != l1tContainer.end(); ++l1tIt) {
583 TauL1TPair pairTmpCand((*probeTauIt), &(*l1tIt));
586 pairBestCand = pairTmpCand;
600 pfmet = &(
mets->front());
604 for (
auto muonIt2 =
muons->begin(); muonIt2 !=
muons->end(); ++muonIt2) {
605 if (fabs(muonIt2->eta()) < 2.4 && muonIt2->pt() > 10 &&
muon::isLooseMuon((*muonIt2)) &&
606 (muonIt2->pfIsolationR04().sumChargedHadronPt +
607 max(muonIt2->pfIsolationR04().sumNeutralHadronEt + muonIt2->pfIsolationR04().sumPhotonEt -
608 0.5 * muonIt2->pfIsolationR04().sumPUPt,
615 bool foundTightMu =
false;
616 for (
auto muonIt =
muons->begin(); muonIt !=
muons->end(); ++muonIt) {
619 float muiso = (muonIt->pfIsolationR04().sumChargedHadronPt +
620 max(muonIt->pfIsolationR04().sumNeutralHadronEt + muonIt->pfIsolationR04().sumPhotonEt -
621 0.5 * muonIt->pfIsolationR04().sumPUPt,
625 if (muiso < 0.1 && nb_mu < 2 && !foundTightMu && fabs(muonIt->eta()) < 2.1 && muonIt->pt() > 24 &&
627 float mt =
sqrt(
pow(muonIt->pt() + pfmet->
pt(), 2) -
pow(muonIt->px() + pfmet->
px(), 2) -
628 pow(muonIt->py() + pfmet->
py(), 2));
646 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::PFTauDiscriminator anti-mu";
653 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::PFTauDiscriminator decay mode finding input";
668 edm::LogWarning(
"L1TTauOffline") <<
"invalid collection: reco::PFTauDiscriminator comb3T";
682 const std::vector<edm::ParameterSet> psetsFromProvenance =
684 .getParameter<std::vector<edm::ParameterSet>>(
"IDWPdefinitions");
685 for (
uint i = 0;
i < psetsFromProvenance.size();
i++) {
686 if (psetsFromProvenance[
i].getParameter<std::string>(
"IDname") ==
AntiMuWP_)
693 const std::vector<std::string> psetsFromProvenance =
695 .getParameter<std::vector<std::string>>(
"workingPoints");
696 for (
unsigned int i = 0;
i < psetsFromProvenance.size();
i++) {
704 const std::vector<edm::ParameterSet> psetsFromProvenance =
706 .getParameter<std::vector<edm::ParameterSet>>(
"IDWPdefinitions");
707 for (
uint i = 0;
i < psetsFromProvenance.size();
i++) {
708 if (psetsFromProvenance[
i].getParameter<std::string>(
"IDname") ==
comb3TWP_)
714 for (
auto tauIt =
taus->begin(); tauIt !=
taus->end(); ++tauIt, ++iTau) {
716 TLorentzVector mytau;
717 mytau.SetPtEtaPhiE(tauIt->pt(), tauIt->eta(), tauIt->phi(), tauIt->energy());
719 if ((*antimu)[tauCandidate].workingPoints.empty()) {
720 edm::LogWarning(
"L1TTauOffline") <<
"This offline tau has no antimu discriminator, skipping";
725 edm::LogWarning(
"L1TTauOffline") <<
"This offline tau has no antiele discriminator, skipping";
730 edm::LogWarning(
"L1TTauOffline") <<
"This offline tau has no comb3T discriminator, skipping";
733 bool antiele_condition =
true;
736 antiele_condition = (*antiele)[tauCandidate].workingPoints[
AntiEleWPIndex_];
738 if (fabs(tauIt->charge()) == 1 && fabs(tauIt->eta()) < 2.1 && tauIt->pt() > 20 &&
739 (*antimu)[tauCandidate].workingPoints[
AntiMuWPIndex_] && antiele_condition && (*dmf)[tauCandidate] > 0.5 &&
741 if (mymu.DeltaR(mytau) > 0.5 && (mymu + mytau).M() > 40 && (mymu + mytau).M() < 80 &&
759 for (
auto mon : monElementstoNormalize) {
760 if (
mon !=
nullptr) {
761 auto h =
mon->getTH2F();
763 h->Scale(1,
"width");
std::vector< float > binsX
const std::string & triggerName(unsigned int triggerIndex) const
edm::EDGetTokenT< reco::VertexCollection > VtxInputTag_
std::vector< std::string > triggerPath_
edm::ESGetToken< MagneticField, IdealMagneticFieldRecord > mFieldToken_
std::vector< PFTau > PFTauCollection
collection of PFTau objects
~L1TTauOffline() override
double pt() const final
transverse momentum
The single EDProduct to be saved for each event (AOD case)
std::map< double, MonitorElement * > h_efficiencyIsoTauET_EB_pass_
std::vector< int > m_trigIndices
virtual void setCurrentFolder(std::string const &fullpath)
std::vector< TauL1TPair > m_TauL1tPairs
const Point & position() const
position
MonitorElement * h_L1TauPhivsTauPhi_EB_
void bookTauHistos(DQMStore::IBooker &)
edm::ESHandle< MagneticField > m_BField
void dqmBeginRun(const edm::Run &run, const edm::EventSetup &iSetup) override
math::Error< dimension >::type Error
covariance error matrix (3x3)
static const std::map< std::string, unsigned int > PlotConfigNames
std::vector< Vertex > VertexCollection
collection of Vertex objects
std::vector< double > tauEfficiencyBins_
std::map< double, MonitorElement * > h_efficiencyNonIsoTauET_EB_EE_pass_
edm::EDGetTokenT< reco::TauDiscriminatorContainer > AntiMuInputTag_
MonitorElement * h_nVertex_
std::map< double, MonitorElement * > h_efficiencyIsoTauET_EE_pass_
std::map< double, MonitorElement * > h_efficiencyNonIsoTauET_EB_total_
Log< level::Error, false > LogError
std::map< double, MonitorElement * > h_efficiencyNonIsoTauET_EB_pass_
std::string efficiencyFolder_
void getProbeTaus(const edm::Event &e, edm::Handle< reco::PFTauCollection > const &taus, edm::Handle< reco::MuonCollection > const &muons, const reco::Vertex &vertex)
muons
the two sets of parameters below are mutually exclusive, depending if RECO or ALCARECO is used the us...
BXVector< Tau > TauBxCollection
Provenance const * provenance() const
ParameterSet const & parameterSet(StableProvenance const &provenance, ProcessHistory const &history)
std::map< double, MonitorElement * > h_efficiencyNonIsoTauET_EB_EE_total_
static std::string to_string(const XMLCh *ch)
std::vector< Muon > MuonCollection
collection of Muon objects
MonitorElement * h_resolutionTauPhi_EB_
bool isLooseMuon(const reco::Muon &)
edm::ProcessHistoryID phID_
L1TTauOffline(const edm::ParameterSet &ps)
MonitorElement * h_L1TauPhivsTauPhi_EE_
const_iterator begin(int bx) const
unsigned size(int bx) const
void normalise2DHistogramsToBinArea()
std::vector< int > tauEfficiencyThresholds_
HLTConfigProvider m_hltConfig
double px() const final
x coordinate of momentum vector
std::vector< const reco::PFTau * > m_ProbeTaus
void analyze(edm::Event const &e, edm::EventSetup const &eSetup) override
MonitorElement * h_resolutionTauPhi_EB_EE_
edm::EDGetTokenT< reco::TauDiscriminatorContainer > comb3TInputTag_
const reco::Vertex getPrimaryVertex(edm::Handle< reco::VertexCollection > const &vertex, edm::Handle< reco::BeamSpot > const &beamSpot)
unsigned int size() const
number of trigger paths in trigger table
const l1t::Tau * m_regTau
const std::vector< std::string > & moduleLabels(unsigned int trigger) const
label(s) of module(s) on a trigger path
std::map< double, MonitorElement * > h_efficiencyIsoTauET_EB_total_
ALPAKA_FN_HOST_ACC ALPAKA_FN_INLINE constexpr float phi(ConstView const &tracks, int32_t i)
MonitorElement * h_resolutionTauPhi_EE_
math::XYZPoint Point
point in the space
std::map< double, MonitorElement * > h_efficiencyIsoTauET_EB_EE_pass_
MonitorElement * h_L1TauEtavsTauEta_
#define DEFINE_FWK_MODULE(type)
edm::EDGetTokenT< l1t::TauBxCollection > stage2CaloLayer2TauToken_
std::map< double, MonitorElement * > h_efficiencyIsoTauET_EB_EE_total_
double py() const final
y coordinate of momentum vector
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
MonitorElement * h_resolutionTauEta_
std::map< double, MonitorElement * > h_efficiencyNonIsoTauET_EE_total_
edm::EDGetTokenT< reco::BeamSpot > BsInputTag_
constexpr auto deltaR(const T1 &t1, const T2 &t2) -> decltype(t1.eta())
edm::EDGetTokenT< reco::PFMETCollection > MetInputTag_
MonitorElement * h_resolutionTauET_EB_EE_
edm::EDGetTokenT< edm::TriggerResults > triggerResults_
edm::EDGetTokenT< reco::TauDiscriminatorContainer > AntiEleInputTag_
std::vector< TriggerObject > TriggerObjectCollection
collection of trigger physics objects (e.g., all isolated muons)
Log< level::Info, false > LogInfo
HistDefinitions readHistDefinitions(const edm::ParameterSet &ps, const std::map< std::string, unsigned int > &mapping)
std::vector< const reco::Muon * > m_TightMuons
MonitorElement * h_resolutionTauET_EE_
std::map< double, MonitorElement * > h_efficiencyIsoTauET_EE_total_
const reco::PFTau * m_tau
edm::EDGetTokenT< reco::MuonCollection > MuonInputTag_
std::vector< float > binsY
edm::EDGetTokenT< reco::PFTauDiscriminator > DecayModeFindingInputTag_
MonitorElement * h_tagAndProbeMass_
std::vector< size_type > Keys
bool init(const edm::Run &iRun, const edm::EventSetup &iSetup, const std::string &processName, bool &changed)
d'tor
MonitorElement * book2D(TString const &name, TString const &title, int nchX, double lowX, double highX, int nchY, double lowY, double highY, FUNC onbooking=NOOP())
void getTauL1tPairs(edm::Handle< l1t::TauBxCollection > const &l1tCands)
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
TauL1TPair(const reco::PFTau *tau, const l1t::Tau *regTau)
ParameterSet const & getParameterSet(ParameterSetID const &id)
edm::EDGetTokenT< trigger::TriggerEvent > triggerEvent_
const_iterator end(int bx) const
static std::atomic< unsigned int > counter
bool matchHlt(edm::Handle< trigger::TriggerEvent > const &triggerEvent, const reco::Muon *muon)
dqmoffline::l1t::HistDefinitions histDefinitions_
edm::EDGetTokenT< reco::PFTauCollection > theTauCollection_
MonitorElement * h_L1TauETvsTauET_EB_EE_
MonitorElement * h_L1TauETvsTauET_EE_
Log< level::Warning, false > LogWarning
MonitorElement * book1D(TString const &name, TString const &title, int const nchX, double const lowX, double const highX, FUNC onbooking=NOOP())
MonitorElement * h_L1TauPhivsTauPhi_EB_EE_
void getTightMuons(edm::Handle< reco::MuonCollection > const &muons, edm::Handle< reco::PFMETCollection > const &mets, const reco::Vertex &vertex, edm::Handle< trigger::TriggerEvent > const &trigEvent)
The Signals That Services Can Subscribe To This is based on ActivityRegistry h
Helper function to determine trigger accepts.
MonitorElement * h_resolutionTauET_EB_
primaryVertex
hltOfflineBeamSpot for HLTMON
StableProvenance const & stable() const
MonitorElement * h_L1TauETvsTauET_EB_
Power< A, B >::type pow(const A &a, const B &b)
std::map< double, MonitorElement * > h_efficiencyNonIsoTauET_EE_pass_