18 from optparse
import OptionParser
23 b2.set_log_level(b2.LogLevel.INFO)
25 outroot =
'arichbtest.root'
27 parser = OptionParser()
28 parser.add_option(
'-r',
'--run', dest=
'runno', default=
'068',
30 parser.add_option(
'-p',
'--path', dest=
'path',
31 default=
'/afs/f9.ijs.si/data/belle/data/beamtests/2011/run',
34 parser.add_option(
'-y',
'--year', dest=
'year', default=
'2011',
35 help=
'beam test year')
37 parser.add_option(
'-t',
'--track-mask', dest=
'mask', default=
'0x5',
38 help=
'track mask 4 bits')
40 parser.add_option(
'-m',
'--avgagel', dest=
'avgagel', default=
'0',
41 help=
'average thc calculation based on the mean agel')
48 help=
'Output filename',
52 parser.add_option(
'-n',
'--neve', dest=
'neve', default=20000,
53 help=
'Number of events to process')
55 (options, args) = parser.parse_args()
57 fname = options.path +
'/run' + options.runno +
'.dat'
59 if not os.path.isfile(fname):
60 print(
'File does not exist:')
63 print(
'Appending .gz...')
64 if not os.path.isfile(fname):
65 print(
'File does not exist:')
69 if options.output == outroot:
70 outroot =
'run_' + options.runno +
'.root'
72 outroot = options.output
74 mask = int(options.mask, 16)
75 runno = int(options.runno)
77 print(
'TrackMask:' + options.mask)
80 averageagel = int(options.avgagel)
82 eventinfosetter = b2.register_module(
'EventInfoSetter')
83 eventinfosetter.param(
'evtNumList', [int(options.neve)])
84 eventinfosetter.param(
'runList', [int(options.runno)])
85 eventinfosetter.param(
'expList', [1])
88 paramloader = b2.register_module(
'Gearbox')
90 xmlgeometry =
'file://%s/arich/modules/arichBtest/data/%s/arichBtest%s.xml' \
91 % (os.getcwd(), options.year, options.year)
92 paramloader.param(
'fileName', xmlgeometry)
94 paramloader.param(
'fileName', xmlgeometry)
107 geobuilder = b2.register_module(
'Geometry')
108 geobuilder.param(
'components', [
'ARICHBtest'])
110 btest = b2.register_module(
'arichBtest')
111 btest.param(
'mwpcTrackMask', [mask])
113 btest.param(
'runList', [fname])
114 btest.param(
'outputFileName', outroot)
116 if options.year ==
'2013':
118 print(
'Beam momentum ' + str(momentum))
119 btest.param(
'beamMomentum', momentum)
122 g4sim = b2.register_module(
'FullSim')
125 g4sim.param(
'RegisterOptics', 1)
129 g4sim.param(
'PhotonFraction', 0.3)
131 g4sim.param(
'EnableVisualization',
True)
135 g4sim.param(
'UICommandsAtIdle', [
'/vis/open VRML2FILE',
'/vis/drawVolume',
136 '/vis/scene/add/axes 0 0 0 100 mm'])
139 geosaver = b2.register_module(
'ExportGeometry')
140 geosaver.param(
'Filename',
'Belle2Geo.root')
142 arichrec = b2.register_module(
'ARICHReconstructor')
143 arichrec.param(
'inputTrackType', 1)
144 arichrec.param(
'beamtest', 3)
145 arichrec.param(
'trackPositionResolution', 0.0)
146 arichrec.param(
'trackAngleResolution', 0.0)
148 profile = b2.register_module(
'Profile')
149 profile.param(
'outputFileName',
'profileusage.ps')
151 main = b2.create_path()
152 main.add_module(eventinfosetter)
153 main.add_module(paramloader)
155 main.add_module(geobuilder)
156 main.add_module(btest)
157 main.add_module(arichrec)
159 main.add_module(geosaver)
164 print(
'Event Statistics:')