Newer
Older
STAging / macros / leakageCurrent / getPredictions.py
import ROOT

import numpy as np

#dn_lumi = ROOT.TString("/home/hep/che/cmtuser/Vetra_v13r2/ST/STAging/data/lumi");
dn_lumi = ROOT.TString("/home/hep/egraveri/cmtuser/STMonitoring/STAging/data/lumi");
fn_lumi = ROOT.TString("%s/lumi.root"%(dn_lumi.Data()));

#dn_sector = ROOT.TString("/home/hep/che/cmtuser/Vetra_v13r2/ST/STAging/data/db");
dn_sector = ROOT.TString("/home/hep/egraveri/cmtuser/STMonitoring/STAging/data/db");
fn_sector = ROOT.TString("%s/fluence.root"%(dn_sector.Data()));

f_lumi   = ROOT.TFile.Open(fn_lumi.Data());
f_sector = ROOT.TFile.Open(fn_sector.Data());

# Get information on luminosity
v_fillTime  = f_lumi.Get("v_fillTime_tot");
v_beamEner  = f_lumi.Get("v_beamEner_tot");
v_stopTime  = f_lumi.Get("v_stopTime_tot");
v_peakLumi  = f_lumi.Get("v_peakLumi_tot");

# Get information on fluence
v_sector    = {}
v_flux7_v   = {}
v_flux7_e   = {}
v_flux8_v   = {}
v_flux8_e   = {}

v_sector["TT"]   = f_sector.Get("v_sector_TTaU")
v_flux7_v["TT"]  = f_sector.Get("v_flux7_v_TTaU")
v_flux7_e["TT"]  = f_sector.Get("v_flux7_e_TTaU")
v_flux8_v["TT"]  = f_sector.Get("v_flux8_v_TTaU")
v_flux8_e["TT"]  = f_sector.Get("v_flux8_e_TTaU")

v_sector["IT"]   = f_sector.Get("v_sector_T3X2")
v_flux7_v["IT"]  = f_sector.Get("v_flux7_v_T3X2")
v_flux7_e["IT"]  = f_sector.Get("v_flux7_e_T3X2")
v_flux8_v["IT"]  = f_sector.Get("v_flux8_v_T3X2")
v_flux8_e["IT"]  = f_sector.Get("v_flux8_e_T3X2")

# dictionnary of read-out sectors matched to boxes (IT) or types of read-out sectors (TT; 1, 2, 3 and 4 sensor sectors)
sect_dict  = {}
sect_dict["TT"]  = {
  "1" : [2627,2628,2634,2633,2639,2640],
  "2" : [2626,2629,2635,2632,2638,2641],
  "3" : [2615,2614,2611,2610,2607,2606,2603,2602,2599,2598,2595,2594,2659,2658,2663,2662,2667,2666,2671,2670,2675,2674,2679,2678],
  "4" : [2616,2613,2612,2609,2608,2605,2604,2601,2600,2597,2596,2594,2660,2657,2664,2661,2668,2665,2672,2669,2676,2673,2680,2677,2642,2636,2630,2637,2631,2625]
}

sect_dict["IT"]  = {
  "T"  : [7303,7302,7301,7300,7299,7298,7297],
  "A"  : [7239,7238,7237,7236,7235,7234,7233],
  "C"  : [7207,7206,7205,7204,7203,7202,7201],
  "B"  : [7271,7270,7269,7268,7267,7266,7265],
  "AC" : [7207,7206,7205,7204,7203,7202,7201,7239,7238,7237,7236,7235,7234,7233],
  "BT" : [7271,7270,7269,7268,7267,7266,7265,7303,7302,7301,7300,7299,7298,7297]
}

# conversion factor linking the number of 1-MeV neutron flux per collision to the corresponding in a pb
flukaConvFac = 7.2e4

# Get the index in a vector such that the value associated to this index is the closest to the input value (val)
def findIndex(v_ind,val):
  ind = -1
  min = 1000000
  for i,v in enumerate(v_ind):
    if ROOT.TMath.Abs(v-val)<min:
      min = ROOT.TMath.Abs(v-val)
      ind = i
  return ind

# calculate the time factor according to the Arrhenius relation
def Arrhenius(para,temp):
  return 1.0/(para["k0I"]*ROOT.TMath.Exp(-para["EI"]/(para["kb"]*temp)))

