EWP-BplusToKstMuMu-AngAna/Code/Scripts/LaTeX/GetTableOfMVASignificance.cc

170 lines
6.2 KiB
C++
Raw Permalink Normal View History

//Create tables of BDT significance for B+->Kst+mumu
//david gerick
#include "../../GlobalFunctions.hh"
#include "../../HeidelbergFitter/LHCbStyle.h"
//#include "MVA_b2kmm.cc"
using namespace std;
using namespace RooFit ;
//////////////////////////////////////////////////////
/// GetMVASignificance()
///
void GetMVASignificance(std::vector<Int_t> Run, std::vector<std::string> DDLL, std::string BDTmethod) {
bool debug = false;
UInt_t NN = Run.size();
assert(NN == DDLL.size());
std::vector< std::vector<int> > rank;
std::vector< std::vector< std::string> > latex_name;
std::vector< std::vector<float> > value;
for(UInt_t n = 0; n < NN; n++){
std::cout << "[LOAD]\t\tRun" << Run.at(n) << " " << DDLL.at(n) << std::endl;
//load MVAconfig
MVA_variables vars(DDLL.at(n));
rank.push_back(std::vector<int>());
latex_name.push_back(std::vector<std::string>());
value.push_back(std::vector<float>());
//load results from .txt (This has to be saved manually from the MVA training output, before creating the LaTeX table)
std::ifstream file;
std::string line = "";
std::string filename = path_to_data+"/"+BDTmethod+"results_Run"+std::to_string(Run.at(n))+DDLL.at(n)+".txt";
file.open(filename);
if (file.is_open()){
std::cout << "[INFO]\t\tOpened the result file: " << filename << std::endl;
std::cout << "[INFO]\t\tProceed with loading the results!" << std::endl;
}
else{
std::cout << "[ERROR]\t\tCould not load the result file: " << filename << std::endl;
std::cout << "[ERROR]\t\tMake sure, the result from the MVA training are copied (by hand) into the *.txt file" << std::endl;
std::cout << "[ERROR]\t\tThe part that needs to be copied looks something like this:" << std::endl;
std::cout << "[ERROR]\t\t" << std::endl;
for(UInt_t i = 0; i < 8; i++)
std::cout << "[ERROR]\t\t--- " << BDTmethod << " : " << i+1 << " : variable" << i+1 << " : value" << std::endl;
return;
}
while(1){ //loop over lines until you find the end of the file
getline(file, line);
if(file.eof()) break;
if(line.length() == 0)continue;
size_t first_colon = line.find(":");
if(first_colon == line.length())continue;
size_t secon_colon = line.find(":", first_colon+1);
if(secon_colon == line.length())continue;
size_t third_colon = line.find(":", secon_colon+1);
if(third_colon == line.length())continue;
if(debug){
std::cout << "Line: '" << line << "'\twith length=" << line.length() << std::endl;
std::cout << "First ':' at pos=" << first_colon << "\tSecond ':' at pos=" << secon_colon << "\tThird ':' at pos=" << third_colon << std::endl;
}
//save the rank
rank.at(n).push_back(atoi(line.substr(first_colon+1, secon_colon-first_colon-2).c_str()));
std::string branch_name = line.substr(secon_colon+2, third_colon-secon_colon-2);
while(replace(branch_name, " ", ""));
while(replace(branch_name, "log_", ""));
//convert and save the LaTeX name
Int_t var = 0;
while(var < vars.NumberOfVariables()){
if(vars.AllVariables.at(var).ReaderName.find(branch_name.c_str()) < vars.AllVariables.at(var).ReaderName.length())
break;
var++;
}
if(var == vars.NumberOfVariables()){
std::cout << "[ERROR]\t\tNo LaTeX name found for varialbe: '" << branch_name << "'" << std::endl;
return;
}
latex_name.at(n).push_back(vars.AllVariables.at(var).LaTeXName);
while(replace(latex_name.at(n).back(), "K_{s}^{0}", "\\KS "));
while(replace(latex_name.at(n).back(), "K_{s}", "\\KS "));
while(replace(latex_name.at(n).back(), "B^{+}", "\\Bu "));
while(replace(latex_name.at(n).back(), "#chi^{2}", "\\chisq "));
while(replace(latex_name.at(n).back(), "#mu^{+}", "\\mup "));
while(replace(latex_name.at(n).back(), "#mu^{-}", "\\mun "));
while(replace(latex_name.at(n).back(), "K^{*+}", "\\Kstarp "));
while(replace(latex_name.at(n).back(), "#pi^{+}", "\\pip "));
while(replace(latex_name.at(n).back(), "p_{T}", "\\pt "));
while(replace(latex_name.at(n).back(), "#eta", "$\\eta$"));
while(replace(latex_name.at(n).back(), "#", "\\"));
// while(replace(latex_name.at(n).back(), "", ""));
//save the MVA significance value (in %)
value.at(n).push_back(atof(line.substr(third_colon+2).c_str())*100.);
}
assert(rank.at(n).size() == latex_name.at(n).size());
assert(rank.at(n).size() == value.at(n).size());
if(debug){
for(UInt_t i = 0; i < rank.at(n).size(); i++){
std::cout << "#" << rank.at(n).at(i) << ": " << latex_name.at(n).at(i) << " = " << Form("%.2f", value.at(n).at(i)) << std::endl;
}
}
file.close();
}
//print LaTeX table:
std::cout << std::endl << std::endl << std::endl;
std::cout << "\\begin{center}\\begin{tabular}{";
for(UInt_t n = 0; n < NN; n++)
std::cout << "lr";
std::cout << "} \\hline" << std::endl;
for(UInt_t n = 0; n < NN; n++){
if(n != 0)
std::cout << "\t&";
std::cout << "Run " << Run.at(n);
if(DDLL.at(n) != "")
std::cout << " \\" << DDLL.at(n);
std::cout << "\t&[\\\%]";
}
std::cout << "\\\\" << std::endl;
std::cout << "\\hline" << std::endl;
for(UInt_t v = 0; v < rank.at(0).size(); v++){
for(UInt_t n = 0; n < NN; n++){
if(n != 0)
std::cout << "\t&";
if(latex_name.at(n).size() > v)
std::cout << latex_name.at(n).at(v) << "\t&" << Form("%.2f", value.at(n).at(v));
else
std::cout << "\t &";
}
std::cout << "\\\\" << std::endl;
}
std::cout << "\\hline" << std::endl;
std::cout << "\\end{tabular}\\end{center}" << std::endl;
std::cout << std::endl << std::endl << std::endl;
return;
}
void GetAllMVATables(){
std::string method = std::string(TMVAmethod);
if(Kst2Kspiplus){
GetMVASignificance({1, 1}, {"DD", "LL"}, method);
GetMVASignificance({2, 2}, {"DD", "LL"}, method);
}
else{
GetMVASignificance({1, 2}, {"",""}, method);
}
}