EWP-BplusToKstMuMu-AngAna/Code/Selection/ReorganizeTGraph.py

55 lines
1.7 KiB
Python

#Reorganizes the arrays in TGraph in a way x is ascending, as ROOT is stupidly behaving when plotting when it is not the case
#Renata Kopecna
from ROOT import TTree, TChain, TFile, TVector3, TObject, TGraphErrors, TGraph
import numpy as np
import os
'''
Tool for removing multiple candidates after TMVA.
Adds a branch with a boolean for each TMVA cut, whether the event should be removed or not
New version, as there is something wrong with 2016
'''
def redoGraph(Run, graphFile, name):
graph = graphFile.Get("MLP "+name+"Run"+str(Run))
size = graph.GetN()
buffer_X = graph.GetX()
X = np.fromiter(buffer_X,dtype=np.float, count = size)
buffer_Y = graph.GetY()
Y = np.fromiter(buffer_Y,dtype=np.float, count = size)
arr = np.column_stack((X,Y))
arr = np.unique(arr,axis=0)
print(arr)
X = arr[:,0].flatten('C')
Y = arr[:,1].flatten('C')
newGraph = TGraph(X.size,X,Y)
newGraph.SetTitle(name)
newGraph.SetName(name)
return newGraph
def rewriteMVAscan(Run):
path = "/home/lhcb/kopecna/B2KstarMuMu_clean/Data/Tuples/FinalSelection/KplusPi0Resolved_BDTscan_Run"+str(Run)+"_fine.root"
graphFile = TFile.Open(path,"READ")
list_of_names = ["sigYield","bkgYield","bkgYield_fromAllEvts","refYield","significance","significance_fromAllEvts"]
newFile = TFile.Open(path.replace(".root","_new.root"),"RECREATE")
newFile.cd()
for name in list_of_names:
redoGraph(Run,graphFile,name).Write()
newFile.Close()
graphFile.Close()
cmd = "mv " + path + " " + path.replace(".root","_old.root")
os.system(cmd)
cmd = "mv " + path.replace(".root","_new.root") + " " + path
os.system(cmd)
rewriteMVAscan(1)
rewriteMVAscan(2)