18 import modularAnalysis
as ma
23 ma.inputMdstList([basf2.find_file(
'analysis/tests/mdst.root')], path=mypath)
24 ma.fillParticleLists([(
'K-',
'kaonID > 0.2'), (
'pi+',
'pionID > 0.2')], path=mypath)
25 ma.reconstructDecay(
'D0 -> K- pi+',
'1.750 < M < 1.95', path=mypath)
26 ma.matchMCTruth(
'D0', path=mypath)
30 mypath.add_module(
'VariablesToNtuple',
32 variables=[
'dM',
'isSignal',
'mcErrors',
'p',
'E',
33 'daughter(0, kaonID)',
'daughter(1, pionID)'],
34 fileName=
'CandidateVariables.root')
39 mypath.add_module(
'VariablesToNtuple',
41 variables=[
'nTracks',
'isMC',
'year'],
42 fileName=
'EventVariables.root')
46 ma.buildRestOfEvent(
'D0', path=mypath)
47 cleanMask = (
'cleanMask',
48 'nCDCHits > 0 and useCMSFrame(p)<=3.2',
49 'p >= 0.05 and useCMSFrame(p)<=3.2'
51 ma.appendROEMasks(
'D0', mask_tuples=[cleanMask], path=mypath)
54 roe_path = basf2.Path()
55 ma.fillParticleList(
'pi+:inRoe',
'isInRestOfEvent > 0 and passesROEMask(cleanMask)', path=roe_path)
56 ma.variablesToNtuple(decayString=
'pi+:inRoe',
58 filename=
'CandidateVariables.root',
60 signalSideParticleList=
'D0',
62 mypath.for_each(
'RestOfEvent',
'RestOfEvents', roe_path)
71 print(basf2.statistics)