14 from mdst
import add_mdst_output
15 import modularAnalysis
as ma
17 from variables
import variables
as vm
21 def preprocess_roe_data(listName, charge, path):
22 ''' Process/select events on top of the skim processing:
24 -- select of the positive/negative charge
29 if listName.find(
"B0") == 0:
30 basf2.B2ERROR(f
"Inconsistency between neutral list {listName} and charge requirement {charge}")
31 ma.variablesToEventExtraInfo(listName, {
'charge':
'bcharge'}, path=path)
32 vm.addAlias(
'bcharge',
'eventExtraInfo(bcharge)')
35 empty_path = basf2.create_path()
36 cfilter = basf2.register_module(
'VariableToReturnValue')
37 cfilter.param(
'variable',
'bcharge')
38 cfilter.if_value(f
'!={charge}', empty_path)
39 path.add_module(cfilter).set_name(
"chargeFilter")
42 vtx.treeFit(listName, path=path)
43 ma.variablesToEventExtraInfo(listName, {
'chiProb':
'chiProb'}, path=path)
44 vm.addAlias(
'fitProb',
'eventExtraInfo(chiProb)')
47 empty_path2 = basf2.create_path()
48 fitfilter = basf2.register_module(
'VariableToReturnValue')
49 fitfilter.param(
'variable',
'fitProb')
50 fitfilter.if_value(
'<0', empty_path2)
51 path.add_module(fitfilter).set_name(
"fitFilter")
54 vm.addAlias(
'nB', f
'nParticlesInList({listName})')
55 eventFilter = basf2.register_module(
'VariableToReturnValue')
56 eventFilter.param(
'variable',
'nB')
57 eventFilter.if_value(
'!=1', empty_path2)
58 path.add_module(eventFilter).set_name(
"eventFilter")
61 Vars = {
'px':
'PX',
'py':
'PY',
'pz':
'PZ',
'x':
'X',
'y':
'Y',
'z':
'Z',
62 'IPX':
'IPX',
'IPY':
'IPY',
'IPZ':
'IPZ'}
63 ma.variablesToEventExtraInfo(listName, Vars, path=path)
66 def list_select_roe_data(listName, path):
68 filter1 = basf2.register_module(
"UdstListFilter")
69 filter1.param(
"listName", listName)
70 filter1.param(
"keepNotInList",
True)
71 path.add_module(filter1).set_name(
"filter1")
74 def preprocess_signal_mc(listName, charge, path):
77 if listName.find(
"B0") == 0:
78 basf2.B2ERROR(f
"Inconsistency between neutral list {listName} and charge requirement {charge}")
79 ma.variablesToEventExtraInfo(listName, {
'charge':
'bcharge'}, path=path)
80 vm.addAlias(
'bcharge',
'eventExtraInfo(bcharge)')
81 empty_path = basf2.create_path()
82 cfilter = basf2.register_module(
'VariableToReturnValue')
83 cfilter.param(
'variable',
'bcharge')
84 cfilter.if_value(f
'!={charge}', empty_path)
85 path.add_module(cfilter).set_name(
"chargeFilter")
87 vm.addAlias(
'nB', f
'nParticlesInList({listName})')
88 empty_path2 = basf2.create_path()
89 eventFilter = basf2.register_module(
'VariableToReturnValue')
90 eventFilter.param(
'variable',
'nB')
91 eventFilter.if_value(
'!=1', empty_path2)
92 path.add_module(eventFilter).set_name(
"eventFilter")
94 Vars = {
'mcPX':
'PX',
'mcPY':
'PY',
'mcPZ':
'PZ',
95 'mcDecayVertexX':
'X',
96 'mcDecayVertexY':
'Y',
97 'mcDecayVertexZ':
'Z',
98 'IPX':
'IPX',
'IPY':
'IPY',
'IPZ':
'IPZ'
100 ma.variablesToEventExtraInfo(listName, Vars, path=path)
103 def list_select_signal_mc(listName, path):
104 filter2 = basf2.register_module(
"UdstListFilter")
105 filter2.param(
"listName", listName)
106 filter2.param(
"keepNotInList",
False)
107 path.add_module(filter2).set_name(
"filter2")
110 def prepare_path(FileIn, ListName, icharge, isROE, FileOut):
112 Return processing path
113 FileIn -- input file name
114 ListName -- B+ or B0 decay chain of the skim
115 icharge -- charge (0, -1 or +1)
116 isROE -- ROE (data) if true, signal (MC) if false
117 FileOut -- output file name
122 input1 = basf2.register_module(
'RootInput')
123 input1.param(
'inputFileName', FileIn)
124 main.add_module(input1).set_name(
"input1")
127 preprocess_roe_data(ListName, icharge, main)
128 list_select_roe_data(ListName, main)
130 preprocess_signal_mc(ListName, icharge, main)
131 list_select_signal_mc(ListName, main)
134 additionalBranches = [
'EventExtraInfo']
136 add_mdst_output(main, filename=FileOut, additionalBranches=additionalBranches)
139 main.add_module(
'Progress')
141 basf2.print_path(main)
146 """Handles the command-line argument parsing.
149 argparse.Namespace: The parsed arguments.
151 parser = argparse.ArgumentParser(formatter_class=argparse.ArgumentDefaultsHelpFormatter)
152 parser.add_argument(
"--fileIn", help=
'Input file name.', required=
True)
153 parser.add_argument(
'--listName', help=
'Name of the particle list to keep (isSignal) or to remove.', required=
True)
154 parser.add_argument(
"--isSignal", action=
'store_true', help=
'If added, the input is signal MC')
155 parser.add_argument(
"--charge", default=
'pos',
156 help=
'Filter charge. Possible values are :code:`pos`, :code:`neg` or :code:`zero`. Default is :code:`pos`')
157 parser.add_argument(
"--fileOut", default=
'test.root', help=
'Output file name. Default: :code:`test.root`')
163 if __name__ ==
'__main__':
165 args = get_parser().parse_args()
167 list1 = args.listName
168 signal = args.isSignal
170 fileOut = args.fileOut
175 elif charge ==
'pos':
177 elif charge ==
'neg':
180 main = prepare_path(fileIn, list1, icharge,
not signal, fileOut)
183 print(basf2.statistics)