-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathFig3_ThreeFourHar_Models_OneObs.py
122 lines (99 loc) · 4.15 KB
/
Fig3_ThreeFourHar_Models_OneObs.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import numpy as np
import ROOT
import scipy
from scipy import interpolate
import sys
sys.path.append("JPyPlotRatio");
import JPyPlotRatio
f = ROOT.TFile("data/Output_ALICE.root","read");
fmodel = ROOT.TFile("data/Output_TrentoVISHNU.root","read");
obsPanel = [0];
obsTypeStr = [
"2Psi2_n6Psi3_4Psi4"
];
plabel = [
"$\\langle cos[2\\Psi_{2}-6\\Psi_{3}+4\\Psi_{4}]\\rangle$"
];
dataTypeStr = ["ALICE","{T\\raisebox{-.5ex}{R}ENTo} (cumulants)","{T\\raisebox{-.5ex}{R}ENTo} (eccentricities)","{T\\raisebox{-.5ex}{R}ENTo} + VISH2+1 + UrQMD"];
dataTypeInRoot = ["ALICE","_Trento_Cumulants","_Trento_Ecc","_TrentoVISHNU_FinalState"];
dataTypePlotParams = [
{'plotType':'data','color':'red','fmt':'o','markersize':5.0},
{'plotType':'data','color':'#e580ff','fmt':'X','fillstyle':'none','markersize':5.5},
{'plotType':'data','color':'#44aa11','fmt':'h','markersize':4.0},
{'plotType':'data','color':'red','fmt':'D','fillstyle':'none','markersize':5.0},
{'plotType':'data','color':'cyan','fmt':'d','fillstyle':'none','markersize':5.5}
];
modelTypePlotParams = [
{'plotType':'theory','color':'#0051a2','linecolor':'#0051a2','alpha':0.5,'linestyle':'solid'},
{'plotType':'theory','color':'#e580ff','linecolor':'#e580ff','alpha':0.5,'linestyle':'dotted'},
{'plotType':'theory','color':'red','linecolor':'red','alpha':0.5,'linestyle':'solid'}
];
def RemovePoints(arrays, pointIndices):
return tuple([np.delete(a,pointIndices) for a in arrays]);
# define panel/xaxis limits/titles
ny = 1;
nx = 1;
xlimits = [(-1.,52.)];
ylimits = [(-0.2,0.2),(-0.14,0.17),(0,0.5)]; # just rows
ylimitsPri = [(-0.07,0.11),(-0.6,0.82)]
xtitle = ["Centrality percentile"];
ytitle = ["Correlations","Correlations"];
ytitleRight = ["Correlations"];
# Following two must be added
toptitle = "PbPb $\\sqrt{s_{NN}}$ = 2.76 TeV"; # need to add on the top
dataDetail = "$0.2 < p_\\mathrm{T} < 5.0\\,\\mathrm{GeV}/c$\n$|\\eta| < 0.8$";
plot = JPyPlotRatio.JPyPlotRatio(panels=(ny,nx),panelsize=(4,5),disableRatio=[0],
rowBounds=ylimits, #only one row, add the shared ylims
#panelPrivateRowBounds={1:ylimitsPri[0],3:ylimitsPri[1]},
colBounds=xlimits, #two columns, set xlimit for both of them
#ratioBounds={0:(-1,3),1:(-1,3)},
#panelPrivateScale=[1,3], # because rowBounds are just for rows
#panelLabel={i:label for i,label in enumerate(plabel)},
panelLabelLoc=(0.07,0.89),panelLabelSize=13,
panelLabel=plabel,
#panelScaling={3:5},
panelLabelAlign="left",
systPatchWidth = 0.03,
axisLabelSize=15,
tickLabelSize=13,
legendPanel=0,legendLoc=(0.45,0.2),legendSize=11,xlabel=xtitle[0],ylabel=ytitle[0]);
#plot.GetPlot().text(0.5,0.05,xtitle[0],size=plot.axisLabelSize,horizontalalignment="center");
#plot.GetAxes(1).yaxis.tick_right();
#plot.GetAxes(3).yaxis.tick_right();
#plot.GetAxes(5).yaxis.tick_right();
plot.EnableLatex(True);
#plot.EnableLatex(True);
obsN = len(obsTypeStr);
print(obsN)
#scale1 = {4:10,5:10};
plot.GetAxes(0).plot([0,50],[0,0],linestyle=":",color="gray");
for i in range(0,obsN):
gr = f.Get("{:s}{:s}".format(obsTypeStr[i],"_Stat"));
x,y,_,yerr = JPyPlotRatio.TGraphErrorsToNumpy(gr);
plot1 = plot.Add(obsPanel[i],(x,y,yerr),**dataTypePlotParams[0]);
if(i==0):
plot1 = plot.Add(obsPanel[i],(x,y,yerr),**dataTypePlotParams[0],label=dataTypeStr[0]);
# systematics
grsyst = f.Get("{:s}{:s}".format(obsTypeStr[i],"_Syst"));
_,_,_,yerrsyst = JPyPlotRatio.TGraphErrorsToNumpy(grsyst);
plot.AddSyst(plot1,yerrsyst);
# model
for j in range(0,3):
grmodel = fmodel.Get("{:s}{:s}".format(obsTypeStr[i],dataTypeInRoot[j+1]));
x1,y1,_,yerr1 = JPyPlotRatio.TGraphErrorsToNumpy(grmodel);
# Remove first model data very large error
if(i==0 and j==2):
x1 = x1[1:]
y1 = y1[1:]
yerr1 = yerr1[1:]
plotModel = plot.Add(obsPanel[i],(x1,y1,yerr1),**modelTypePlotParams[j],label=dataTypeStr[j+1]);
f.Close();
print("I am here,,")
#plot.GetPlot().text(0.16,0.31,"ALICE",fontsize=9);
plot.GetPlot().text(0.2,0.71,toptitle,fontsize=12);
plot.GetPlot().text(0.2,0.60,dataDetail,fontsize=12);
#plot.GetAxes(3).text(0.1,0.1,dataDetail,fontsize=9);
plot.Plot();
#plot.GetRatioAxes(3).remove();
plot.Save("figs/Fig3_ThreeFourHar_models_OneObs.pdf");
plot.Show();