10from reconstruction
import prepare_cdst_analysis
11import modularAnalysis
as mA
15def make_electron_collection(path_electron):
17 trg_bhabhaskim = path_electron.add_module(
19 triggerLines=[
"software_trigger_cut&skim&accept_bhabha_cdc"])
20 trg_bhabhaskim.if_value(
"==0", basf2.Path(), basf2.AfterConditionPath.END)
22 prepare_cdst_analysis(path=path_electron)
25 path_electron.add_module(
27 relativeCorrections=
False,
37 mA.fillParticleList(
'e+:calib',
' ', path=path_electron)
45def make_muon_collection(path_muon):
47 prepare_cdst_analysis(path=path_muon)
52 relativeCorrections=
False,
62 goodTrack =
'abs(dr) < 0.5 and abs(dz) < 0.5 and nCDCHits > 0'
63 goodTrack +=
' and clusterE < 0.40 and clusterEoP < 0.40 and inCDCAcceptance==1'
64 goodTrack +=
' and [[isPIDAvailableFrom(KLM) == 0 and clusterE < 0.25] or isPIDAvailableFrom(KLM) == 1]'
67 mA.fillParticleList(
'mu+:calib', goodTrack, path=path_muon)
71 track_cuts +=
'daughterProductOf(charge) < 0'
72 track_cuts +=
' and daughterLowest(clusterE) <= 0.25'
75 track_cuts +=
' and [daughter(0,isPIDAvailableFrom(KLM)) == 1 or daughter(1,isPIDAvailableFrom(KLM)) == 1]'
78 mA.reconstructDecay(
'vpho:mumu -> mu+:calib mu-:calib', track_cuts, path=path_muon)
81 event_cuts =
'[nCleanedTracks('+goodTrack+
') == 2]'
82 mA.applyEventCuts(event_cuts, path=path_muon)
83 radmumulist = [
'vpho:mumu']
86 skimfilter = basf2.register_module(
'SkimFilter')
87 skimfilter.param(
'particleLists', radmumulist)
88 path_muon.add_module(skimfilter)
90 filter_path = basf2.create_path()
91 skimfilter.if_value(
'=1', filter_path, basf2.AfterConditionPath.CONTINUE)
95 mA.cutAndCopyList(
'mu+:cal',
'mu+:calib', cutonPairs, path=filter_path)
98 event_cutscopy =
'[nCleanedTracks('+goodTrack+
') == 2]'
99 mA.applyEventCuts(event_cutscopy, path=filter_path)
108def make_proton_collection(path_hadrons):
111 trg_skim = path_hadrons.add_module(
"TriggerSkim", triggerLines=[
"software_trigger_cut&skim&accept_lambda"])
112 trg_skim.if_value(
"==0", basf2.Path(), basf2.AfterConditionPath.END)
114 prepare_cdst_analysis(path=path_hadrons)
117 path_hadrons.add_module(
119 relativeCorrections=
False,
129 goodProtonTrack =
'dr< 0.50 and abs(dz)<0.50'
130 mA.fillParticleList(
"p+:calib", goodProtonTrack, path=path_hadrons)
138def make_pion_kaon_collection(path_hadrons):
141 trg_skim = path_hadrons.add_module(
144 "software_trigger_cut&skim&accept_dstar_1",
145 "software_trigger_cut&skim&accept_dstar_3"])
147 trg_skim.if_value(
"==0", basf2.Path(), basf2.AfterConditionPath.END)
149 prepare_cdst_analysis(path=path_hadrons)
152 path_hadrons.add_module(
154 relativeCorrections=
False,
164 clean_K =
'dr < 1.00 and abs(dz) < 1.0 and inCDCAcceptance==1 '
165 clean_K +=
' and [[cosTheta<-0.45 or cosTheta >= 0.80] or [[cosTheta>=-0.45 and cosTheta <= 0.80 and pt <= 0.50]'
166 clean_K +=
' or [cosTheta>=-0.45 and cosTheta <= 0.80 and pt > 0.50 and pidProbabilityExpert(321, TOP) > 0.015 ]]]'
169 mA.fillParticleList(
"K+:calib", clean_K, path=path_hadrons)
172 clean_Pi =
'dr < 1.0 and abs(dz) < 1.0 and inCDCAcceptance==1 '
173 clean_Pi +=
' and [[cosTheta<-0.45 or cosTheta > 0.80] or [[cosTheta>=-0.45 and cosTheta <= 0.80 and pt <= 0.50] '
174 clean_Pi +=
' or [cosTheta>=-0.45 and cosTheta <= 0.80 and pt > 0.50 and pidProbabilityExpert(321, TOP) < 0.60 ]]]'
177 mA.fillParticleList(
"pi+:calib", clean_Pi, path=path_hadrons)
181 clean_Dz1 =
'abs(dM) < 0.020'
182 clean_Dz1 +=
' and [daughter(0,nCDCHits) > 30 or daughter(1, nCDCHits) > 30] '
184 mA.reconstructDecay(
'D0:cal1 -> K-:calib pi+:calib', clean_Dz1, path=path_hadrons)
187 clean_Dz2 =
'abs(dM) < 0.020'
188 clean_Dz2 +=
' and [daughter(0,nCDCHits) > 25 or daughter(1, nCDCHits) > 25 or daughter(2, nCDCHits) > 25 '
189 clean_Dz2 +=
' or daughter(3, nCDCHits) > 25] '
190 mA.reconstructDecay(
'D0:cal2 -> K-:calib pi+:calib pi+:calib pi-:calib', clean_Dz2, path=path_hadrons)
194 clean_sPi =
'dr < 1.00 and abs(dz) < 1.00 and p < 1.5 and nCDCHits > 10 and inCDCAcceptance==1'
195 mA.fillParticleList(
"pi+:slow", clean_sPi, path=path_hadrons)
200 clean_Ds =
'useCMSFrame(p) > 1.5 and abs(formula(massDifference(0) - 0.14542)) < 0.00070 '
201 clean_Ds +=
' and abs(dM) < 0.020'
202 mA.reconstructDecay(
'D*+:cal1 -> D0:cal1 pi+:slow', clean_Ds, path=path_hadrons)
205 list_Ds1 = [
'D*+:cal1']
206 skimf_Ds1 = basf2.register_module(
'SkimFilter')
207 skimf_Ds1.param(
'particleLists', list_Ds1)
208 path_hadrons.add_module(skimf_Ds1)
209 fpath_Ds1 = basf2.create_path()
210 skimf_Ds1.if_value(
'=1', fpath_Ds1, basf2.AfterConditionPath.CONTINUE)
213 mA.reconstructDecay(
'D*+:cal2 -> D0:cal2 pi+:slow', clean_Ds, path=path_hadrons)
215 list_Ds2 = [
'D*+:cal2']
216 skimf_Ds2 = basf2.register_module(
'SkimFilter')
217 skimf_Ds2.param(
'particleLists', list_Ds2)
218 path_hadrons.add_module(skimf_Ds2)
219 fpath_Ds2 = basf2.create_path()
220 skimf_Ds2.if_value(
'=1', fpath_Ds2, basf2.AfterConditionPath.CONTINUE)
224 mA.variablesToDaughterExtraInfo(
'D*+:cal1',
'D*+ -> [D0 -> ^K- ^pi+ ] ^pi+', {
'dM':
'l_Ds1dM'}, path=fpath_Ds1)
225 mA.variablesToDaughterExtraInfo(
'D*+:cal1',
'D*+ -> [D0 -> ^K- ^pi+ ] ^pi+', {
'useCMSFrame(p)':
'l_Ds1p'}, path=fpath_Ds1)
226 mA.variablesToDaughterExtraInfo(
'D*+:cal1',
'D*+ -> [D0 -> ^K- ^pi+ ] ^pi+',
227 {
'massDifference(0)':
'l_Ds1mDiff'}, path=fpath_Ds1)
228 mA.variablesToDaughterExtraInfo(
'D*+:cal1',
'D*+ -> [D0 -> ^K- ^pi+ ] ^pi+', {
'daughter(0,dM)':
'l_Ds1_DzdM'}, path=fpath_Ds1)
229 mA.variablesToDaughterExtraInfo(
'D*+:cal1',
230 'D*+ -> [D0 -> ^K- ^pi+ ] ^pi+',
231 {
'daughter(0,daughter(0,nCDCHits))':
'l_Ds1_Dz_Khits'},
233 mA.variablesToDaughterExtraInfo(
'D*+:cal1',
234 'D*+ -> [D0 -> ^K- ^pi+ ] ^pi+',
235 {
'daughter(0,daughter(1,nCDCHits))':
'l_Ds1_Dz_Pihits'},
239 cutonD1var =
"abs(extraInfo(l_Ds1dM)) < 0.02"
240 cutonD1var +=
" and extraInfo(l_Ds1p) > 1.5 "
241 cutonD1var +=
" and abs(formula(extraInfo(l_Ds1mDiff) - 0.14542)) < 0.0010"
242 cutonD1var +=
" and abs(extraInfo(l_Ds1_DzdM)) < 0.02"
243 cutonD1var +=
" and [extraInfo(l_Ds1_Dz_Khits) > 30 or extraInfo(l_Ds1_Dz_Pihits) > 30]"
246 mA.cutAndCopyList(
'K+:dst1',
'K+:calib', cutonD1var, path=fpath_Ds1)
247 mA.cutAndCopyList(
'pi+:dst1',
'pi+:calib', cutonD1var, path=fpath_Ds1)
251 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+', {
'dM':
'l_Ds2dM'}, path=fpath_Ds2)
252 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
253 'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+',
254 {
'useCMSFrame(p)':
'l_Ds2p'},
256 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
257 'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+',
258 {
'massDifference(0)':
'l_Ds2mDiff'},
260 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
261 'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+',
262 {
'daughter(0,dM)':
'l_Ds2_DzdM'},
264 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
265 'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+',
266 {
'daughter(0,daughter(0,nCDCHits))':
'l_Ds2_Dz_Khits'},
268 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
269 'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+',
270 {
'daughter(0,daughter(1,nCDCHits))':
'l_Ds2_Dz_Pi1hits'},
272 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
273 'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+',
274 {
'daughter(0,daughter(2,nCDCHits))':
'l_Ds2_Dz_Pi2hits'},
276 mA.variablesToDaughterExtraInfo(
'D*+:cal2',
277 'D*+ -> [D0 -> ^K- ^pi+ ^pi+ ^pi-] ^pi+',
278 {
'daughter(0,daughter(3,nCDCHits))':
'l_Ds2_Dz_Pi3hits'},
282 cutonD2var =
"abs(extraInfo(l_Ds2dM)) < 0.02"
283 cutonD2var +=
" and extraInfo(l_Ds2p) > 2.0"
284 cutonD2var +=
" and abs(formula(extraInfo(l_Ds2mDiff) - 0.14542)) < 0.0010"
285 cutonD2var +=
" and abs(extraInfo(l_Ds2_DzdM)) < 0.02"
286 cutonD2var +=
" and [extraInfo(l_Ds2_Dz_Khits) > 25 or extraInfo(l_Ds2_Dz_Pi1hits) > 25 "
287 cutonD2var +=
" or extraInfo(l_Ds2_Dz_Pi2hits) > 25 or extraInfo(l_Ds2_Dz_Pi3hits) > 25]"
290 mA.cutAndCopyList(
'K+:dst2',
'K+:calib', cutonD2var, path=fpath_Ds2)
291 mA.cutAndCopyList(
'pi+:dst2',
'pi+:calib', cutonD2var, path=fpath_Ds2)
293 pion_kaon_list = [
'pi+:dst1',
'pi+:dst2',
'K+:dst1',
'K+:dst2']
295 return pion_kaon_list