Loading [MathJax]/extensions/tex2jax.js
 |
ATLAS Offline Software
|
Go to the documentation of this file.
22 std::unique_ptr<TFile> calFile(TFile::Open(calFilePath.c_str(),
"READ"));
29 for (
size_t decayModeIndex = 0; decayModeIndex <
DecayModeBinning; ++ decayModeIndex) {
33 hist->SetDirectory(
nullptr);
39 return StatusCode::FAILURE;
43 tf1 =
dynamic_cast<TF1*
> (calFile->Get(
histName.c_str()));
50 return StatusCode::FAILURE;
55 TGraph* graph =
nullptr;
56 std::string graphName=
"";
57 for (
size_t decayModeIndex = 0; decayModeIndex <
DecayModeBinning; ++decayModeIndex) {
58 for (
size_t etaIndex = 0; etaIndex <
EtaBinning; ++etaIndex) {
61 graph =
dynamic_cast<TGraph*
> (calFile->Get(graphName.c_str()));
63 m_caloRelBiasMaxEt[decayModeIndex][etaIndex] = TMath::MaxElement(graph->GetN(), graph->GetX());
64 m_caloRelBias[decayModeIndex][etaIndex] = std::unique_ptr<TGraph>(graph);
68 ATH_MSG_FATAL(
"Failed to get an object with name " << graphName);
69 return StatusCode::FAILURE;
74 graph =
dynamic_cast<TGraph*
> (calFile->Get(graphName.c_str()));
76 m_caloResMaxEt[decayModeIndex][etaIndex] = TMath::MaxElement(graph->GetN(), graph->GetX());
77 m_caloRes[decayModeIndex][etaIndex] = std::unique_ptr<TGraph>(graph);
81 ATH_MSG_FATAL(
"Failed to get an object with name " << graphName);
82 return StatusCode::FAILURE;
87 graph =
dynamic_cast<TGraph*
> (calFile->Get(graphName.c_str()));
89 m_panTauRelBiasMaxEt[decayModeIndex][etaIndex] = TMath::MaxElement(graph->GetN(), graph->GetX());
90 m_panTauRelBias[decayModeIndex][etaIndex] = std::unique_ptr<TGraph>(graph);
94 ATH_MSG_FATAL(
"Failed to get an object with name " << graphName);
95 return StatusCode::FAILURE;
100 graph =
dynamic_cast<TGraph*
> (calFile->Get(graphName.c_str()));
102 m_panTauResMaxEt[decayModeIndex][etaIndex] = TMath::MaxElement(graph->GetN(), graph->GetX());
103 m_panTauRes[decayModeIndex][etaIndex] = std::unique_ptr<TGraph>(graph);
107 ATH_MSG_FATAL(
"Failed to get an object with name " << graphName);
108 return StatusCode::FAILURE;
114 graph =
dynamic_cast<TGraph*
> (calFile->Get(graphName.c_str()));
116 m_mvaResMaxEt[decayModeIndex][etaIndex] = TMath::MaxElement(graph->GetN(), graph->GetX());
117 m_mvaRes[decayModeIndex][etaIndex] = std::unique_ptr<TGraph>(graph);
121 ATH_MSG_FATAL(
"Failed to get an object with name " << graphName);
122 return StatusCode::FAILURE;
129 return StatusCode::SUCCESS;
151 decPtCombined(tau) = combinedP4.Pt();
152 decEtaCombined(tau) = combinedP4.Eta();
153 decPhiCombined(tau) = combinedP4.Phi();
154 decMCombined(tau) = combinedP4.M();
166 decPtConstituent(tau) =
variables.pt_constituent;
167 decPtTauRecCalibrated(tau) =
variables.pt_tauRecCalibrated;
168 decPtWeighted(tau) =
variables.pt_weighted;
169 decWeightWeighted(tau) =
variables.weight;
170 decSigmaCompatibility(tau) =
variables.sigma_compatibility;
171 decSigmaTaurec(tau) =
variables.sigma_tauRec;
172 decSigmaConstituent(tau) =
variables.sigma_constituent;
173 decCorrelationCoefficient(tau) =
variables.corrcoeff;
176 return StatusCode::SUCCESS;
182 if (!
isValid(tau))
return false;
192 bool compatibility =
true;
195 if (std::abs(deltaEt) > 5 * caloSigma) {
196 compatibility =
false;
199 return compatibility;
206 if (std::abs(
eta) < 0.3) {
209 if (std::abs(
eta) < 0.8) {
212 if (std::abs(
eta) < 1.3) {
215 if (std::abs(
eta) < 1.6) {
219 if (std::abs(
eta) < 2.6) {
238 return static_cast<int>(decayMode);
269 int etaIndex)
const {
279 double caloCalEt = caloEt -
ratio * caloEt;
288 int etaIndex)
const {
297 double panTauCalEt = panTauEt -
ratio * panTauEt;
342 double correlation)
const {
343 double cov = correlation * caloSigma * panTauSigma;
344 double caloWeight =
std::pow(panTauSigma, 2) -
cov;
345 double panTauWeight =
std::pow(caloSigma, 2) -
cov;
347 double weight = (caloWeight + panTauWeight !=0.) ? caloWeight/(caloWeight + panTauWeight) : 0.;
349 return std::clamp(
weight, 0., 1.);
354 double correlation)
const {
355 double compatibilitySigma2 =
std::pow(caloSigma, 2) +
std::pow(panTauSigma, 2) - 2 * correlation * caloSigma * panTauSigma;
357 return std::sqrt(compatibilitySigma2);
365 if (nsigma < 0.)
return 0.;
387 if (0. == caloSigma) {
389 m_caloRes[decayModeIndex][etaIndex]->Print(
"all");
395 if (0. == panTauSigma) {
397 m_panTauRes[decayModeIndex][etaIndex]->Print(
"all");
402 double caloCalEt =
getCaloCalEt(caloEt, decayModeIndex, etaIndex);
405 double panTauCalEt =
getPanTauCalEt(panTauEt, decayModeIndex, etaIndex);
410 double weightedEt =
weight * caloCalEt + (1 -
weight) * panTauCalEt;
419 double deltaEt = caloCalEt - panTauCalEt;
428 variables.sigma_constituent = panTauSigma;
429 variables.pt_tauRecCalibrated = caloCalEt;
432 variables.sigma_compatibility = compatibilitySigma;
435 "coff: " << correlation <<
" sigma(calo): " << caloSigma <<
" sigma(constituent): " << panTauSigma <<
436 "\ncalibrated et(calo): " << caloCalEt <<
" calibrated et(constituent): " << panTauCalEt <<
437 "\nweight:" <<
weight <<
" combined et: " << weightedEt <<
" compatibility sigma: " << compatibilitySigma);
448 ATH_MSG_DEBUG(
"Four momentum at calo TES, pt: " << caloP4.Pt() <<
" eta: " << caloP4.Eta() <<
449 " phi: " << caloP4.Phi() <<
" mass: " << caloP4.M());
450 ATH_MSG_DEBUG(
"Four momentum at PanTau, pt: " << panTauP4.Pt() <<
" eta: " << panTauP4.Eta() <<
451 " phi: " << panTauP4.Phi() <<
" mass: " << panTauP4.M());
458 TLorentzVector combinedP4;
459 combinedP4.SetPtEtaPhiM(combinedEt, panTauP4.Eta(), panTauP4.Phi(), 0.);
461 ATH_MSG_DEBUG(
"Combined four momentum, pt: " << combinedP4.Pt() <<
" eta: " << combinedP4.Eta() <<
462 " phi: " << combinedP4.Phi() <<
" mass: " << combinedP4.M());
double getCaloCalEt(double et, int decayModeIndex, int etaIndex) const
Get the Et at the calo TES after calibration correction.
double getMvaEnergyResolution(const xAOD::TauJet &tau) const
Get MVA Et resolution, invoked by METSignificance.
std::array< std::array< double, EtaBinning >, DecayModeBinning > m_mvaResMaxEt
Maximum Et of m_mvaRes.
bool getTESCompatibility(const xAOD::TauJet &tau) const
Check if MVA TES and CaloTES are compatible, invoked by TauSmearing tool.
Extra patterns decribing particle interation process.
double etaTauEnergyScale() const
int getDecayModeIndex(xAOD::TauJetParameters::DecayMode decayMode) const
Get the index of decay mode in the calibration histogram.
Gaudi::Property< bool > m_useMvaResolution
Scalar eta() const
pseudorapidity method
bool isValid(const xAOD::TauJet &tau) const
Whether the tau candidate is valid for the calculation.
std::array< std::array< double, EtaBinning >, DecayModeBinning > m_caloRelBiasMaxEt
Maximum Et of m_caloRelBias.
double etaFinalCalib() const
int getEtaIndex(float eta) const
Get the index of eta in the calibration histogram.
virtual StatusCode initialize() override
Tool initializer.
Gaudi::Property< std::string > m_calFileName
std::array< std::unique_ptr< TF1 >, DecayModeBinning > m_nSigmaCompatibility
Maximum tolerence in unit of combined sigma, as a function of calo Et.
bool panTauDetail(TauJetParameters::PanTauDetails panTauDetail, int &value) const
Get and set values of pantau details variables via enum.
Gaudi::Property< bool > m_addCalibrationResultVariables
double resolution[nGasTypes][nParametersResolution]
double getCorrelation(int decayModeIndex, int etaIndex) const
Get correlation coefficient between the calo TES and PanTau.
double ptTauEnergyScale() const
::StatusCode StatusCode
StatusCode definition for legacy code.
const std::array< std::string, DecayModeBinning > m_decayModeNames
Decay mode binning in the calibration graph/hist.
double getCaloResolution(double et, int decayModeIndex, int etaIndex) const
Get the resolution of Et at the calo TES.
Class describing a tau jet.
double getCompatibilitySigma(double caloSigma, double panTauSigma, double correlation) const
Get the compatibility sigma of calo TES and PanTau.
std::array< std::unique_ptr< TH1F >, DecayModeBinning > m_correlationHists
Calibration histogram: correlation coefficient of calo TES and PanTau.
std::array< std::array< std::unique_ptr< TGraph >, EtaBinning >, DecayModeBinning > m_panTauRelBias
Calibration graph: mean of bias/panTauEt as a funtion of panTauEt.
const std::array< std::string, EtaBinning > m_etaBinNames
Eta binning in the calibration graph.
double getWeight(double caloSigma, double panTauSigma, double correlatioon) const
Get the weight of calo TES.
xAOD::TauJetParameters::DecayMode getDecayMode(const xAOD::TauJet &tau) const
Get the decay mode of the tau candidate.
virtual StatusCode execute(xAOD::TauJet &xTau) const override
Execute - called for each tau candidate.
double getPanTauResolution(double et, int decayModeIndex, int etaIndex) const
Get the resolution of Et at PanTau.
std::array< std::array< double, EtaBinning >, DecayModeBinning > m_panTauRelBiasMaxEt
Maximum Et of m_panTauRelBias.
double getPanTauCalEt(double panTauEt, int decayModeIndex, int etaIndex) const
Get the Et at PanTau after calibration correction.
double getNsigmaCompatibility(double caloEt, int decayModeIndex) const
Get the allowed difference between calo TES and PanTau.
TauCombinedTES(const std::string &name="TauCombinedTES")
std::array< std::array< std::unique_ptr< TGraph >, EtaBinning >, DecayModeBinning > m_caloRelBias
Calibration graph: mean of bias/caloEt as a function of caloEt.
std::array< std::array< double, EtaBinning >, DecayModeBinning > m_caloResMaxEt
Maximum Et of m_caloRes.
#define ATH_MSG_WARNING(x)
virtual FourMom_t p4() const
The full 4-momentum of the particle.
std::array< std::array< std::unique_ptr< TGraph >, EtaBinning >, DecayModeBinning > m_caloRes
Calibration graph: resolution at Calo TES as a function of caloEt.
std::array< std::array< double, EtaBinning >, DecayModeBinning > m_panTauResMaxEt
Maximum Et of m_panTauRes.
def TH1F(name, title, nxbins, bins_par2, bins_par3=None, path='', **kwargs)
double getCombinedEt(double caloEt, double et_substructure, xAOD::TauJetParameters::DecayMode decayMode, float eta, Variables &variables) const
Get the combined Et of calo TES and PanTau.
std::array< std::array< std::unique_ptr< TGraph >, EtaBinning >, DecayModeBinning > m_mvaRes
Calibration graph: MVA TES resolution as a function of MVA pt.
TLorentzVector getCombinedP4(const xAOD::TauJet &tau, Variables &variables) const
Get the weighted four momentum of calo TES and PanTau.
constexpr int pow(int base, int exp) noexcept
double ptFinalCalib() const
std::array< std::array< std::unique_ptr< TGraph >, EtaBinning >, DecayModeBinning > m_panTauRes
Calibration graph: resolution at PanTau as a function of panTauEt.