Belle II Software
release-08-01-10
trainFeasibleTrackRelationFilter.py
1
#!/usr/bin/env python3
2
# -*- coding: utf-8 -*-
3
4
11
12
import
os
13
import
sys
14
import
os.path
15
16
from
tracking.run.event_generation
import
ReadOrGenerateEventsRun
17
from
trackfindingcdc.run.training
import
TrainingRunMixin
18
19
20
class
FeasibleTrackRelationFilterTrainingRun
(TrainingRunMixin,
ReadOrGenerateEventsRun
):
21
"""Run to record track relations encountered at the TrackLinker and retrain its mva method"""
22
23
24
n_events = 10000
25
26
generator_module =
"generic"
27
28
bkg_files = os.path.join(os.environ[
"VO_BELLE2_SW_DIR"
],
"bkg"
)
29
30
31
truth =
"truth_positive"
32
33
@property
34
def
identifier
(self):
35
"""Database identifier of the filter being trained"""
36
return
"trackfindingcdc_FeasibleTrackRelationFilter.xml"
37
38
def
create_path
(self):
39
"""Setup the recording path after the simulation"""
40
path = super().
create_path
()
41
path.add_module(
"TFCDC_WireHitPreparer"
,
42
flightTimeEstimation=
"outwards"
)
43
44
path.add_module(
'TFCDC_ClusterPreparer'
,
45
SuperClusterDegree=3,
46
SuperClusterExpandOverApogeeGap=
True
)
47
48
path.add_module(
"TFCDC_SegmentFinderFacetAutomaton"
)
49
50
51
if
self.
task
task ==
"train"
:
52
varSets = [
53
"feasible"
,
54
"filter(truth)"
,
55
]
56
57
elif
self.
task
task ==
"eval"
:
58
varSets = [
59
"filter(feasible)"
,
60
"filter(truth)"
,
61
]
62
63
elif
self.
task
task ==
"explore"
:
64
varSets = [
65
"basic"
,
66
"hit_gap"
,
67
"filter(truth)"
,
68
]
69
70
else
:
71
raise
ValueError(
"Unknown task "
+ self.
task
task)
72
73
path.add_module(
"TFCDC_TrackFinderSegmentPairAutomaton"
,
74
TrackRelationFilter=
"unionrecording"
,
75
TrackRelationFilterParameters={
76
"rootFileName"
: self.sample_file_name,
77
"varSets"
: varSets,
78
})
79
80
return
path
81
82
83
def
main
():
84
run =
FeasibleTrackRelationFilterTrainingRun
()
85
run.configure_and_execute_from_commandline()
86
87
88
if
__name__ ==
"__main__"
:
89
import
logging
90
logging.basicConfig(stream=sys.stdout, level=logging.INFO, format=
'%(levelname)s:%(message)s'
)
91
main
()
tracking.run.event_generation.ReadOrGenerateEventsRun
Definition:
event_generation.py:35
trainFeasibleTrackRelationFilter.FeasibleTrackRelationFilterTrainingRun
Definition:
trainFeasibleTrackRelationFilter.py:20
trainFeasibleTrackRelationFilter.FeasibleTrackRelationFilterTrainingRun.create_path
def create_path(self)
Definition:
trainFeasibleTrackRelationFilter.py:38
trainFeasibleTrackRelationFilter.FeasibleTrackRelationFilterTrainingRun.task
task
Process each event according to the user's desired task (train, eval, explore)
Definition:
trainFeasibleTrackRelationFilter.py:51
trainFeasibleTrackRelationFilter.FeasibleTrackRelationFilterTrainingRun.identifier
def identifier(self)
Definition:
trainFeasibleTrackRelationFilter.py:34
main
Definition:
main.py:1
tracking.run.event_generation
Definition:
event_generation.py:1
main
int main(int argc, char **argv)
Run all tests.
Definition:
test_main.cc:91
tracking
trackFindingCDC
train
trainFeasibleTrackRelationFilter.py
Generated on Mon Sep 23 2024 14:06:21 for Belle II Software by
1.9.1