24 parser = argparse.ArgumentParser()
28 default=
"/nfs/dust/belle2/user/kovalch/energyBiasCorrFiles/Feb2021.txt",
29 help=
'Path to input file with energy bias correction values .')
30 args = parser.parse_args()
32 weightsDB = args.input_path
33 df_weightDB = pd.read_csv(weightsDB, delimiter=
r"\s+")
35 tableName =
"Feb2021:TestEnergy"
36 tableName2 =
"Feb2021:TestEnergy2"
41 def make_1D_bin(name, min_val, max_val):
42 return {name: [min_val, max_val]}
45 def get_weight(namew, w, namewerr, werr):
46 return {namew: w, namewerr: werr}
49 def make_2D_bin(bin_x, bin_y):
55 def make_3D_bin(bin_x, bin_y, bin_z):
57 bin_3d.update(bin_y).update(bin_z)
79 for x
in range(0, len(df_weightDB)):
81 bins_x = make_1D_bin(df_weightDB[
'namebin1'].values[x], df_weightDB[
'minbin1'].values[x], df_weightDB[
'maxbin1'].values[x])
82 bins_y = make_1D_bin(df_weightDB[
'namebin2'].values[x], df_weightDB[
'minbin2'].values[x], df_weightDB[
'maxbin2'].values[x])
83 weightInfo = get_weight(
"Weight", df_weightDB[
'w'].values[x],
"StatErr", df_weightDB[
'werr'].values[x])
84 tableIDNotSpec.append([weightInfo, make_2D_bin(bins_x, bins_y)])
86 tableIDSpec.append([[weightInfo, make_2D_bin(bins_x, bins_y)], binID])
89 outOfRangeWeightInfo = {}
90 outOfRangeWeightInfo[
"Weight"] = -1
91 outOfRangeWeightInfo[
"StatErr"] = -1
94 addtable = b2.register_module(
'ParticleWeightingLookUpCreator')
95 addtable.param(
'tableIDSpec', tableIDSpec)
96 addtable.param(
'outOfRangeWeight', outOfRangeWeightInfo)
97 addtable.param(
'experimentHigh', -1)
98 addtable.param(
'experimentLow', 0)
99 addtable.param(
'runHigh', -1)
100 addtable.param(
'runLow', 0)
101 addtable.param(
'tableName', tableName)
103 addtable2 = b2.register_module(
'ParticleWeightingLookUpCreator')
104 addtable2.param(
'tableIDNotSpec', tableIDNotSpec)
105 addtable2.param(
'outOfRangeWeight', outOfRangeWeightInfo)
106 addtable2.param(
'experimentHigh', -1)
107 addtable2.param(
'experimentLow', 0)
108 addtable2.param(
'runHigh', -1)
109 addtable2.param(
'runLow', 0)
110 addtable2.param(
'tableName', tableName2)
112 eventinfosetter = b2.register_module(
'EventInfoSetter')
113 eventinfosetter.param(
'evtNumList', [10])
114 eventinfosetter.param(
'runList', [0])
115 eventinfosetter.param(
'expList', [0])
117 my_path = b2.create_path()
118 my_path.add_module(addtable)
119 my_path.add_module(addtable2)
120 my_path.add_module(eventinfosetter)