From 6cd6fc712c87b19401c02590929c1d39e8f3459d Mon Sep 17 00:00:00 2001 From: Frank Winklmeier <frank.winklmeier@cern.ch> Date: Fri, 13 May 2022 09:54:13 +0200 Subject: [PATCH 1/2] FakeBkgTools: do not write unit test files to /tmp Do not use `/tmp` for unit test files. Instead just write to the current directory. This avoids problems when `/tmp` is not writable. --- .../AnalysisCommon/FakeBkgTools/CMakeLists.txt | 3 --- .../FakeBkgTools/util/fbtTestBasics.cxx | 14 +++++++------- 2 files changed, 7 insertions(+), 10 deletions(-) diff --git a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/CMakeLists.txt b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/CMakeLists.txt index fe391ae2ca04..41d371d7bbe6 100644 --- a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/CMakeLists.txt +++ b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/CMakeLists.txt @@ -1,7 +1,4 @@ # Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration -################################################################################ -# Package: FakeBkgTools -################################################################################ atlas_subdir( FakeBkgTools ) find_package( Boost ) diff --git a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/util/fbtTestBasics.cxx b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/util/fbtTestBasics.cxx index f7ca6696c5d3..c19a0d176d82 100644 --- a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/util/fbtTestBasics.cxx +++ b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/util/fbtTestBasics.cxx @@ -140,16 +140,16 @@ bool allTests() if(verbose) std::cout <<"\nWill test parallel jobs and merging\n"; eventOffset = 0; nEvents = 16; - FBT_CHECK( parallelJob("CP::LhoodMM_tools", "/tmp/fbt_job1.root") ); + FBT_CHECK( parallelJob("CP::LhoodMM_tools", "fbt_job1.root") ); eventOffset = 16; - FBT_CHECK( parallelJob("CP::LhoodMM_tools", "/tmp/fbt_job2.root") ); + FBT_CHECK( parallelJob("CP::LhoodMM_tools", "fbt_job2.root") ); eventOffset = 32; - FBT_CHECK( parallelJob("CP::LhoodMM_tools", "/tmp/fbt_job3.root") ); + FBT_CHECK( parallelJob("CP::LhoodMM_tools", "fbt_job3.root") ); eventOffset = 0; - FBT_CHECK( gSystem->Exec("hadd -f /tmp/fbt_merged.root /tmp/fbt_job*.root") == 0 ); + FBT_CHECK( gSystem->Exec("hadd -f fbt_merged.root fbt_job*.root") == 0 ); { asg::AnaToolHandle<CP::IFakeBkgTool> tool; - progressFile = "/tmp/fbt_merged.root"; + progressFile = "fbt_merged.root"; FBT_CHECK( setup(tool, "CP::LhoodMM_tools") ); progressFile.clear(); FBT_CHECK( fillResult(tool, result5) ); @@ -315,7 +315,7 @@ void Result::Print() const bool readFromROOT() { config.clear(); - config.emplace_back("/tmp/fbt_efficiencies.root"); + config.emplace_back("fbt_efficiencies.root"); TH1D hElFake("FakeEfficiency_el_pt","FakeEfficiency", 1, 10., 100.); hElFake.SetBinContent(1, 0.05); hElFake.SetBinError(1, 0.01); @@ -342,7 +342,7 @@ bool readFromROOT() bool readFromXML() { config.clear(); - config.emplace_back("/tmp/fbt_efficiencies.xml"); + config.emplace_back("fbt_efficiencies.xml"); std::ofstream out(config.back().c_str(), std::ios_base::out); FBT_CHECK( out.is_open() ); /// note: the declarations must be placed in the "good" order, -- GitLab From d26a969f01e3dc7a72d171e0ec0ba8cee8489fbd Mon Sep 17 00:00:00 2001 From: Frank Winklmeier <frank.winklmeier@cern.ch> Date: Fri, 13 May 2022 10:06:07 +0200 Subject: [PATCH 2/2] FakeBkgTools: make code compliant with ATLAS naming convention - Make `LhoodMMFitInfo` a `struct`. It has only one client that was declared as `friend`. May as well just have everything public. - Use `s_` prefix for static members. --- .../FakeBkgTools/LhoodMMFitInfo.h | 28 +++++------ .../FakeBkgTools/FakeBkgTools/LhoodMM_tools.h | 10 ++-- .../FakeBkgTools/Root/LhoodMM_tools.cxx | 48 +++++++++---------- 3 files changed, 40 insertions(+), 46 deletions(-) diff --git a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMMFitInfo.h b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMMFitInfo.h index 39ce1e021e4d..34fbb881caed 100644 --- a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMMFitInfo.h +++ b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMMFitInfo.h @@ -10,25 +10,21 @@ class TTree; namespace CP { - class LhoodMMFitInfo{ + struct LhoodMMFitInfo{ - public: LhoodMMFitInfo(int nlep = 1); - private: - std::vector< std::vector < std::vector< FakeBkgTools::Efficiency> > > coeffs_num; - std::vector < std::vector< FakeBkgTools::Efficiency> > normterms; - std::vector<std::vector<double> > event_cat; - std::vector<std::vector<double> > event_sumw2; - std::vector< std::vector < double > > OSfrac_num; - std::vector< std::vector < double > > OSfrac_denom; - int totEvents; - std::vector<double> eventCount; - void reset(); - void resizeVectors(unsigned nlep); - void add(LhoodMMFitInfo& rhs, int nLepMax); - - friend class LhoodMM_tools; + std::vector< std::vector < std::vector< FakeBkgTools::Efficiency> > > coeffs_num; + std::vector < std::vector< FakeBkgTools::Efficiency> > normterms; + std::vector<std::vector<double> > event_cat; + std::vector<std::vector<double> > event_sumw2; + std::vector< std::vector < double > > OSfrac_num; + std::vector< std::vector < double > > OSfrac_denom; + int totEvents; + std::vector<double> eventCount; + void add(LhoodMMFitInfo& rhs, int nLepMax); + void resizeVectors(unsigned nlep); + void reset(); }; diff --git a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMM_tools.h b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMM_tools.h index ecb51eb35b8d..81b57ee452ee 100644 --- a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMM_tools.h +++ b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/FakeBkgTools/LhoodMM_tools.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration */ #ifndef Lhood_MM_tools_h @@ -105,8 +105,8 @@ class LhoodMM_tools : public BaseFakeBkgTool bool m_alreadyMerged; - static const int nLepMax = 6; - static const int maxRank = 64; // i.e. 2^nLepMax + inline static const int s_nLepMax = 6; + inline static const int s_maxRank = 64; // i.e. 2^nLepMax std::vector < std::vector < std::vector < double > > > m_coeffs; @@ -135,8 +135,8 @@ class LhoodMM_tools : public BaseFakeBkgTool unsigned m_lastSaveIndex; //mathematical constants - const double _piover2 = 1.57079632679489661923; - const double _piover4 = 0.785398163397448309616; + inline static const double s_piover2 = 1.57079632679489661923; + inline static const double s_piover4 = 0.785398163397448309616; StatusCode setup(); diff --git a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/Root/LhoodMM_tools.cxx b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/Root/LhoodMM_tools.cxx index c14418c95f03..6f3d076056c6 100644 --- a/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/Root/LhoodMM_tools.cxx +++ b/PhysicsAnalysis/AnalysisCommon/FakeBkgTools/Root/LhoodMM_tools.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration */ #include <iostream> @@ -35,8 +35,6 @@ using std::string; using std::vector; using Clock=std::chrono::high_resolution_clock; -const int LhoodMM_tools::nLepMax; -const int LhoodMM_tools::maxRank; LhoodMM_tools* LhoodMM_tools::m_current_lhoodMM_tool; @@ -92,9 +90,9 @@ void LhoodMM_tools::reset() { m_fixNormalization = false; m_coeffs.clear(); - m_coeffs.resize(nLepMax); + m_coeffs.resize(s_nLepMax); - for (int ilep = 0; ilep < nLepMax; ilep++) { + for (int ilep = 0; ilep < s_nLepMax; ilep++) { m_coeffs[ilep].clear(); m_coeffs[ilep].resize((0x1 << (ilep+1)) ); for (int ientry = 0; ientry < (0x1 << (ilep+1)); ientry++) { @@ -106,9 +104,9 @@ void LhoodMM_tools::reset() { } m_real_indices.clear(); - m_real_indices.resize(nLepMax); + m_real_indices.resize(s_nLepMax); m_fake_indices.clear(); - m_fake_indices.resize(nLepMax); + m_fake_indices.resize(s_nLepMax); m_maxnlep_loose = 0; @@ -116,12 +114,12 @@ void LhoodMM_tools::reset() { m_requireOS = false; m_fsvec.clear(); - m_fsvec.resize(nLepMax); + m_fsvec.resize(s_nLepMax); m_OSfrac.clear(); - m_OSfrac.resize(nLepMax); + m_OSfrac.resize(s_nLepMax); - for (int ilep = 0; ilep <nLepMax; ilep++) { + for (int ilep = 0; ilep <s_nLepMax; ilep++) { m_OSfrac[ilep].resize(ilep); } @@ -129,11 +127,11 @@ void LhoodMM_tools::reset() { m_nrf_mat_vec.clear(); m_MMmatrix_vec.clear(); - m_nrf_mat_vec.resize(nLepMax); - m_MMmatrix_vec.resize(nLepMax); + m_nrf_mat_vec.resize(s_nLepMax); + m_MMmatrix_vec.resize(s_nLepMax); m_ntlpred_vec.clear(); - m_ntlpred_vec.resize(nLepMax); - for (int ilep = 0; ilep < nLepMax; ilep++) { + m_ntlpred_vec.resize(s_nLepMax); + for (int ilep = 0; ilep < s_nLepMax; ilep++) { m_nrf_mat_vec[ilep] = std::shared_ptr<TMatrixT<double>>(std::make_shared<TMatrixT<double>>(0x1 << (ilep+1),1) ); m_MMmatrix_vec[ilep] = std::shared_ptr<TMatrixT<double>>(std::make_shared<TMatrixT<double>> ((0x1 << (ilep+1)),(0x1 << (ilep+1)))); m_ntlpred_vec[ilep] = std::shared_ptr<TMatrixT<double>>(std::make_shared< TMatrixT<double>>(0x1 << (ilep+1),1)); @@ -425,7 +423,7 @@ StatusCode LhoodMM_tools::incrementOneMatrixSet(LhoodMMFitInfo& fitInfo, fitInfo.eventCount[lepidx]++; - if (nlep <= nLepMax) { + if (nlep <= s_nLepMax) { ATH_MSG_VERBOSE("In incrementMatrices, how many uncertainties? " << mmevt.realEffObj(0).uncertainties.size()); ATH_MSG_VERBOSE("In incrementMatrices, m_totEvents = " << fitInfo.totEvents); @@ -450,7 +448,7 @@ StatusCode LhoodMM_tools::incrementOneMatrixSet(LhoodMMFitInfo& fitInfo, //check to see if there is at least one OS pair... for (int icomb = 0; icomb < (0x1 << nlep); icomb++) { int totcharge = 0; - std::bitset<nLepMax+1> tights(icomb); + std::bitset<s_nLepMax+1> tights(icomb); int ntight = tights.count(); for (int jlep = 0; jlep < nlep; jlep++) { @@ -519,7 +517,7 @@ StatusCode LhoodMM_tools::incrementOneMatrixSet(LhoodMMFitInfo& fitInfo, } return StatusCode::SUCCESS; } else { - ATH_MSG_ERROR( "Error: can only handle " << nLepMax << " leptons; you tried " << nlep); + ATH_MSG_ERROR( "Error: can only handle " << s_nLepMax << " leptons; you tried " << nlep); return StatusCode::FAILURE; } @@ -585,7 +583,7 @@ void LhoodMM_tools::fcn_minnlep_maxnlep(Int_t &npar, Double_t *gin, Double_t &f, ASG_MSG_VERBOSE("theta_nlep_index for ilep = " << ilep << " = " << theta_nlep_index); } - Double_t pars_thisnlep[maxRank]; // a bit of a waste of memory, but avoids compiler warnings for variable- + Double_t pars_thisnlep[s_maxRank]; // a bit of a waste of memory, but avoids compiler warnings for variable- if(verbose) ASG_MSG_VERBOSE("theta_nlep_index = " << theta_nlep_index); @@ -755,13 +753,13 @@ double LhoodMM_tools::nfakes(Double_t *poserr, Double_t *negerr) { m_fitStatus = 0; - m_minnlep = nLepMax; + m_minnlep = s_nLepMax; m_maxnlep = 0; m_requireSS = false; m_requireOS = false; - for (int ilep = 0; ilep < nLepMax; ilep++) { + for (int ilep = 0; ilep < s_nLepMax; ilep++) { string error; // possible issue here -- reassigning vector elements? m_fsvec[ilep].reset(new FakeBkgTools::FinalState(0, ilep+1, m_selection, m_process, error)); @@ -954,7 +952,7 @@ double LhoodMM_tools::nfakes(Double_t *poserr, Double_t *negerr) { ATH_MSG_VERBOSE("nfakes for nlep = " << ilep << " used to find theta_tot = " << loc_init_pars[ilep-1][0]); theta_tot[theta_index] = TMath::ACos(TMath::Sqrt(TMath::Max(loc_init_pars[ilep-1][0],0.)/(m_nfakes_std))/sinterm); if (TMath::IsNaN( theta_tot[theta_index] ) ) { - theta_tot[theta_index] = _piover4; + theta_tot[theta_index] = s_piover4; } sinterm *= TMath::Sin(theta_tot[theta_index]); theta_index++; @@ -962,7 +960,7 @@ double LhoodMM_tools::nfakes(Double_t *poserr, Double_t *negerr) { } else { int theta_index = 0; for (int ilep = m_minnlep; ilep < m_maxnlep_loose; ilep++ ){ - theta_tot[theta_index] = _piover4; + theta_tot[theta_index] = s_piover4; theta_index++; } } @@ -982,7 +980,7 @@ double LhoodMM_tools::nfakes(Double_t *poserr, Double_t *negerr) { } for (int ipar = real_index; ipar < npar; ipar++) { - upper_limits[ipar] = _piover2; + upper_limits[ipar] = s_piover2; } //re-organize from "per-lepton" parameters to global parameters @@ -1056,7 +1054,7 @@ double LhoodMM_tools::nfakes(Double_t *poserr, Double_t *negerr) { } //now the theta_tot angle associated with this multiplicity arglist[0] = m_theta_tot_start_index + ilep - m_minnlep +1; - arglist[1] = _piover2; + arglist[1] = s_piover2; lhoodFit->mnexcm("SET PAR", arglist, 2, ierflg); lhoodFit->mnexcm("FIX PAR", arglist, 1, ierflg); @@ -1310,7 +1308,7 @@ void LhoodMM_tools::get_init_pars(vector<double> &init_pars, int nlep) { } } else { for (int ipar = m_real_indices[lepidx].size()+1; ipar < (0x1 << nlep); ipar++) { - init_pars[ipar] = _piover4; + init_pars[ipar] = s_piover4; } } -- GitLab