DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
generate Namespace Reference

Functions

 generate_dataflow (oksfile, include, n_dfapps, tpwriting_enabled, generate_segment, n_data_writers=1, trmon_app=False)
 
 generate_hsi (oksfile, include, generate_segment)
 
 generate_readout (readoutmap, oksfile, include, generate_segment, emulated_file_name, tpg_enabled=True, hosts_to_use=[])
 
 generate_fakedata (oksfile, include, generate_segment, n_streams, n_apps, det_id)
 
 generate_trigger (oksfile, include, generate_segment, tpg_enabled=True, hsi_enabled=False)
 
 generate_session (oksfile, include, session_name, op_env, connectivity_service_is_infrastructure_app=True, disable_connectivity_service=False)
 

Function Documentation

◆ generate_dataflow()

generate.generate_dataflow ( oksfile,
include,
n_dfapps,
tpwriting_enabled,
generate_segment,
n_data_writers = 1,
trmon_app = False )
Simple script to create an OKS configuration file for a dataflow segment.

  The file will automatically include the relevant schema files and
any other OKS files you specify.

Definition at line 10 of file generate.py.

18):
19 """Simple script to create an OKS configuration file for a dataflow segment.
20
21 The file will automatically include the relevant schema files and
22 any other OKS files you specify.
23 """
24
25 includefiles = [
26 "schema/confmodel/dunedaq.schema.xml",
27 "schema/appmodel/application.schema.xml",
28 ]
29
30 res, extra_includes = find_oksincludes(include, os.path.dirname(oksfile))
31 if res:
32 includefiles += extra_includes
33 else:
34 return
35
36 dal = conffwk.dal.module("generated", includefiles)
37 db = conffwk.Configuration("oksconflibs")
38 if not oksfile.endswith(".data.xml"):
39 oksfile = oksfile + ".data.xml"
40 print(f"Creating OKS database file {oksfile}")
41 db.create_db(oksfile, includefiles)
42 db.set_active(oksfile)
43
44 hosts = []
45 for vhost in db.get_dals(class_name="VirtualHost"):
46 hosts.append(vhost.id)
47 if vhost.id == "vlocalhost":
48 host = vhost
49 if "vlocalhost" not in hosts:
50 cpus = dal.ProcessingResource("cpus", cpu_cores=[0, 1, 2, 3])
51 db.update_dal(cpus)
52 phdal = dal.PhysicalHost("localhost", contains=[cpus])
53 db.update_dal(phdal)
54 host = dal.VirtualHost("vlocalhost", runs_on=phdal, uses=[cpus])
55 db.update_dal(host)
56 hosts.append("vlocalhost")
57
58 # Services
59 daqapp_control = db.get_dal(class_name="Service", uid="daqapp_control")
60 rccontroller_control = db.get_dal(class_name="Service", uid="rccontroller_control")
61
62 # Source IDs
63 tpw_source_id = db.get_dal("SourceIDConf", uid="srcid-tp-stream-writer")
64
65 # Queue Rules
66 trigger_record_q_rule = db.get_dal(
67 class_name="QueueConnectionRule", uid="trigger-record-q-rule"
68 )
69 dfapp_qrules = [trigger_record_q_rule]
70
71 # Net Rules
72 frag_net_rule = db.get_dal(class_name="NetworkConnectionRule", uid="frag-net-rule")
73 df_token_net_rule = db.get_dal(
74 class_name="NetworkConnectionRule", uid="df-token-net-rule"
75 )
76 tpset_net_rule = db.get_dal(
77 class_name="NetworkConnectionRule", uid="tpset-net-rule"
78 )
79 ti_net_rule = db.get_dal(class_name="NetworkConnectionRule", uid="ti-net-rule")
80 td_dfo_net_rule = db.get_dal(
81 class_name="NetworkConnectionRule", uid="td-dfo-net-rule"
82 )
83 td_trb_net_rule = db.get_dal(
84 class_name="NetworkConnectionRule", uid="td-trb-net-rule"
85 )
86 data_req_trig_net_rule = db.get_dal(
87 class_name="NetworkConnectionRule", uid="data-req-trig-net-rule"
88 )
89 data_req_hsi_net_rule = db.get_dal(
90 class_name="NetworkConnectionRule", uid="data-req-hsi-net-rule"
91 )
92 data_req_readout_net_rule = db.get_dal(
93 class_name="NetworkConnectionRule", uid="data-req-readout-net-rule"
94 )
95 dfapp_netrules = [
96 td_trb_net_rule,
97 frag_net_rule,
98 df_token_net_rule,
99 data_req_hsi_net_rule,
100 data_req_readout_net_rule,
101 data_req_trig_net_rule,
102 ]
103
104 trmon_netrules = []
105 trmon_qrules = []
106 if trmon_app:
107 trmon_req_net_rule = db.get_dal(
108 class_name="NetworkConnectionRule", uid="trmon-req-net-rule"
109 )
110 trigger_record_net_rule = db.get_dal(
111 class_name="NetworkConnectionRule", uid="trigger-record-net-rule"
112 )
113 dfapp_netrules.append(trmon_req_net_rule)
114 dfapp_netrules.append(trigger_record_net_rule)
115
116 trmon_netrules.append(trigger_record_net_rule)
117 trigger_decision_token_q_rule = db.get_dal(
118 class_name="QueueConnectionRule", uid="trigger-decision-token-q-rule"
119 )
120 trmon_qrules.append(trigger_decision_token_q_rule)
121
122 dfo_netrules = [td_dfo_net_rule, ti_net_rule, df_token_net_rule]
123 tpw_netrules = [tpset_net_rule]
124
125 opmon_conf = db.get_dal(class_name="OpMonConf", uid="slow-all-monitoring")
126
127 dfo_conf = db.get_dal(class_name="DFOConf", uid="dfoconf-01")
128 dfo = dal.DFOApplication(
129 "dfo-01",
130 runs_on=host,
131 application_name="daq_application",
132 exposes_service=[daqapp_control],
133 network_rules=dfo_netrules,
134 opmon_conf=opmon_conf,
135 dfo=dfo_conf,
136 )
137 db.update_dal(dfo)
138
139 trb_conf = db.get_dal(class_name="TRBConf", uid="trb-01")
140 dw_conf = db.get_dal(class_name="DataWriterConf", uid="dw-01")
141 dfhw = db.get_dal(class_name="DFHWConf", uid="dfhw-01")
142 dfapps = []
143 for dfapp_idx in range(n_dfapps):
144 dfapp_id = dfapp_idx + 1
145
146 # Offset sids by one so that TPW sourceID can stay at 1
147 dfapp_source_id = dal.SourceIDConf(
148 f"srcid-df-{dfapp_id:02}", sid=dfapp_id + 1, subsystem="TR_Builder"
149 )
150 db.update_dal(dfapp_source_id)
151
152 dfapp = dal.DFApplication(
153 f"df-{dfapp_id:02}",
154 runs_on=host,
155 application_name="daq_application",
156 exposes_service=[daqapp_control],
157 source_id=dfapp_source_id,
158 queue_rules=dfapp_qrules,
159 network_rules=dfapp_netrules,
160 opmon_conf=opmon_conf,
161 trb=trb_conf,
162 data_writers=[dw_conf] * n_data_writers,
163 uses=dfhw,
164 )
165 db.update_dal(dfapp)
166 dfapps.append(dfapp)
167
168 tpwapps = []
169 if tpwriting_enabled:
170 tpw_writer_conf = db.get_dal(
171 class_name="TPStreamWriterConf", uid="tp-stream-writer-conf"
172 )
173
174 tpwapp = dal.TPStreamWriterApplication(
175 "tp-stream-writer",
176 runs_on=host,
177 application_name="daq_application",
178 exposes_service=[daqapp_control],
179 source_id=tpw_source_id,
180 network_rules=tpw_netrules,
181 opmon_conf=opmon_conf,
182 tp_writer=tpw_writer_conf,
183 )
184 db.update_dal(tpwapp)
185 tpwapps.append(tpwapp)
186
187 trmonapps = []
188 if trmon_app:
189 trmonconf = db.get_dal(class_name="TRMonRequestorConf", uid="trmr-01")
190 trmondwconf = db.get_dal(class_name="DataWriterConf", uid="tr_mon_dw-01")
191
192 trmonapp = dal.TRMonReqApplication(
193 "trmon-01",
194 runs_on=host,
195 application_name="daq_application",
196 exposes_service=[daqapp_control],
197 network_rules=trmon_netrules,
198 queue_rules=trmon_qrules,
199 opmon_conf=opmon_conf,
200 trmonreq=trmonconf,
201 data_writer=trmondwconf,
202 uses=dfhw,
203 )
204 db.update_dal(trmonapp)
205 trmonapps.append(trmonapp)
206
207 if generate_segment:
208 fsm = db.get_dal(class_name="FSMconfiguration", uid="FSMconfiguration_noAction")
209 controller = dal.RCApplication(
210 "df-controller",
211 application_name="drunc-controller",
212 runs_on=host,
213 fsm=fsm,
214 opmon_conf=opmon_conf,
215 exposes_service=[rccontroller_control],
216 )
217 db.update_dal(controller)
218
219 seg = dal.Segment(
220 f"df-segment",
221 controller=controller,
222 applications=[dfo] + dfapps + tpwapps + trmonapps,
223 )
224 db.update_dal(seg)
225
226 try:
227 db.commit()
228 except RuntimeError as err:
229 print("Failed to commit Dataflow DB!")
230 print(traceback.format_exc())
231 raise err
232 return
233
234
module(name, schema, other_dals=[], backend='oksconflibs', db=None)
Definition dal.py:673

