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)
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

Private Attributes

float m_bDiTauCharge

Detailed Description

Definition at line 104 of file DiTauSelectionCuts.h.

Constructor & Destructor Documentation

◆ DiTauSelectionCutAbsCharge()

DiTauSelectionCutAbsCharge::DiTauSelectionCutAbsCharge ( DiTauSelectionTool * tDTST)

Definition at line 221 of file DiTauSelectionCuts.cxx.

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

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 242 of file DiTauSelectionCuts.cxx.

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

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 DiTauSelectionCutAbsCharge::fillHistogram ( const xAOD::DiTauJet & xTau,
TH1F & hHist ) const
overrideprivatevirtual

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 230 of file DiTauSelectionCuts.cxx.

231{
232 hHist.Fill(m_bDiTauCharge);
233}

◆ 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 DiTauSelectionCutAbsCharge::setAcceptInfo ( asg::AcceptInfo & info) const
overridevirtual

Implements TauAnalysisTools::DiTauSelectionCut.

Definition at line 236 of file DiTauSelectionCuts.cxx.

237{
238 info.addCut( "AbsCharge",
239 "Selection of taus according to their absolute charge" );
240}

◆ 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_bDiTauCharge

float TauAnalysisTools::DiTauSelectionCutAbsCharge::m_bDiTauCharge
private

Definition at line 113 of file DiTauSelectionCuts.h.

◆ 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: