10 Validation of KLM time cabledelay calibration.
15 from prompt
import ValidationSettings
17 from ROOT.Belle2
import KLMCalibrationChecker
23 from ROOT
import TH1F, TCanvas, TFile, gStyle
26 settings = ValidationSettings(name=
'KLM time cabledelay',
28 download_files=[
'stdout'],
31 "LowerTimeBoundaryRPC": -800.0,
32 "UpperTimeBoundaryRPC": -600.0,
33 "LowerTimeBoundaryScintilltorsBKLM": -4800.0,
34 "UpperTimeBoundaryScintilltorsBKLM": -4400.0,
35 "LowerTimeBoundaryScintilltorsEKLM": -4900.0,
36 "UpperTimeBoundaryScintilltorsEKLM": -4500.0,
40 def run_validation(job_path, input_data_path, requested_iov, expert_config):
44 - job_path will be replaced with path/to/calibration_results
45 - input_data_path will be replaced with path/to/data_path used for calibration, e.g. /group/belle2/dataprod/Data/PromptSkim/
49 expert_config = json.loads(expert_config)
51 chunk_size = expert_config[
'chunk_size']
52 LowerTimeBoundaryRPC = expert_config[
'LowerTimeBoundaryRPC']
53 UpperTimeBoundaryRPC = expert_config[
'UpperTimeBoundaryRPC']
54 LowerTimeBoundaryScintilltorsBKLM = expert_config[
'LowerTimeBoundaryScintilltorsBKLM']
55 UpperTimeBoundaryScintilltorsBKLM = expert_config[
'UpperTimeBoundaryScintilltorsBKLM']
56 LowerTimeBoundaryScintilltorsEKLM = expert_config[
'LowerTimeBoundaryScintilltorsEKLM']
57 UpperTimeBoundaryScintilltorsEKLM = expert_config[
'UpperTimeBoundaryScintilltorsEKLM']
60 ROOT.PyConfig.IgnoreCommandLineOptions =
True
62 ROOT.gROOT.SetBatch(
True)
64 ROOT.gROOT.SetStyle(
"BELLE2")
66 ROOT.gStyle.SetOptStat(0)
69 database_file = os.path.join(f
'{job_path}',
'KLMTime',
'outputdb',
'database.txt')
74 with open(database_file)
as f:
76 fields = line.split(
' ')
77 if (fields[0] ==
'dbstore/KLMTimeCableDelay'):
78 iov = fields[2].split(
',')
81 if (exp != previous_exp):
82 exp_run_dict[exp] = [run]
85 exp_run_dict[exp].append(run)
89 for exp, run_list
in exp_run_dict.items():
92 if run_list[0] == 0
and run_list[1] > 5:
93 run_list[0] = run_list[1] - 5
96 for exp, run_list
in exp_run_dict.items():
98 checker = KLMCalibrationChecker()
99 checker.setExperimentRun(exp, run)
100 checker.setTestingPayload(database_file)
101 basf2.B2INFO(f
'Creating time cable delay results tree for experiment {exp}, run {run}.')
102 checker.setTimeCableDelayResultsFile(f
'time_cabledelay_exp{exp}_run{run}.root')
103 checker.checkTimeCableDelay()
106 for exp, run_list
in exp_run_dict.items():
108 chunks = math.ceil(len(run_list) / chunk_size)
109 for chunk
in range(chunks):
110 file_name = f
'time_cabledelay_exp{exp}_chunk{chunk}.root'
112 f
'time_cabledelay_exp{exp}_run{run}.root' for run
in run_list[chunk * chunk_size:(chunk + 1) * chunk_size]]
113 subprocess.run([
'hadd',
'-f', file_name] + run_files, check=
True)
114 input_file = ROOT.TFile(f
'{file_name}')
116 gStyle.SetOptStat(1111111)
117 gStyle.SetOptFit(1111)
118 barrel_RPC = TH1F(
"barrel_RPC",
"time cable delay for Barrel RPC", 100, LowerTimeBoundaryRPC, UpperTimeBoundaryRPC)
119 barrel_scintillator = TH1F(
"barrel_scintillator",
"time cable delay for Barrel scintillator",
120 100, LowerTimeBoundaryScintilltorsBKLM, UpperTimeBoundaryScintilltorsBKLM)
121 endcap_scintillator = TH1F(
"endcap_scintillator",
"time cable delay for endcap scintillator",
122 100, LowerTimeBoundaryScintilltorsEKLM, UpperTimeBoundaryScintilltorsEKLM)
124 tree = input_file.Get(
"cabledelay")
125 assert isinstance(tree, ROOT.TTree) == 1
128 tree.Draw(
"timeDelay>>barrel_RPC",
"subdetector==1 & layer>=3")
129 barrel_RPC.Fit(
"gaus")
130 barrel_RPC.GetXaxis().SetTitle(
"T_{cable} (ns)")
131 barrel_RPC.GetYaxis().SetTitle(
"Entries")
132 myC.Print(
"barrel_RPC.png")
134 tree.Draw(
"timeDelay>>barrel_scintillator",
"subdetector==1 & layer<3")
135 barrel_scintillator.Fit(
"gaus")
136 barrel_scintillator.GetXaxis().SetTitle(
"T_{cable} (ns)")
137 barrel_scintillator.GetYaxis().SetTitle(
"Entries")
138 myC.Print(
"barrel_scintillator.png")
140 tree.Draw(
"timeDelay>>endcap_scintillator",
"subdetector==2")
141 endcap_scintillator.Fit(
"gaus")
142 endcap_scintillator.GetXaxis().SetTitle(
"T_{cable} (ns)")
143 endcap_scintillator.GetYaxis().SetTitle(
"Entries")
144 myC.Print(
"endcap_scintillator.png")
147 fout = TFile(
"KLMTimeCableDelay.root",
"recreate")
149 barrel_scintillator.Write()
150 endcap_scintillator.Write()
155 for run_file
in run_files:
159 basf2.B2ERROR(f
'The file {run_file} can not be removed: {e.strerror}')
162 if __name__ ==
"__main__":