ATLAS Offline Software
Loading...
Searching...
No Matches
TauAnalysisTools::DiTauSelectionCutOmniIDWP Class Reference

#include <DiTauSelectionCuts.h>

Inheritance diagram for TauAnalysisTools::DiTauSelectionCutOmniIDWP:
Collaboration diagram for TauAnalysisTools::DiTauSelectionCutOmniIDWP:

Public Member Functions

 DiTauSelectionCutOmniIDWP (DiTauSelectionTool *tDTST)
virtual void setAcceptInfo (asg::AcceptInfo &info) const override
virtual bool accept (const xAOD::DiTauJet &xTau, asg::AcceptData &accept) override
void writeControlHistograms ()
void fillHistogramCutPre (const xAOD::DiTauJet &xTau)
void fillHistogramCut (const xAOD::DiTauJet &xTau)
std::unique_ptr< TH1F > CreateControlPlot (const char *sName, const char *sTitle, int iBins, double dXLow, double dXUp)
const std::string & getName ()
void setProperty (const std::string &name, const std::string &value)

Protected Member Functions

void declareProperty (const std::string &name, std::string &loc)
std::string getProperty (const std::string &name)

Protected Attributes

std::string m_sName
std::unique_ptr< TH1F > m_hHistCutPre
std::unique_ptr< TH1F > m_hHistCut
DiTauSelectionToolm_tDTST
std::map< std::string, std::string & > m_mProperties

Private Member Functions

virtual void fillHistogram (const xAOD::DiTauJet &xTau, TH1F &hHist) const override

Detailed Description

Definition at line 134 of file DiTauSelectionCuts.h.

Constructor & Destructor Documentation

◆ DiTauSelectionCutOmniIDWP()

DiTauSelectionCutOmniIDWP::DiTauSelectionCutOmniIDWP ( DiTauSelectionTool * tDTST)

Definition at line 325 of file DiTauSelectionCuts.cxx.

326 : DiTauSelectionCut("CutOmniIDWP", tDTST)
327{
328 m_hHistCutPre = CreateControlPlot("hOmniIDWP_pre","OmniIDWP_pre;; events",8,-.5,7.5);
329 m_hHistCut = CreateControlPlot("hOmniIDWP_cut","OmniIDWP_cut;; events",8,-.5,7.5);
330 // only proceed if histograms are defined
331 if (!m_hHistCutPre or !m_hHistCut)
332 return;
333
334 m_hHistCutPre->GetXaxis()->SetBinLabel(1,"!VeryLoose");
335 m_hHistCutPre->GetXaxis()->SetBinLabel(2,"VeryLoose");
336 m_hHistCutPre->GetXaxis()->SetBinLabel(3,"!Loose");
337 m_hHistCutPre->GetXaxis()->SetBinLabel(4,"Loose");
338 m_hHistCutPre->GetXaxis()->SetBinLabel(5,"!Medium");
339 m_hHistCutPre->GetXaxis()->SetBinLabel(6,"Medium");
340 m_hHistCutPre->GetXaxis()->SetBinLabel(7,"!Tight");
341 m_hHistCutPre->GetXaxis()->SetBinLabel(8,"Tight");
342 m_hHistCut->GetXaxis()->SetBinLabel(1,"!VeryLoose");
343 m_hHistCut->GetXaxis()->SetBinLabel(2,"VeryLoose");
344 m_hHistCut->GetXaxis()->SetBinLabel(3,"!Loose");
345 m_hHistCut->GetXaxis()->SetBinLabel(4,"Loose");
346 m_hHistCut->GetXaxis()->SetBinLabel(5,"!Medium");
347 m_hHistCut->GetXaxis()->SetBinLabel(6,"Medium");
348 m_hHistCut->GetXaxis()->SetBinLabel(7,"!Tight");
349 m_hHistCut->GetXaxis()->SetBinLabel(8,"Tight");
350}
std::unique_ptr< TH1F > CreateControlPlot(const char *sName, const char *sTitle, int iBins, double dXLow, double dXUp)
DiTauSelectionCut(const std::string &sName, TauAnalysisTools::DiTauSelectionTool *tDTST)