◆ generate_fakedata()

generate.generate_fakedata ( oksfile,
include,
generate_segment,
n_streams,
n_apps,
det_id )
Simple script to create an OKS configuration file for a FakeDataProd-based readout segment.

  The file will automatically include the relevant schema files and
any other OKS files you specify.

Definition at line 791 of file generate.py.

791def generate_fakedata(oksfile, include, generate_segment, n_streams, n_apps, det_id):
792 """Simple script to create an OKS configuration file for a FakeDataProd-based readout segment.
793
794 The file will automatically include the relevant schema files and
795 any other OKS files you specify.
796
797 """
798
799 includefiles = [
800 "schema/confmodel/dunedaq.schema.xml",
801 "schema/appmodel/application.schema.xml",
802 ]
803
804 res, extra_includes = find_oksincludes(include, os.path.dirname(oksfile))
805 if res:
806 includefiles += extra_includes
807 else:
808 return
809
810 dal = conffwk.dal.module("generated", includefiles)
811 db = conffwk.Configuration("oksconflibs")
812 if not oksfile.endswith(".data.xml"):
813 oksfile = oksfile + ".data.xml"
814 print(f"Creating OKS database file {oksfile}")
815 db.create_db(oksfile, includefiles)
816 db.set_active(oksfile)
817
818 hosts = []
819 for vhost in db.get_dals(class_name="VirtualHost"):
820 hosts.append(vhost.id)
821 if vhost.id == "vlocalhost":
822 host = vhost
823 if "vlocalhost" not in hosts:
824 cpus = dal.ProcessingResource("cpus", cpu_cores=[0, 1, 2, 3])
825 db.update_dal(cpus)
826 phdal = dal.PhysicalHost("localhost", contains=[cpus])
827 db.update_dal(phdal)
828 host = dal.VirtualHost("vlocalhost", runs_on=phdal, uses=[cpus])
829 db.update_dal(host)
830 hosts.append("vlocalhost")
831
832 source_id = 0
833 fakeapps = []
834 # Services
835 daqapp_control = db.get_dal(class_name="Service", uid="daqapp_control")
836 rccontroller_control = db.get_dal(class_name="Service", uid="rccontroller_control")
837 dataRequests = db.get_dal(class_name="Service", uid="dataRequests")
838 timeSyncs = db.get_dal(class_name="Service", uid="timeSyncs")
839 opmon_conf = db.get_dal(class_name="OpMonConf", uid="slow-all-monitoring")
840 fragagg = db.get_dal(class_name="FragmentAggregatorConf", uid="frag-agg-01")
841
842 rule = db.get_dal(
843 class_name="NetworkConnectionRule", uid="data-req-readout-net-rule"
844 )
845 netrules = [rule]
846 for rule in ["ts-fdp-net-rule"]:
847 netrules.append(db.get_dal(class_name="NetworkConnectionRule", uid=rule))
848
849 try:
850 rule = db.get_dal(
851 class_name="QueueConnectionRule", uid="fpdm-data-requests-queue-rule"
852 )
853 except:
854 print(
855 'Expected QueueConnectionRule "fpdm-data-requests-queue-rule" not found in input databases!'
856 )
857 else:
858 qrules = [rule]
859 for rule in [
860 "fa-queue-rule",
861 ]:
862 qrules.append(db.get_dal(class_name="QueueConnectionRule", uid=rule))
863
864 frame_size = 0
865 fragment_type = ""
866 if det_id == 3:
867 frame_size = 7200
868 time_tick_diff = 32 * 64
869 response_delay = 0
870 fragment_type = "WIBEth"
871 else:
872 raise Exception(
873 f"FakeDataProd parameters not configured for detector ID {det_id}"
874 )
875
876 for appidx in range(n_apps):
877
878 fakeapp = dal.FakeDataApplication(f"fakedata_{appidx}",
879 runs_on=host,
880 application_name="daq_application",
881 exposes_service=[daqapp_control, dataRequests, timeSyncs],
882 queue_rules=qrules,
883 network_rules=netrules,
884 fragment_aggregator=fragagg,
885 opmon_conf=opmon_conf,)
886
887 for streamidx in range(n_streams):
888 stream = dal.FakeDataProdConf(
889 f"fakedata_{appidx}_stream_{streamidx}",
890 system_type="Detector_Readout",
891 source_id=source_id,
892 time_tick_diff=time_tick_diff,
893 frame_size=frame_size,
894 response_delay=response_delay,
895 fragment_type=fragment_type,
896 )
897 db.update_dal(stream)
898 fakeapp.producers.append(stream)
899 source_id = source_id + 1
900
901 db.update_dal(fakeapp)
902 fakeapps.append(fakeapp)
903
904 if generate_segment:
905 fsm = db.get_dal(class_name="FSMconfiguration", uid="FSMconfiguration_noAction")
906 controller = dal.RCApplication(
907 "ru-controller",
908 application_name="drunc-controller",
909 opmon_conf=opmon_conf,
910 runs_on=host,
911 fsm=fsm,
912 exposes_service=[rccontroller_control],
913 )
914 db.update_dal(controller)
915
916 seg = dal.Segment(
917 f"ru-segment",
918 controller=controller,
919 applications=fakeapps,
920 )
921 db.update_dal(seg)
922
923 db.commit()
924 return
925
926

◆ generate_hsi()

generate.generate_hsi ( oksfile,
include,
generate_segment )
Simple script to create an OKS configuration file for a FakeHSI segment.

  The file will automatically include the relevant schema files and
any other OKS files you specify.

Definition at line 235 of file generate.py.

239):
240 """Simple script to create an OKS configuration file for a FakeHSI segment.
241
242 The file will automatically include the relevant schema files and
243 any other OKS files you specify.
244
245
246 """
247
248 includefiles = [
249 "schema/confmodel/dunedaq.schema.xml",
250 "schema/appmodel/application.schema.xml",
251 "schema/appmodel/trigger.schema.xml",
252 ]
253
254 res, extra_includes = find_oksincludes(include, os.path.dirname(oksfile))
255 if res:
256 includefiles += extra_includes
257 else:
258 return
259
260 dal = conffwk.dal.module("generated", includefiles)
261 db = conffwk.Configuration("oksconflibs")
262 if not oksfile.endswith(".data.xml"):
263 oksfile = oksfile + ".data.xml"
264 print(f"Creating OKS database file {oksfile}")
265 db.create_db(oksfile, includefiles)
266 db.set_active(oksfile)
267
268 hosts = []
269 for vhost in db.get_dals(class_name="VirtualHost"):
270 hosts.append(vhost.id)
271 if vhost.id == "vlocalhost":
272 host = vhost
273 if "vlocalhost" not in hosts:
274 cpus = dal.ProcessingResource("cpus", cpu_cores=[0, 1, 2, 3])
275 db.update_dal(cpus)
276 phdal = dal.PhysicalHost("localhost", contains=[cpus])
277 db.update_dal(phdal)
278 host = dal.VirtualHost("vlocalhost", runs_on=phdal, uses=[cpus])
279 db.update_dal(host)
280 hosts.append("vlocalhost")
281
282 # Services
283 daqapp_control = db.get_dal(class_name="Service", uid="daqapp_control")
284 rccontroller_control = db.get_dal(class_name="Service", uid="rccontroller_control")
285 dataRequests = db.get_dal(class_name="Service", uid="dataRequests")
286 hsievents = db.get_dal(class_name="Service", uid="HSIEvents")
287
288 # Source IDs
289 hsi_source_id = db.get_dal(class_name="SourceIDConf", uid="hsi-srcid-01")
290 hsi_tc_source_id = db.get_dal(class_name="SourceIDConf", uid="hsi-tc-srcid-1")
291
292 # Queue Rules
293 hsi_dlh_queue_rule = db.get_dal(
294 class_name="QueueConnectionRule", uid="hsi-dlh-data-requests-queue-rule"
295 )
296 hsi_qrules = [hsi_dlh_queue_rule]
297
298 # Net Rules
299 tc_net_rule = db.get_dal(class_name="NetworkConnectionRule", uid="tc-net-rule")
300 hsi_rule = db.get_dal(class_name="NetworkConnectionRule", uid="hsi-rule")
301 ts_hsi_net_rule = db.get_dal(
302 class_name="NetworkConnectionRule", uid="ts-hsi-net-rule"
303 )
304 data_req_hsi_net_rule = db.get_dal(
305 class_name="NetworkConnectionRule", uid="data-req-hsi-net-rule"
306 )
307 hsi_netrules = [hsi_rule, data_req_hsi_net_rule, ts_hsi_net_rule]
308 tc_netrules = [hsi_rule, tc_net_rule]
309
310 opmon_conf = db.get_dal(class_name="OpMonConf", uid="slow-all-monitoring")
311 hsi_handler = db.get_dal(class_name="DataHandlerConf", uid="def-hsi-handler")
312 fakehsi = db.get_dal(class_name="FakeHSIEventGeneratorConf", uid="fakehsi")
313
314 hsi = dal.FakeHSIApplication(
315 "hsi-01",
316 runs_on=host,
317 application_name="daq_application",
318 exposes_service=[daqapp_control],
319 source_id=hsi_source_id,
320 queue_rules=hsi_qrules,
321 network_rules=hsi_netrules,
322 opmon_conf=opmon_conf,
323 link_handler=hsi_handler,
324 generator=fakehsi,
325 )
326 db.update_dal(hsi)
327
328 hsi_to_tc_conf = db.get_dal(class_name="HSI2TCTranslatorConf", uid="hsi-to-tc-conf")
329
330 hsi_to_tc = dal.HSIEventToTCApplication(
331 "hsi-to-tc-app",
332 runs_on=host,
333 application_name="daq_application",
334 exposes_service=[dataRequests, hsievents, daqapp_control],
335 source_id=hsi_tc_source_id,
336 network_rules=tc_netrules,
337 opmon_conf=opmon_conf,
338 hsevent_to_tc_conf=hsi_to_tc_conf,
339 )
340 db.update_dal(hsi_to_tc)
341
342 if generate_segment:
343 fsm = db.get_dal(class_name="FSMconfiguration", uid="FSMconfiguration_noAction")
344 controller = dal.RCApplication(
345 "hsi-controller",
346 application_name="drunc-controller",
347 runs_on=host,
348 fsm=fsm,
349 opmon_conf=opmon_conf,
350 exposes_service=[rccontroller_control],
351 )
352 db.update_dal(controller)
353
354 seg = dal.Segment(
355 f"hsi-segment", controller=controller, applications=[hsi, hsi_to_tc]
356 )
357 db.update_dal(seg)
358
359 db.commit()
360 return
361
362

◆ generate_readout()

generate.generate_readout ( readoutmap,
oksfile,
include,
generate_segment,
emulated_file_name,
tpg_enabled = True,
hosts_to_use = [] )
Simple script to create an OKS configuration file for all
ReadoutApplications defined in a readout map.

The file will automatically include the relevant schema files and
any other OKS files you specify.

Example:
 generate_readoutOKS -i hosts \
   -i appmodel/connections.data.xml -i appmodel/moduleconfs \
   config/np04readoutmap.data.xml readoutApps.data.xml

Will load hosts, connections and moduleconfs data files as well as
the readoutmap (config/np04readoutmap.data.xml) and write the
generated apps to readoutApps.data.xml.

 generate_readoutOKS --session --segment \
   -i appmodel/fsm -i hosts \
   -i appmodel/connections.data.xml -i appmodel/moduleconfs  \
   config/np04readoutmap.data.xml np04readout-session.data.xml

Will do the same but in addition it will generate a containing
Segment for the apps and a containing Session for the Segment.

NB: Currently FSM generation is not implemented so you must include
an fsm file in order to generate a Segment

Definition at line 363 of file generate.py.

371):
372 """Simple script to create an OKS configuration file for all
373 ReadoutApplications defined in a readout map.
374
375 The file will automatically include the relevant schema files and
376 any other OKS files you specify.
377
378 Example:
379 generate_readoutOKS -i hosts \
380 -i appmodel/connections.data.xml -i appmodel/moduleconfs \
381 config/np04readoutmap.data.xml readoutApps.data.xml
382
383 Will load hosts, connections and moduleconfs data files as well as
384 the readoutmap (config/np04readoutmap.data.xml) and write the
385 generated apps to readoutApps.data.xml.
386
387 generate_readoutOKS --session --segment \
388 -i appmodel/fsm -i hosts \
389 -i appmodel/connections.data.xml -i appmodel/moduleconfs \
390 config/np04readoutmap.data.xml np04readout-session.data.xml
391
392 Will do the same but in addition it will generate a containing
393 Segment for the apps and a containing Session for the Segment.
394
395 NB: Currently FSM generation is not implemented so you must include
396 an fsm file in order to generate a Segment
397
398 """
399
400 if not readoutmap.endswith(".data.xml"):
401 readoutmap = readoutmap + ".data.xml"
402
403 print(f"Readout map file {readoutmap}")
404
405 includefiles = (
406 [
407 "schema/confmodel/dunedaq.schema.xml",
408 "schema/appmodel/application.schema.xml",
409 "schema/appmodel/trigger.schema.xml",
410 "schema/appmodel/fdmodules.schema.xml",
411 "schema/appmodel/wiec.schema.xml",
412 ]
413 + [readoutmap]
414 if os.path.exists(readoutmap)
415 else []
416 )
417
418 searchdirs = [path for path in os.environ["DUNEDAQ_DB_PATH"].split(":")]
419 searchdirs.append(os.path.dirname(oksfile))
420 for inc in include:
421 # print (f"Searching for {inc}")
422 match = False
423 inc = inc.removesuffix(".xml")
424 if inc.endswith(".data"):
425 sub_dirs = ["config", "data"]
426 elif inc.endswith(".schema"):
427 sub_dirs = ["schema"]
428 else:
429 sub_dirs = ["*"]
430 inc = inc + "*"
431 for path in searchdirs:
432 # print (f" {path}/{inc}.xml")
433 matches = glob.glob(f"{inc}.xml", root_dir=path)
434 if len(matches) == 0:
435 for search_dir in sub_dirs:
436 # print (f" {path}/{search_dir}/{inc}.xml")
437 matches = glob.glob(f"{search_dir}/{inc}.xml", root_dir=path)
438 for filename in matches:
439 if filename not in includefiles:
440 print(f"Adding {filename} to include list")
441 includefiles.append(filename)
442 else:
443 print(f"{filename} already in include list")
444 match = True
445 break
446 if match:
447 break
448 if match:
449 break
450 else:
451 for filename in matches:
452 if filename not in includefiles:
453 print(f"Adding {filename} to include list")
454 includefiles.append(filename)
455 else:
456 print(f"{filename} already in include list")
457 match = True
458 break
459
460 if not match:
461 print(f"Error could not find include file for {inc}")
462 return
463
464 dal = conffwk.dal.module("generated", includefiles)
465 db = conffwk.Configuration("oksconflibs")
466 if not oksfile.endswith(".data.xml"):
467 oksfile = oksfile + ".data.xml"
468 print(f"Creating OKS database file {oksfile}")
469 db.create_db(oksfile, includefiles)
470 db.set_active(oksfile)
471
472 detector_connections = db.get_dals(class_name="DetectorToDaqConnection")
473 daqapp_control = db.get_dal(class_name="Service", uid="daqapp_control")
474 rccontroller_control = db.get_dal(class_name="Service", uid="rccontroller_control")
475
476 try:
477 rule = db.get_dal(
478 class_name="NetworkConnectionRule", uid="data-req-readout-net-rule"
479 )
480 except:
481 print(
482 'Expected NetworkConnectionRule "data-req-readout-net-rule" not found in input databases!'
483 )
484 else:
485 netrules = [rule]
486 # Assume we have all the other rules we need
487 for rule in ["tpset-net-rule", "ts-net-rule", "ta-net-rule"]:
488 netrules.append(db.get_dal(class_name="NetworkConnectionRule", uid=rule))
489
490 try:
491 rule = db.get_dal(
492 class_name="QueueConnectionRule", uid="fd-dlh-data-requests-queue-rule"
493 )
494 except:
495 print(
496 'Expected QueueConnectionRule "fd-dlh-data-requests-queue-rule" not found in input databases!'
497 )
498 else:
499 qrules = [rule]
500 for rule in [
501 "fa-queue-rule",
502 "tp-queue-rule",
503 ]:
504 qrules.append(db.get_dal(class_name="QueueConnectionRule", uid=rule))
505
506 hosts = []
507 if len(hosts_to_use) == 0:
508 for vhost in db.get_dals(class_name="VirtualHost"):
509 if vhost.id == "vlocalhost":
510 hosts.append(vhost.id)
511 if "vlocalhost" not in hosts:
512 cpus = dal.ProcessingResource("cpus", cpu_cores=[0, 1, 2, 3])
513 db.update_dal(cpus)
514 phdal = dal.PhysicalHost("localhost", contains=[cpus])
515 db.update_dal(phdal)
516 host = dal.VirtualHost("vlocalhost", runs_on=phdal, uses=[cpus])
517 db.update_dal(host)
518 hosts.append("vlocalhost")
519 else:
520 for vhost in db.get_dals(class_name="VirtualHost"):
521 if vhost.id in hosts_to_use:
522 hosts.append(vhost.id)
523 assert len(hosts) > 0
524
525 rohw = dal.RoHwConfig(f"rohw-{detector_connections[0].id}")
526 db.update_dal(rohw)
527
528 opmon_conf = db.get_dal(class_name="OpMonConf", uid="slow-all-monitoring")
529 fragagg = db.get_dal(class_name="FragmentAggregatorConf", uid="frag-agg-01")
530
531 appnum = 0
532 nicrec = None
533 flxcard = None
534 wm_conf = None
535 hermes_conf = None
536 ruapps = []
537 for connection in detector_connections:
538
539 geo_id = connection.get("GeoId")
540 det_id = geo_id[0].detector_id
541 if det_id == 0:
542 raise Exception(f"Unable to determine detector ID from Hardware Map!")
543
544 tphandler = db.get_dal(class_name="DataHandlerConf", uid="def-tp-handler")
545
546 if det_id == 2:
547 if "DAPHNEStream" in emulated_file_name:
548 linkhandler = db.get_dal(
549 class_name="DataHandlerConf", uid="def-pds-stream-link-handler"
550 )
551 det_q = db.get_dal(
552 class_name="QueueConnectionRule", uid="pds-stream-raw-data-rule"
553 )
554 else:
555 linkhandler = db.get_dal(
556 class_name="DataHandlerConf", uid="def-pds-link-handler"
557 )
558 det_q = db.get_dal(
559 class_name="QueueConnectionRule", uid="pds-raw-data-rule"
560 )
561
562 elif det_id == 3 or det_id == 10:
563 linkhandler = db.get_dal(
564 class_name="DataHandlerConf", uid="def-link-handler"
565 )
566 det_q = db.get_dal(
567 class_name="QueueConnectionRule", uid="wib-eth-raw-data-rule"
568 )
569 elif det_id == 11:
570 linkhandler = db.get_dal(
571 class_name="DataHandlerConf", uid="def-tde-link-handler"
572 )
573 det_q = db.get_dal(
574 class_name="QueueConnectionRule", uid="tde-raw-data-rule"
575 )
576 elif det_id == 12:
577 linkhandler = db.get_dal(
578 class_name="DataHandlerConf", uid="def-crt-bern-link-handler"
579 )
580 det_q = db.get_dal(
581 class_name="QueueConnectionRule", uid="crt-bern-raw-data-rule"
582 )
583 elif det_id == 13:
584 linkhandler = db.get_dal(
585 class_name="DataHandlerConf", uid="def-crt-grenoble-link-handler"
586 )
587 det_q = db.get_dal(
588 class_name="QueueConnectionRule", uid="crt-grenoble-raw-data-rule"
589 )
590
591 hostnum = appnum % len(hosts)
592 # print(f"Looking up host[{hostnum}] ({hosts[hostnum]})")
593 host = db.get_dal(class_name="VirtualHost", uid=hosts[hostnum])
594
595 # Find which type of DataReceiver we need for this connection
596 if connection.className() == "NetworkDetectorToDaqConnection":
597 receiver = connection.net_receiver
598 elif connection.className() == "FelixDetectorToDaqConnection":
599 receiver = connection.felix_receiver
600
601 # Action Plans
602 readout_start = db.get_dal(class_name="ActionPlan", uid="readout-start")
603 readout_stop = db.get_dal(class_name="ActionPlan", uid="readout-stop")
604
605 # Emulated stream
606 if type(receiver).__name__ == "FakeDataReceiver":
607 if nicrec == None:
608 try:
609 stream_emu = db.get_dal(
610 class_name="StreamEmulationParameters", uid="stream-emu"
611 )
612 stream_emu.data_file_name = resolve_asset_file(emulated_file_name)
613 db.update_dal(stream_emu)
614 except:
615 stream_emu = dal.StreamEmulationParameters(
616 "stream-emu",
617 data_file_name=resolve_asset_file(emulated_file_name),
618 input_file_size_limit=5777280,
619 set_t0=True,
620 random_population_size=100000,
621 frame_error_rate_hz=0,
622 generate_periodic_adc_pattern=True,
623 TP_rate_per_channel=1,
624 )
625 db.update_dal(stream_emu)
626
627 print("Generating fake DataReaderConf")
628 nicrec = dal.DPDKReaderConf(
629 f"nicrcvr-fake-gen",
630 template_for="FDFakeReaderModule",
631 emulation_mode=1,
632 emulation_conf=stream_emu,
633 )
634 db.update_dal(nicrec)
635 datareader = nicrec
636 elif type(receiver).__name__ == "DPDKReceiver":
637 if nicrec == None:
638 print("Generating DPDKReaderConf")
639 nicrec = dal.DPDKReaderConf(
640 f"nicrcvr-dpdk-gen", template_for="DPDKReaderModule"
641 )
642 db.update_dal(nicrec)
643 if wm_conf == None:
644 try:
645 wm_conf = db.get_dal("WIBModuleConf", "def-wib-conf")
646 except:
647 print(
648 'Expected WIBModuleConf "def-wib-conf" not found in input databases!'
649 )
650 if hermes_conf == None:
651 try:
652 hermes_conf = db.get_dal("HermesModuleConf", "def-hermes-conf")
653 except:
654 print(
655 'Expected HermesModuleConf "def-hermes-conf" not found in input databases!'
656 )
657
658 datareader = nicrec
659
660 wiec_app = dal.WIECApplication(
661 f"wiec-{connection.id}",
662 application_name="daq_application",
663 runs_on=host,
664 detector_connections=[connection],
665 wib_module_conf=wm_conf,
666 hermes_module_conf=hermes_conf,
667 exposes_service=[daqapp_control],
668 )
669 db.update_dal(wiec_app)
670
671 elif type(receiver).__name__ == "FelixInterface":
672 if flxcard == None:
673 print("Generating Felix DataReaderConf")
674 flxcard = dal.DataReaderConf(
675 f"flxConf-1", template_for="FelixReaderModule"
676 )
677 db.update_dal(flxcard)
678 datareader = flxcard
679 elif type(receiver).__name__ == "FileReaderReceiver":
680 if nicrec == None:
681 try:
682 snb_files = db.get_dal(
683 class_name="SNBFileSourceParameters", uid=f"snb-files-{connection.id}"
684 )
685 snb_files.data_files = [resolve_asset_file(emulated_file_name)]
686 db.update_dal(snb_files)
687 except:
688 snb_files = dal.SNBFileSourceParameters(
689 "snb-files-0",
690 data_files=[resolve_asset_file(emulated_file_name)],
691 input_buffer_size=5777280,
692 file_compression_algorithm="None",
693 )
694 db.update_dal(snb_files)
695
696 print("Generating fake DataReaderConf")
697 nicrec = dal.SNBFileReaderConf(
698 f"nicrcvr-file-reader",
699 template_for="SNBFileReaderModule",
700 emulation_mode=1,
701 snb_conf=snb_files,
702 )
703 db.update_dal(nicrec)
704 datareader = nicrec
705
706 print(f"Using SNB DataHandler")
707 linkhandler.template_for = "SNBDataHandlerModule"
708 db.update_dal(linkhandler)
709
710 readout_start = db.get_dal(class_name="ActionPlan", uid="snb-readout-start")
711 readout_stop = db.get_dal(class_name="ActionPlan", uid="snb-readout-stop")
712 else:
713 print(
714 f"ReadoutGroup contains unknown interface type {type(receiver).__name__}"
715 )
716 continue
717
718 db.commit()
719
720 # Services
721 dataRequests = db.get_dal(class_name="Service", uid="dataRequests")
722 timeSyncs = db.get_dal(class_name="Service", uid="timeSyncs")
723 triggerActivities = db.get_dal(class_name="Service", uid="triggerActivities")
724 triggerPrimitives = db.get_dal(class_name="Service", uid="triggerPrimitives")
725
726 ru = dal.ReadoutApplication(
727 f"ru-{connection.id}",
728 application_name="daq_application",
729 runs_on=host,
730 detector_connections=[connection],
731 network_rules=netrules,
732 queue_rules=qrules + [det_q],
733 link_handler=linkhandler,
734 data_reader=datareader,
735 fragment_aggregator=fragagg,
736 opmon_conf=opmon_conf,
737 tp_generation_enabled=tpg_enabled,
738 ta_generation_enabled=tpg_enabled,
739 uses=rohw,
740 exposes_service=[daqapp_control, dataRequests, timeSyncs],
741 action_plans=[readout_start, readout_stop],
742 )
743 if tpg_enabled:
744 ru.tp_handler = tphandler
745 tp_sources = []
746 tpbaseid = (appnum * 3) + 100
747 # 30-Apr-2025, KAB: added support for 1 "plane" of non-TPC TPs (e.g. PDS).
748 # That is compared with the usual 3 planes of TPs for TPC detectors.
749 for plane in range(1 if det_id not in [3, 10, 11] else 3):
750 s_id = tpbaseid + plane
751 tps_dal = dal.SourceIDConf(
752 f"tp-srcid-{s_id}", sid=s_id, subsystem="Trigger"
753 )
754 db.update_dal(tps_dal)
755 tp_sources.append(tps_dal)
756 ru.tp_source_ids = tp_sources
757 ru.exposes_service += [triggerActivities, triggerPrimitives]
758 appnum = appnum + 1
759 print(f"{ru=}")
760 db.update_dal(ru)
761 db.commit()
762 ruapps.append(ru)
763 if appnum == 0:
764 print(f"No ReadoutApplications generated\n")
765 return
766
767 db.commit()
768
769 if generate_segment:
770 # fsm = db.get_dal(class_name="FSMconfiguration", uid="fsmConf-test")
771 fsm = db.get_dal(class_name="FSMconfiguration", uid="FSMconfiguration_noAction")
772 controller = dal.RCApplication(
773 "ru-controller",
774 application_name="drunc-controller",
775 runs_on=host,
776 fsm=fsm,
777 opmon_conf=opmon_conf,
778 exposes_service=[rccontroller_control],
779 )
780 db.update_dal(controller)
781 db.commit()
782
783 seg = dal.Segment(f"ru-segment", controller=controller, applications=ruapps)
784 db.update_dal(seg)
785 db.commit()
786
787 db.commit()
788 return
789
790

◆ generate_session()

generate.generate_session ( oksfile,
include,
session_name,
op_env,
connectivity_service_is_infrastructure_app = True,
disable_connectivity_service = False )
Simple script to create an OKS configuration file for a session.

  The file will automatically include the relevant schema files and
any other OKS files you specify.

Definition at line 1101 of file generate.py.

1108):
1109 """Simple script to create an OKS configuration file for a session.
1110
1111 The file will automatically include the relevant schema files and
1112 any other OKS files you specify.
1113
1114 """
1115
1116 includefiles = [
1117 "schema/confmodel/dunedaq.schema.xml",
1118 "schema/appmodel/application.schema.xml",
1119 ]
1120 res, extra_includes = find_oksincludes(include, os.path.dirname(oksfile))
1121 if res:
1122 includefiles += extra_includes
1123 else:
1124 return
1125
1126 dal = conffwk.dal.module("generated", includefiles)
1127 db = conffwk.Configuration("oksconflibs")
1128 if not oksfile.endswith(".data.xml"):
1129 oksfile = oksfile + ".data.xml"
1130 print(f"Creating OKS database file {oksfile} with includes {includefiles}")
1131 db.create_db(oksfile, includefiles)
1132 db.set_active(oksfile)
1133
1134 hosts = []
1135 for vhost in db.get_dals(class_name="VirtualHost"):
1136 hosts.append(vhost.id)
1137 if vhost.id == "vlocalhost":
1138 host = vhost
1139 if "vlocalhost" not in hosts:
1140 cpus = dal.ProcessingResource("cpus", cpu_cores=[0, 1, 2, 3])
1141 db.update_dal(cpus)
1142 phdal = dal.PhysicalHost("localhost", contains=[cpus])
1143 db.update_dal(phdal)
1144 host = dal.VirtualHost("vlocalhost", runs_on=phdal, uses=[cpus])
1145 db.update_dal(host)
1146 hosts.append("vlocalhost")
1147
1148 fsm = db.get_dal(class_name="FSMconfiguration", uid="fsmConf-test")
1149 rccontroller_control = db.get_dal(class_name="Service", uid="rccontroller_control")
1150 controller = dal.RCApplication(
1151 "root-controller",
1152 application_name="drunc-controller",
1153 runs_on=host,
1154 fsm=fsm,
1155 exposes_service=[rccontroller_control],
1156 )
1157 db.update_dal(controller)
1158
1159 segments = db.get_dals(class_name="Segment")
1160
1161 seg = dal.Segment(f"root-segment", controller=controller, segments=segments)
1162 db.update_dal(seg)
1163
1164 detconf = db.get_dal(class_name="DetectorConfig", uid="dummy-detector")
1165
1166 detconf.op_env = op_env
1167 db.update_dal(detconf)
1168
1169 opmon_svc = db.get_dal(class_name="OpMonURI", uid="local-opmon-uri")
1170
1171 trace_file_var = None
1172 TRACE_FILE = os.getenv("TRACE_FILE")
1173 if TRACE_FILE is not None:
1174 trace_file_var = dal.Variable(
1175 "session-env-trace-file", name="TRACE_FILE", value=TRACE_FILE
1176 )
1177 db.update_dal(trace_file_var)
1178
1179 infrastructure_applications = []
1180 if connectivity_service_is_infrastructure_app:
1181 conn_svc = db.get_dal(
1182 class_name="ConnectionService", uid="local-connection-server"
1183 )
1184 infrastructure_applications.append(conn_svc)
1185
1186 env_vars_for_local_running = db.get_dal(
1187 class_name="VariableSet", uid="local-variables"
1188 ).contains
1189 if trace_file_var is not None:
1190 env_vars_for_local_running.append(trace_file_var)
1191
1192 sessiondal = dal.Session(
1193 session_name,
1194 environment=env_vars_for_local_running,
1195 segment=seg,
1196 detector_configuration=detconf,
1197 infrastructure_applications=infrastructure_applications,
1198 opmon_uri=opmon_svc,
1199 )
1200
1201 if not disable_connectivity_service:
1202 conn_svc_cfg = db.get_dal(
1203 class_name="ConnectivityService", uid="local-connectivity-service-config"
1204 )
1205 sessiondal.connectivity_service = conn_svc_cfg
1206
1207 db.update_dal(sessiondal)
1208
1209 db.commit()
1210 return

◆ generate_trigger()

generate.generate_trigger ( oksfile,
include,
generate_segment,
tpg_enabled = True,
hsi_enabled = False )
Simple script to create an OKS configuration file for a trigger segment.

  The file will automatically include the relevant schema files and
any other OKS files you specify.

Definition at line 927 of file generate.py.

933):
934 """Simple script to create an OKS configuration file for a trigger segment.
935
936 The file will automatically include the relevant schema files and
937 any other OKS files you specify.
938
939 """
940
941 includefiles = [
942 "schema/confmodel/dunedaq.schema.xml",
943 "schema/appmodel/application.schema.xml",
944 "schema/appmodel/trigger.schema.xml",
945 ]
946
947 res, extra_includes = find_oksincludes(include, os.path.dirname(oksfile))
948 if res:
949 includefiles += extra_includes
950 else:
951 return
952
953 dal = conffwk.dal.module("generated", includefiles)
954 db = conffwk.Configuration("oksconflibs")
955 if not oksfile.endswith(".data.xml"):
956 oksfile = oksfile + ".data.xml"
957 print(f"Creating OKS database file {oksfile}")
958 db.create_db(oksfile, includefiles)
959 db.set_active(oksfile)
960
961 hosts = []
962 for vhost in db.get_dals(class_name="VirtualHost"):
963 hosts.append(vhost.id)
964 if vhost.id == "vlocalhost":
965 host = vhost
966 if "vlocalhost" not in hosts:
967 cpus = dal.ProcessingResource("cpus", cpu_cores=[0, 1, 2, 3])
968 db.update_dal(cpus)
969 phdal = dal.PhysicalHost("localhost", contains=[cpus])
970 db.update_dal(phdal)
971 host = dal.VirtualHost("vlocalhost", runs_on=phdal, uses=[cpus])
972 db.update_dal(host)
973 hosts.append("vlocalhost")
974
975 # Services
976 daqapp_control = db.get_dal(class_name="Service", uid="daqapp_control")
977 rccontroller_control = db.get_dal(class_name="Service", uid="rccontroller_control")
978 dataRequests = db.get_dal(class_name="Service", uid="dataRequests")
979 triggerActivities = db.get_dal(class_name="Service", uid="triggerActivities")
980 triggerCandidates = db.get_dal(class_name="Service", uid="triggerCandidates")
981 triggerInhibits = db.get_dal(class_name="Service", uid="triggerInhibits")
982
983 # Source IDs
984 mlt_source_id = db.get_dal(class_name="SourceIDConf", uid="tc-srcid-1")
985 tc_source_id = db.get_dal(class_name="SourceIDConf", uid="ta-srcid-1")
986
987 # Queue Rules
988 tc_queue_rule = db.get_dal(class_name="QueueConnectionRule", uid="tc-queue-rule")
989 td_queue_rule = db.get_dal(class_name="QueueConnectionRule", uid="td-queue-rule")
990 ta_queue_rule = db.get_dal(class_name="QueueConnectionRule", uid="ta-queue-rule")
991 mlt_qrules = [tc_queue_rule, td_queue_rule]
992 tapp_qrules = [ta_queue_rule]
993
994 # Net Rules
995 tc_net_rule = db.get_dal(class_name="NetworkConnectionRule", uid="tc-net-rule")
996 ta_net_rule = db.get_dal(class_name="NetworkConnectionRule", uid="ta-net-rule")
997 ts_net_rule = db.get_dal(class_name="NetworkConnectionRule", uid="ts-net-rule")
998 ti_net_rule = db.get_dal(class_name="NetworkConnectionRule", uid="ti-net-rule")
999 td_dfo_net_rule = db.get_dal(
1000 class_name="NetworkConnectionRule", uid="td-dfo-net-rule"
1001 )
1002 data_req_trig_net_rule = db.get_dal(
1003 class_name="NetworkConnectionRule", uid="data-req-trig-net-rule"
1004 )
1005 mlt_netrules = [
1006 tc_net_rule,
1007 ti_net_rule,
1008 td_dfo_net_rule,
1009 data_req_trig_net_rule,
1010 ts_net_rule,
1011 ]
1012 tapp_netrules = [ta_net_rule, tc_net_rule, data_req_trig_net_rule]
1013
1014 opmon_conf = db.get_dal(class_name="OpMonConf", uid="slow-all-monitoring")
1015 tc_subscriber = db.get_dal(class_name="DataReaderConf", uid="tc-subscriber-1")
1016 tc_handler = db.get_dal(class_name="DataHandlerConf", uid="def-tc-handler")
1017 mlt_conf = db.get_dal(class_name="MLTConf", uid="def-mlt-conf")
1018 random_tc_generator = db.get_dal(
1019 class_name="RandomTCMakerConf", uid="random-tc-generator"
1020 )
1021 tc_confs = []
1022
1023 try:
1024 fixedtime_tc_generator = db.get_dal(
1025 class_name="FixedTimeTCMakerModuleConf",
1026 uid="ft-trig-conf",
1027 )
1028 print(f"FixedTimeTCMakerModule has been configured, disabling random triggers and HSI")
1029 tc_confs = [fixedtime_tc_generator]
1030 except:
1031 pass # No FixedTimeTCMaker
1032 if not hsi_enabled and len(tc_confs) == 0:
1033 tc_confs = [random_tc_generator]
1034
1035 mlt = dal.MLTApplication(
1036 "mlt",
1037 runs_on=host,
1038 application_name="daq_application",
1039 exposes_service=[
1040 daqapp_control,
1041 triggerCandidates,
1042 triggerInhibits,
1043 dataRequests,
1044 ],
1045 source_id=mlt_source_id,
1046 queue_rules=mlt_qrules,
1047 network_rules=mlt_netrules,
1048 opmon_conf=opmon_conf,
1049 data_subscriber=tc_subscriber,
1050 trigger_inputs_handler=tc_handler,
1051 mlt_conf=mlt_conf,
1052 standalone_candidate_maker_confs=tc_confs,
1053 )
1054 db.update_dal(mlt)
1055
1056 if tpg_enabled:
1057 ta_subscriber = db.get_dal(class_name="DataReaderConf", uid="ta-subscriber-1")
1058 ta_handler = db.get_dal(class_name="DataHandlerConf", uid="def-ta-handler")
1059
1060 # Action Plans
1061 tc_maker_start = db.get_dal(class_name="ActionPlan", uid="tc-maker-start")
1062
1063 tcmaker = dal.TriggerApplication(
1064 "tc-maker-1",
1065 runs_on=host,
1066 application_name="daq_application",
1067 exposes_service=[daqapp_control, triggerActivities, dataRequests],
1068 source_id=tc_source_id,
1069 queue_rules=tapp_qrules,
1070 network_rules=tapp_netrules,
1071 opmon_conf=opmon_conf,
1072 data_subscriber=ta_subscriber,
1073 trigger_inputs_handler=ta_handler,
1074 action_plans=[tc_maker_start],
1075 )
1076 db.update_dal(tcmaker)
1077
1078 if generate_segment:
1079 fsm = db.get_dal(class_name="FSMconfiguration", uid="FSMconfiguration_noAction")
1080 controller = dal.RCApplication(
1081 "trg-controller",
1082 application_name="drunc-controller",
1083 opmon_conf=opmon_conf,
1084 runs_on=host,
1085 fsm=fsm,
1086 exposes_service=[rccontroller_control],
1087 )
1088 db.update_dal(controller)
1089
1090 seg = dal.Segment(
1091 f"trg-segment",
1092 controller=controller,
1093 applications=[mlt] + ([tcmaker] if tpg_enabled else []),
1094 )
1095 db.update_dal(seg)
1096
1097 db.commit()
1098 return
1099
1100