11 """This script is used in the nightly build to check for memory issues with valgrind.
12 It is run as a test to make sure the memcheck does not fail because of issues in the script."""
14 from b2test_utils
import skip_test_if_light
17 from basf2
import set_random_seed, set_log_level, LogLevel, create_path, Module, find_file, process, statistics, conditions
18 from simulation
import add_simulation
19 from reconstruction
import add_reconstruction
20 from mdst
import add_mdst_output
21 from ROOT
import Belle2
22 from modularAnalysis
import reconstructDecay, rankByHighest, buildRestOfEvent, buildContinuumSuppression, matchMCTruth, \
23 variablesToNtuple, getAnalysisGlobaltag
24 from stdCharged
import stdPi, stdMu
25 from vertex
import treeFit, TagV
26 from flavorTagger
import flavorTagger
27 from rawdata
import add_packers, add_unpackers
36 set_log_level(LogLevel.ERROR)
39 conditions.prepend_globaltag(getAnalysisGlobaltag())
45 main.add_module(
'EventInfoSetter')
49 """Module to stop the event processing in case the argument InitOnly is given"""
52 """Set the event meta data to end of data"""
55 eventMetaData.setEndOfData()
58 if len(sys.argv) > 1
and sys.argv[1] ==
'InitOnly':
62 evtmetainfo = main.add_module(
'EventInfoPrinter')
63 evtmetainfo.set_log_level(LogLevel.INFO)
66 main.add_module(
'EvtGenInput', userDECFile=find_file(
'decfiles/dec/1111440100.dec'))
70 if 'BELLE2_BACKGROUND_DIR' in os.environ:
71 bg = glob.glob(os.environ[
'BELLE2_BACKGROUND_DIR'] +
'/*.root')
72 add_simulation(main, bkgfiles=bg)
75 add_reconstruction(main)
78 add_mdst_output(main,
True)
81 main.add_module(
'RootOutput', outputFileName=
'dst.root')
85 stdPi(
'loose', path=main)
86 stdMu(
'loose', path=main)
89 reconstructDecay(
'K_S0:pipi -> pi+:loose pi-:loose', cut=
'0.4 < M < 0.6', path=main)
92 reconstructDecay(
'J/psi:mumu -> mu+:loose mu-:loose', cut=
'3.0 < M < 3.2', path=main)
95 reconstructDecay(
'B0:jpsiks -> J/psi:mumu K_S0:pipi', cut=
'5.2 < M < 5.4', path=main)
98 treeFit(
'B0:jpsiks', 0.0, path=main)
101 rankByHighest(
'B0:jpsiks',
'chiProb', path=main)
104 buildRestOfEvent(
'B0:jpsiks', path=main)
107 buildContinuumSuppression(
'B0:jpsiks',
'all', path=main)
110 matchMCTruth(
'B0:jpsiks', path=main)
116 TagV(
'B0:jpsiks',
'breco', path=main)
119 fs_vars = [
'kaonID',
'muonID',
'dr',
'dz',
'pValue',
'isSignal',
'mcErrors',
'genMotherID']
120 b_vars = [
'nTracks',
'Mbc',
'deltaE',
'p',
'E',
'useCMSFrame(p)',
'useCMSFrame(E)',
121 'isSignal',
'mcErrors',
'nROE_KLMClusters',
'qrOutput(FBDT)',
'TagVLBoost',
'TagVz',
'TagVzErr',
'mcDeltaT'] + \
122 [
'daughter(0,daughter(0,%s))' % var
for var
in fs_vars]
125 variablesToNtuple(
'B0:jpsiks', variables=b_vars, filename=
'ntuple.root', treename=
'B0tree', path=main)
130 for module
in main.modules():
131 if module.type() ==
'SVDUnpacker':
132 module.param(
'silentlyAppend',
True)
135 main.add_module(
'Profile', outputFileName=
'vmem_profile.png', rssOutputFileName=
'rss_profile.png').set_log_level(LogLevel.INFO)
a (simplified) python wrapper for StoreObjPtr.