# calculate the change in the leakage current due to annealing
# alpha(t) = alpha_0 + alpha_1 * exp(-t/tau)
def GetDiff(para,temp,dFlux,Flux,val,tStep):
  tau = Arrhenius(para,temp)
  return ((para["a0"]+para["aI"])*dFlux-((val-para["a0"]*Flux)/tau))*tStep

# get prediction for a given sector
def predict(det,sect):
  flux7_v = 0.0
  flux7_e = 0.0
  flux8_v = 0.0
  flux8_e = 0.0

  c = 0.0
  for s in sect_dict[det][sect]:
    c += 1.0
    ind = findIndex(v_sector[det],s)
    print ind
    flux7_v += v_flux7_v[det](ind)
    flux7_e += v_flux7_e[det](ind)
    flux8_v += v_flux8_v[det](ind)
    flux8_e += v_flux8_e[det](ind)

  flux7_v /= c
  flux7_e /= c
  flux8_v /= c
  flux8_e /= c

  # define start and stop time for the prediction (unixtime)
  tStart = 1262325600;  # 1-1-2010
  #tStop  = 1372654800;  # 1-7-2013
  tStop  = 1437841532;  # 25-7-2015
  tRun   = tStart;
  tFillEnd = tStart;

  # define time step in secs
  tStep  = 6000.0 # 100 min

  v_time = []
  v_val  = []
  v_low  = []
  v_hig  = []
  v_lumi = []
  
  # parameters of the model
  para_v = {"a0" :  6.27e-17, "aI" : 7.73e-17, "k0I" : 4.200e13, "EI" : 1.11, "beta" : 3.07e-18, "t0" :  6000.0, "kb" : 8.617e-5}
  para_e = {"a0" :  0.09e-17, "aI" : 0.06e-17, "k0I" : 0.500e13, "EI" : 0.02, "beta" : 0.18e-18, "t0" :     0.0, "kb" : 0.000e-5}

  N = 1

  temp_e = 2.0

  para_list   = [para_v]
  flux7_list  = [flux7_v]
  flux8_list  = [flux8_v]
  tempU_list  = [0.0]
  val_list    = [0.0]
  flux_list   = [0.0]
  

  # get N-1 replicas of the path with variations of the parameters according to the uncertainties on the parameters
  for i in range(1,N):
    tempU_list.append(0.0)
    #tempU_list.append(ROOT.gRandom.Gaus()*temp_e)
    val_list.append(0.0)
    flux_list.append(0.0)
    flux7_list.append(flux7_v+ROOT.gRandom.Gaus()*flux7_e*1.0)
    flux8_list.append(flux8_v+ROOT.gRandom.Gaus()*flux8_e*1.0)
    para_temp = para_v.copy()
    for key in para_temp.keys():
      while True:
        para_temp[key] = para_v[key] + ROOT.gRandom.Gaus()*para_e[key]
        if para_temp[key]>0.0:
          break
    print para_temp
    para_list.append(para_temp)

  i_lumi = 0
  lumi = 0.0

  # run the simulation
  while tRun<tStop:
    print "%13.0f sec : %20.0f pb"%(tRun,lumi/1e6)
    temp = 273.15+8.0
    while i_lumi<v_fillTime.GetNoElements() and tRun>v_stopTime(i_lumi):
      lumi += (v_stopTime(i_lumi)-v_fillTime(i_lumi))*v_peakLumi(i_lumi)
      i_lumi += 1

    for i in range(0,len(val_list)):
      temp_val = temp+tempU_list[i]
      dFlux  = 0.0
      
      if i_lumi<v_fillTime.GetNoElements():
        if tRun<v_fillTime(i_lumi):
          dFlux  = 0.0
        else:
          if v_beamEner(i_lumi)==7.0:
            dFlux = flux7_list[i]*v_peakLumi(i_lumi)*flukaConvFac
          elif v_beamEner(i_lumi)==8.0:
            dFlux = flux8_list[i]*v_peakLumi(i_lumi)*flukaConvFac
          else:
            dFlux = 0.0

      # calculate the evolution of the current according to 2nd order Runga-Kutta
      dval = GetDiff(para_list[i],temp_val,dFlux,flux_list[i],val_list[i],tStep)
      val_list[i] += dval/2.0
      flux_list[i] += dFlux*tStep
      dval = GetDiff(para_list[i],temp_val,dFlux,flux_list[i],val_list[i],tStep)
      val_list[i] += dval/2.0
      
    # Sort the value list
    val_list_sort = list(val_list)
    v_val.append(val_list[0])
    val_list_sort = sorted(val_list_sort)
    v_time.append(tRun)
    # get the 68% confidence interval
    v_low.append(val_list_sort[(int)((1.0-0.684)*N/2.0)])
    v_hig.append(val_list_sort[(int)((1.0+0.684)*N/2.0)])
    if tRun<1356998400.0:
      v_lumi.append(lumi/1e6)

    tRun += tStep
  
  # reduce the number of data points for plotting
  vr_time     = ROOT.TVectorD(len(v_time[::100]),np.array(v_time[::100]))
  vr_lumi     = ROOT.TVectorD(len(v_lumi[::100]),np.array(v_lumi[::100]))
  
  vr_val      = ROOT.TVectorD(len(v_val[::100]),np.array(v_val[::100])*1e6)
  vr_errcent  = ROOT.TVectorD(len(v_low[::100]),(np.array(v_hig[::100])+np.array(v_low[::100]))/2.0*1e6)
  vr_errband  = ROOT.TVectorD(len(v_hig[::100]),(np.array(v_hig[::100])-np.array(v_low[::100]))/2.0*1e6)
  
  vr_hig      = ROOT.TVectorD(len(v_hig[::100]),np.array(v_hig[::100])*1e6)
  vr_low      = ROOT.TVectorD(len(v_low[::100]),np.array(v_low[::100])*1e6)

  vr_val_lumi      = ROOT.TVectorD(len(v_lumi[::100]),np.array(v_val[::100])[0:len(v_lumi[::100])]*1e6)
  vr_errcent_lumi  = ROOT.TVectorD(len(v_lumi[::100]),(np.array(v_hig[::100])[0:len(v_lumi[::100])]+np.array(v_low[::100])[0:len(v_lumi[::100])])/2.0*1e6)
  vr_errband_lumi  = ROOT.TVectorD(len(v_lumi[::100]),(np.array(v_hig[::100])[0:len(v_lumi[::100])]-np.array(v_low[::100])[0:len(v_lumi[::100])])/2.0*1e6)


  # divide obtained vectors by the volume of the connected sensors
  if det=="TT":
    if sect=="1" or sect=="4":
      vr_val     *=1.0/(0.0500*9.64*9.44)
      vr_errband *=1.0/(0.0500*9.64*9.44)
      vr_errcent *=1.0/(0.0500*9.64*9.44)
      vr_hig     *=1.0/(0.0500*9.64*9.44)
      vr_low     *=1.0/(0.0500*9.64*9.44)
    else:
      vr_val     *=1.2/(0.0500*9.64*9.44)
      vr_errband *=1.2/(0.0500*9.64*9.44)
      vr_errcent *=1.2/(0.0500*9.64*9.44)
      vr_hig     *=1.2/(0.0500*9.64*9.44)
      vr_low     *=1.2/(0.0500*9.64*9.44)
  else:
    if sect=="AC":
      vr_val     *=1.0/(0.041*7.6*11)
      vr_errband *=1.0/(0.041*7.6*11)
      vr_errcent *=1.0/(0.041*7.6*11)
      vr_hig     *=1.0/(0.041*7.6*11)
      vr_low     *=1.0/(0.041*7.6*11)
    else:
      vr_val     *=1.0/(0.032*7.6*11*1.6)
      vr_errband *=1.0/(0.032*7.6*11*1.6)
      vr_errcent *=1.0/(0.032*7.6*11*1.6)
      vr_hig     *=1.0/(0.032*7.6*11*1.6)
      vr_low     *=1.0/(0.032*7.6*11*1.6)

  # Create the luminosity graphs (central value, confidence interval [also as area])
  g_time  = ROOT.TGraph(vr_time,vr_val)
  g_time.SetLineWidth(5)
  ge_time = ROOT.TGraphErrors(vr_time,vr_errcent,ROOT.TVectorD(vr_time.GetNoElements()),vr_errband);
  ge_time.SetFillColor(ROOT.kGray)
  gtop_time = ROOT.TGraph(vr_time,vr_hig );
  gtop_time.SetLineStyle(ROOT.kDashed)
  gtop_time.SetLineWidth(2)
  gbot_time = ROOT.TGraph(vr_time,vr_low);
  gbot_time.SetLineStyle(ROOT.kDashed)
  gbot_time.SetLineWidth(2)

  # Create the time graphs (central value, confidence interval [also as area])
  g_lumi  = ROOT.TGraph(vr_lumi,vr_val)
  g_lumi.SetLineWidth(5)
  ge_lumi = ROOT.TGraphErrors(vr_lumi,vr_errcent,ROOT.TVectorD(vr_lumi.GetNoElements()),vr_errband);
  ge_lumi.SetFillColor(ROOT.kGray)
  gtop_lumi = ROOT.TGraph(vr_lumi,vr_hig );
  gtop_lumi.SetLineStyle(ROOT.kDashed)
  gtop_lumi.SetLineWidth(2)
  gbot_lumi = ROOT.TGraph(vr_lumi,vr_low);
  gbot_lumi.SetLineStyle(ROOT.kDashed)
  gbot_lumi.SetLineWidth(2)

  # Combine the luminosity graphs
  mg_time_cent = ROOT.TMultiGraph("mg_time_cent_%s"%det,"multigraph")
  mg_time_unc  = ROOT.TMultiGraph("mg_time_unc_%s"%det, "multigraph")
  mg_time_cent.Add(g_time,"l")
  mg_time_cent.Add(gtop_time,"l")
  mg_time_cent.Add(gbot_time,"l")
  mg_time_unc.Add(ge_time,"3")

  # Combine the time graphs
  mg_lumi_cent = ROOT.TMultiGraph("mg_lumi_cent_%s"%det,"multigraph")
  mg_lumi_unc  = ROOT.TMultiGraph("mg_lumi_unc_%s"%det, "multigraph")
  mg_lumi_cent.Add(g_lumi,"l")
  mg_lumi_cent.Add(gtop_lumi,"l")
  mg_lumi_cent.Add(gbot_lumi,"l")
  mg_lumi_unc.Add(ge_lumi,"3")

  print "Done"
  return [mg_lumi_cent,mg_time_cent,mg_lumi_unc,mg_time_unc]