Member Function Documentation

◆ accept()

bool DiTauSelectionCutOmniIDWP::accept ( const xAOD::DiTauJet & xTau,
asg::AcceptData & accept )
overridevirtual

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 374 of file DiTauSelectionCuts.cxx.

376{
377 // check Omni ID working point, if ditau passes OmniID working point then return true; false otherwise
378 bool bPass = false;
379 switch (m_tDTST->m_iOmniIDWP)
380 {
381 case OMNIIDNONE:
382 bPass = true;
383 break;
384 case OMNIIDVERYLOOSE:
385 static const SG::ConstAccessor<char> acc_OmniVeryLoose("omni_score_VL");
386 if (!acc_OmniVeryLoose.isAvailable(xTau)) m_tDTST->msg() << MSG::WARNING << "Omni VeryLoose WP not available" << endmsg;
387 else bPass = acc_OmniVeryLoose(xTau);
388 break;
389 case OMNIIDLOOSE:
390 static const SG::ConstAccessor<char> acc_OmniLoose("omni_score_L");
391 if (!acc_OmniLoose.isAvailable(xTau)) m_tDTST->msg() << MSG::WARNING << "Omni Loose WP not available" << endmsg;
392 else bPass = acc_OmniLoose(xTau);
393 break;
394 case OMNIIDMEDIUM:
395 static const SG::ConstAccessor<char> acc_OmniMedium("omni_score_M");
396 if (!acc_OmniMedium.isAvailable(xTau)) m_tDTST->msg() << MSG::WARNING << "Omni Medium WP not available" << endmsg;
397 else bPass = acc_OmniMedium(xTau);
398 break;
399 case OMNIIDTIGHT:
400 static const SG::ConstAccessor<char> acc_OmniTight("omni_score_T");
401 if (!acc_OmniTight.isAvailable(xTau)) m_tDTST->msg() << MSG::WARNING << "Omni Tight WP not available" << endmsg;
402 else bPass = acc_OmniTight(xTau);
403 break;
404 default:
405 m_tDTST->msg() << MSG::WARNING << "The Omni ID working point with the enum " << m_tDTST->m_iOmniIDWP << " is not available" << endmsg;
406 break;
407 }
408 if (bPass)
409 {
410 acceptData.setCutResult( "OmniIDWP", true );
411 return true;
412 }
413 m_tDTST->msg() << MSG::VERBOSE << "DiTau failed OmniIDWP requirement" << endmsg;
414 return false;
415}
#define endmsg

◆ CreateControlPlot()

std::unique_ptr< TH1F > DiTauSelectionCut::CreateControlPlot ( const char * sName,
const char * sTitle,
int iBins,
double dXLow,
double dXUp )
inherited

Definition at line 31 of file DiTauSelectionCuts.cxx.

32{
33 if (m_tDTST->m_bCreateControlPlots)
34 {
35 auto hHist = std::make_unique<TH1F>(sName, sTitle, iBins, dXLow, dXUp);
36 hHist->SetDirectory(0);
37 return hHist;
38 }
39
40 return nullptr;
41}

◆ declareProperty()

void DiTauSelectionCut::declareProperty ( const std::string & name,
std::string & loc )
protectedinherited

Definition at line 66 of file DiTauSelectionCuts.cxx.

67{
68 std::pair<std::string, std::string&> p(name, loc);
69 m_mProperties.insert(p);
70}
std::map< std::string, std::string & > m_mProperties

◆ fillHistogram()

void DiTauSelectionCutOmniIDWP::fillHistogram ( const xAOD::DiTauJet & xTau,
TH1F & hHist ) const
overrideprivatevirtual

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 353 of file DiTauSelectionCuts.cxx.

