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

#include <DiTauSelectionCuts.h>

Inheritance diagram for TauAnalysisTools::DiTauSelectionCutAbsCharge:
Collaboration diagram for TauAnalysisTools::DiTauSelectionCutAbsCharge:

Public Member Functions

 DiTauSelectionCutAbsCharge (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)
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
TH1F * m_hHistCutPre
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

Private Attributes

float m_bDiTauCharge

Detailed Description

Definition at line 102 of file DiTauSelectionCuts.h.

Constructor & Destructor Documentation

◆ DiTauSelectionCutAbsCharge()

DiTauSelectionCutAbsCharge::DiTauSelectionCutAbsCharge ( DiTauSelectionTool * tDTST)

Definition at line 226 of file DiTauSelectionCuts.cxx.

227 : DiTauSelectionCut("CutAbsCharge", tDTST),
228 m_bDiTauCharge(-1234)
229{
230 m_hHistCutPre = CreateControlPlot("hCharge_pre","Charge_pre;charge; events",7,-3.5,3.5);
231 m_hHistCut = CreateControlPlot("hCharge_cut","Charge_cut;charge; events",7,-3.5,3.5);
232}
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 DiTauSelectionCutAbsCharge::accept ( const xAOD::DiTauJet & xTau,
asg::AcceptData & accept )
overridevirtual

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 247 of file DiTauSelectionCuts.cxx.

249{
250 m_bDiTauCharge = 0;
251 static const SG::ConstAccessor<float> acc_charge ("charge");
252 if ( acc_charge.isAvailable(xTau) ) {
253 m_bDiTauCharge = acc_charge(xTau);
254 } else {
255 for (const auto& xTrack : xTau.trackLinks()) {
256 if (!xTrack.isValid())
257 continue;
258
259 if(xTau.nSubjets() >= 2){
260 for (int i = 0; i < 2; ++i) { // loop over two leading subjets
261 TLorentzVector tlvSubjet = TLorentzVector();
262 tlvSubjet.SetPtEtaPhiE(xTau.subjetPt(i), xTau.subjetEta(i),
263 xTau.subjetPhi(i), xTau.subjetE(i));
264 double dR = tlvSubjet.DeltaR((*xTrack)->p4());
265 if (dR < 0.1) {
266 m_bDiTauCharge += (*xTrack)->charge();
267 break; //prevents double counting of tracks
268 }
269 } // loop over subjets
270 }
271 } // loop over tracks
272 }
273
274 // check charge, if ditau has one of the charges requiered then return true; false otherwise
275 for( unsigned int iCharge = 0; iCharge < m_tDTST->m_vAbsCharges.size(); iCharge++ )
276 {
277 if ( std::abs( m_bDiTauCharge ) == m_tDTST->m_vAbsCharges.at(iCharge) )
278 {
279 acceptData.setCutResult( "AbsCharge", true );
280 return true;
281 }
282 }
283 m_tDTST->msg() << MSG::VERBOSE << "DiTau failed charge requirement, ditau charge: " << m_bDiTauCharge << endmsg;
284 return false;
285
286}
#define endmsg
float subjetEta(unsigned int numSubjet) const
float subjetE(unsigned int numSubjet) const
float subjetPt(unsigned int numSubjet) const
float subjetPhi(unsigned int numSubjet) const
const TrackParticleLinks_t & trackLinks() const
float nSubjets() const

◆ CreateControlPlot()

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

Definition at line 36 of file DiTauSelectionCuts.cxx.

37{
38 if (m_tDTST->m_bCreateControlPlots)
39 {
40 TH1F* hHist = new TH1F(sName, sTitle, iBins, dXLow, dXUp);
41 hHist->SetDirectory(0);
42 return hHist;
43 }
44
45 return nullptr;
46}
TH1F(name, title, nxbins, bins_par2, bins_par3=None, path='', **kwargs)

◆ declareProperty()

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

Definition at line 71 of file DiTauSelectionCuts.cxx.

72{
73 std::pair<std::string, std::string&> p(name, loc);
74 m_mProperties.insert(p);
75}
std::map< std::string, std::string & > m_mProperties

◆ fillHistogram()

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

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 235 of file DiTauSelectionCuts.cxx.

236{
237 hHist.Fill(m_bDiTauCharge);
238}

◆ fillHistogramCut()

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

Definition at line 55 of file DiTauSelectionCuts.cxx.

56{
57 fillHistogram(xDiTau, *m_hHistCut);
58}
virtual void fillHistogram(const xAOD::DiTauJet &xTau, TH1F &hHist) const =0

◆ fillHistogramCutPre()

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

Definition at line 49 of file DiTauSelectionCuts.cxx.

50{
52}

◆ getName()

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

Definition at line 43 of file DiTauSelectionCuts.h.

44 {
45 return m_sName;
46 };

◆ getProperty()

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

Definition at line 78 of file DiTauSelectionCuts.cxx.

79{
80 std::map<std::string, std::string&>::iterator it = m_mProperties.find(name);
81 if(it == m_mProperties.end() )
82 throw std::runtime_error (("Undeclared property: " + name + "\n").c_str());
83
84 return it->second;
85}

◆ setAcceptInfo()

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

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 241 of file DiTauSelectionCuts.cxx.

242{
243 info.addCut( "AbsCharge",
244 "Selection of taus according to their absolute charge" );
245}

◆ setProperty()

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

Definition at line 62 of file DiTauSelectionCuts.cxx.

63{
64 std::map<std::string, std::string&>::iterator it = m_mProperties.find(name);
65 if(it == m_mProperties.end() )
66 throw std::runtime_error (("Undeclared property: " + name + "\n").c_str());
67 it->second = value;
68}

◆ writeControlHistograms()

void DiTauSelectionCut::writeControlHistograms ( )
inherited

Definition at line 29 of file DiTauSelectionCuts.cxx.

30{
31 m_hHistCutPre->Write();
32 m_hHistCut->Write();
33}

Member Data Documentation

◆ m_bDiTauCharge

float TauAnalysisTools::DiTauSelectionCutAbsCharge::m_bDiTauCharge
private

Definition at line 111 of file DiTauSelectionCuts.h.

◆ m_hHistCut

TH1F* TauAnalysisTools::DiTauSelectionCut::m_hHistCut
protectedinherited

Definition at line 54 of file DiTauSelectionCuts.h.

◆ m_hHistCutPre

TH1F* TauAnalysisTools::DiTauSelectionCut::m_hHistCutPre
protectedinherited

Definition at line 53 of file DiTauSelectionCuts.h.

◆ m_mProperties

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

Definition at line 59 of file DiTauSelectionCuts.h.

◆ m_sName

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

Definition at line 51 of file DiTauSelectionCuts.h.

◆ m_tDTST

DiTauSelectionTool* TauAnalysisTools::DiTauSelectionCut::m_tDTST
protectedinherited

Definition at line 56 of file DiTauSelectionCuts.h.


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