12 A test of the ROE-related module tests using a large test file
13 (mdst14.root from the validation server)
17 from basf2
import set_random_seed, create_path, process
22 set_random_seed(
"1337")
23 fsps = [
'K-:all',
'pi-:all',
'gamma:all',
'K_L0:all']
27 testpath = create_path()
28 testpath.add_module(
'RootInput', inputFileNames=inputFile)
30 testpath.add_module(
'ParticleLoader', decayStrings=[fsp])
31 testpath.add_module(
'ParticleSelector', decayString=
'gamma:all', cut=
'isFromECL')
32 testpath.add_module(
'ParticleStats', particleLists=[fsps[0]])
34 testpath.add_module(
'RestOfEventBuilder', particleList=fsps[0],
35 particleListsInput=[
'pi+:all',
'gamma:all',
'K_L0:all'])
36 mask = (
'cleanMask',
'E > 0.05',
'E > 0.05',
'')
37 testpath.add_module(
'RestOfEventInterpreter', particleList=fsps[0],
41 roe_path = create_path()
42 v0list =
'K_S0:V0 -> pi+ pi-'
43 roe_path.add_module(
'ParticleLoader', decayStrings=[v0list])
45 roe_path.add_module(
'ParticleLoader', decayStrings=[
'mu+'])
46 roe_path.add_module(
'ParticleListManipulator', outputListName=
'mu+:roe',
47 inputListNames=[
'mu+:all'],
48 cut=
'isInRestOfEvent == 1 and isSignal == 1')
50 roe_path.add_module(
'RestOfEventUpdater',
51 particleList=v0list.split(
' ->', 1)[0],
52 updateMasks=[mask[0]])
53 roe_path.add_module(
'RestOfEventPrinter',
57 jpsi_roe_list =
'J/psi:roe'
58 roe_path.add_module(
'ParticleCombiner',
59 decayString=jpsi_roe_list +
' -> mu+:roe mu-:roe',
61 roe_path.add_module(
'ParticlePrinter', listName=jpsi_roe_list, fullPrint=
False)
63 roe_path.add_module(
'RestOfEventBuilder', particleList=jpsi_roe_list,
64 createNestedROE=
True, nestedROEMask=mask[0])
67 nested_roe_path = create_path()
69 nested_roe_path.add_module(
'RestOfEventPrinter',
72 roe_path.for_each(
'RestOfEvent',
'NestedRestOfEvents', path=nested_roe_path)
75 nested_list =
'B+:other'
76 roe_path.add_module(
'ParticleLoader',
77 decayStrings=[nested_list +
' -> ' + jpsi_roe_list],
80 roe_path.add_module(
'ParticleStats', particleLists=[nested_list])
81 roe_path.add_module(
'ParticlePrinter', listName=nested_list, fullPrint=
True)
83 testpath.for_each(
'RestOfEvent',
'RestOfEvents', path=roe_path)
def configure_logging_for_tests(user_replacements=None)
def require_file(filename, data_type="", py_case=None)