# plot the legends
if __name__ == '__main__':
  ROOT.gROOT.ProcessLine(".x ../../include/lhcbstyle.C")
  
  h1 = ROOT.TH1F("h1","h1",10,0.0,1.0)
  h1.SetLineColor(ROOT.kRed)
  h1.SetLineWidth(4)
  h2 = ROOT.TH1F("h2","h2",10,0.0,1.0)
  h2.SetLineColor(ROOT.kBlue)
  h2.SetLineWidth(4)
  h3 = ROOT.TH1F("h3","h3",10,0.0,1.0)
  h3.SetFillColor(ROOT.kGray)
  h3.SetLineColor(ROOT.kBlack)
  h3.SetLineWidth(4)
  
  leg1 = ROOT.TLegend(0.0,0.0,1.0,1.0)
  leg1.SetFillStyle(0)
  leg1.SetTextSize(0.14)
  
  leg1.AddEntry(h1,"U layer (TT)","l")
  leg1.AddEntry(h2,"V layer (TT)","l")
  leg1.AddEntry(h3,"Prediction (T_{a} = 8#circ C)","fl")
  
  c_leg1 = ROOT.TCanvas("c_leg1","c_leg1",300,200)
  leg1.Draw()

  leg2 = ROOT.TLegend(0.0,0.0,1.0,1.0)
  leg2.SetFillStyle(0)
  leg2.SetTextSize(0.14)
  
  leg2.AddEntry(h1,"A box (IT)","l")
  leg2.AddEntry(h2,"C box (IT)","l")
  leg2.AddEntry(h3,"Prediction (T_{a} = 8#circ C)","fl")
  
  c_leg2 = ROOT.TCanvas("c_leg2","c_leg2",300,200)
  leg2.Draw()

  leg3 = ROOT.TLegend(0.0,0.0,1.0,1.0)
  leg3.SetFillStyle(0)
  leg3.SetTextSize(0.14)
  
  leg3.AddEntry(h1,"B box (IT)","l")
  leg3.AddEntry(h2,"T box (IT)","l")
  leg3.AddEntry(h3,"Prediction (T_{a} = 8#circ C)","fl")
  
  c_leg3 = ROOT.TCanvas("c_leg3","c_leg3",300,200)
  leg3.Draw()