354{
355 if(m_tDTST->m_useOmniScore){
356 static const SG::ConstAccessor<char> acc_OmniVeryLoose("omni_score_VL");
357 static const SG::ConstAccessor<char> acc_OmniLoose("omni_score_L");
358 static const SG::ConstAccessor<char> acc_OmniMedium("omni_score_M");
359 static const SG::ConstAccessor<char> acc_OmniTight("omni_score_T");
360 hHist.Fill(acc_OmniVeryLoose(xTau));
361 hHist.Fill(acc_OmniLoose(xTau)+2);
362 hHist.Fill(acc_OmniMedium(xTau)+4);
363 hHist.Fill(acc_OmniTight(xTau)+6);
364 }
365}

◆ fillHistogramCut()

void DiTauSelectionCut::fillHistogramCut ( const xAOD::DiTauJet & xTau)
inherited

Definition at line 50 of file DiTauSelectionCuts.cxx.

51{
52 fillHistogram(xDiTau, *m_hHistCut);
53}
virtual void fillHistogram(const xAOD::DiTauJet &xTau, TH1F &hHist) const =0

◆ fillHistogramCutPre()

void DiTauSelectionCut::fillHistogramCutPre ( const xAOD::DiTauJet & xTau)
inherited

Definition at line 44 of file DiTauSelectionCuts.cxx.

45{
47}

◆ getName()

const std::string & TauAnalysisTools::DiTauSelectionCut::getName ( )
inlineinherited

Definition at line 45 of file DiTauSelectionCuts.h.

46 {
47 return m_sName;
48 };

◆ getProperty()

std::string DiTauSelectionCut::getProperty ( const std::string & name)
protectedinherited

Definition at line 73 of file DiTauSelectionCuts.cxx.

74{
75 std::map<std::string, std::string&>::iterator it = m_mProperties.find(name);
76 if(it == m_mProperties.end() )
77 throw std::runtime_error (("Undeclared property: " + name + "\n").c_str());
78
79 return it->second;
80}

◆ setAcceptInfo()

void DiTauSelectionCutOmniIDWP::setAcceptInfo ( asg::AcceptInfo & info) const
overridevirtual

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 368 of file DiTauSelectionCuts.cxx.

369{
370 info.addCut( "OmniIDWP",
371 "Selection of ditaus according to their OmniIDScore" );
372}

◆ setProperty()

void DiTauSelectionCut::setProperty ( const std::string & name,
const std::string & value )
inherited

Definition at line 57 of file DiTauSelectionCuts.cxx.

58{
59 std::map<std::string, std::string&>::iterator it = m_mProperties.find(name);
60 if(it == m_mProperties.end() )
61 throw std::runtime_error (("Undeclared property: " + name + "\n").c_str());
62 it->second = value;
63}

◆ writeControlHistograms()

void DiTauSelectionCut::writeControlHistograms ( )
inherited

Definition at line 24 of file DiTauSelectionCuts.cxx.

25{
26 m_hHistCutPre->Write();
27 m_hHistCut->Write();
28}

Member Data Documentation

◆ m_hHistCut

std::unique_ptr<TH1F> TauAnalysisTools::DiTauSelectionCut::m_hHistCut
protectedinherited

Definition at line 56 of file DiTauSelectionCuts.h.

◆ m_hHistCutPre

std::unique_ptr<TH1F> TauAnalysisTools::DiTauSelectionCut::m_hHistCutPre
protectedinherited

Definition at line 55 of file DiTauSelectionCuts.h.

◆ m_mProperties

std::map<std::string, std::string&> TauAnalysisTools::DiTauSelectionCut::m_mProperties
protectedinherited

Definition at line 61 of file DiTauSelectionCuts.h.

◆ m_sName

std::string TauAnalysisTools::DiTauSelectionCut::m_sName
protectedinherited

Definition at line 53 of file DiTauSelectionCuts.h.

◆ m_tDTST

DiTauSelectionTool* TauAnalysisTools::DiTauSelectionCut::m_tDTST
protectedinherited

Definition at line 58 of file DiTauSelectionCuts.h.


The documentation for this class was generated from the following files: