DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
trigger_activity.cpp
Go to the documentation of this file.
1
10
11#include <pybind11/pybind11.h>
12#include <pybind11/stl.h>
13#include <cstring>
14
15namespace py = pybind11;
16
17namespace dunedaq {
18namespace trgdataformats {
19namespace python {
20
21/*
22 Doesn't work
23*/
25
26
28 m_size = size;
29 m_data.reset(new uint8_t[m_size]);
30 std::memcpy(m_data.get(), ptr, size);
31 }
32
33 TriggerActivity* ptr() { return reinterpret_cast<TriggerActivity*>(m_data.get()); }
34
35 size_t m_size;
36 std::unique_ptr<uint8_t[]> m_data;
37
38};
39
40void
42{
43
44
45 py::class_<TriggerActivityData> trigger_activity_data(m, "TriggerActivityData", py::buffer_protocol());
46 trigger_activity_data
47 .def(py::init())
48 .def(py::init([](py::capsule capsule) {
49 auto tp = *static_cast<TriggerActivityData*>(capsule.get_pointer());
50 return tp;
51 } ))
52 .def(py::init([](py::bytes bytes){
53 py::buffer_info info(py::buffer(bytes).request());
54 auto tp = *static_cast<TriggerActivityData*>(info.ptr);
55 return tp;
56 }))
57 .def_property_readonly("version", [](TriggerActivityData& self) -> uint16_t {return self.version;})
58 .def_property_readonly("time_start", [](TriggerActivityData& self) -> uint64_t {return self.time_start;})
59 .def_property_readonly("time_end", [](TriggerActivityData& self) -> uint64_t {return self.time_end;})
60 .def_property_readonly("time_peak", [](TriggerActivityData& self) -> uint64_t {return self.time_peak;})
61 .def_property_readonly("time_activity", [](TriggerActivityData& self) -> uint64_t {return self.time_activity;})
62 .def_property_readonly("channel_start", [](TriggerActivityData& self) -> int32_t {return self.channel_start;})
63 .def_property_readonly("channel_end", [](TriggerActivityData& self) -> int32_t {return self.channel_end;})
64 .def_property_readonly("channel_peak", [](TriggerActivityData& self) -> int32_t {return self.channel_peak;})
65 .def_property_readonly("adc_integral", [](TriggerActivityData& self) -> uint32_t {return self.adc_integral;})
66 .def_property_readonly("adc_peak", [](TriggerActivityData& self) -> uint32_t {return self.adc_peak;})
67 .def_property_readonly("detid", [](TriggerActivityData& self) -> uint16_t {return self.detid;})
68 .def_property_readonly("type", [](TriggerActivityData& self) -> TriggerActivityData::Type {return self.type;})
69 .def_property_readonly("algorithm", [](TriggerActivityData& self) -> TriggerActivityData::Algorithm {return self.algorithm;})
70 .def_static("sizeof", [](){ return sizeof(TriggerActivityData); })
71 ;
72
73
74 py::enum_<TriggerActivityData::Type>(trigger_activity_data, "Type")
75 .value("kUnknown", TriggerActivityData::Type::kUnknown)
77 .value("kPDS", TriggerActivityData::Type::kPDS);
78
79 py::enum_<TriggerActivityData::Algorithm>(trigger_activity_data, "Algorithm")
83 .value("kADCSimpleWindow", TriggerActivityData::Algorithm::kADCSimpleWindow)
87 .value("kPlaneCoincidence", TriggerActivityData::Algorithm::kPlaneCoincidence)
89 .value("kChannelDistance", TriggerActivityData::Algorithm::kChannelDistance)
90 .value("kChannelAdjacency", TriggerActivityData::Algorithm::kChannelAdjacency);
91
92 py::class_<TriggerActivity>(m, "TriggerActivityOverlay", py::buffer_protocol())
93 .def(py::init())
94 .def(py::init([](py::capsule capsule) {
95 auto tp = *static_cast<TriggerActivity*>(capsule.get_pointer());
96 return tp;
97 } ))
98 .def_property_readonly("data", [](TriggerActivity& self) -> TriggerActivityData& {return self.data;})
99 .def("__len__", [](TriggerActivity& self){ return self.n_inputs; })
100 .def("sizeof", [](TriggerActivity& self){ return sizeof(TriggerActivity)+self.n_inputs*sizeof(TriggerPrimitive); })
101 ;
102
103
104 py::class_<TriggerActivityHolder>(m, "TriggerActivity", py::buffer_protocol())
105 // .def(py::init())
106 .def(py::init([](py::capsule capsule) {
107 auto ta_ptr = static_cast<TriggerActivity*>(capsule.get_pointer());
108 TriggerActivityHolder tah(ta_ptr, sizeof(TriggerActivity)+ta_ptr->n_inputs*sizeof(TriggerPrimitive));
109 return tah;
110 }))
111 .def(py::init([](py::bytes bytes){
112 py::buffer_info info(py::buffer(bytes).request());
113 TriggerActivityHolder tah(info.ptr, info.size);
114
115 return tah;
116 }))
117
118 .def("get_bytes",
119 [](TriggerActivityHolder& tah) -> py::bytes {
120 return py::bytes(reinterpret_cast<char*>(tah.ptr()), tah.m_size);
121 }, py::return_value_policy::reference_internal
122 )
123 .def_property_readonly("data", [](TriggerActivityHolder& self) -> TriggerActivityData& {return self.ptr()->data;})
124 .def("n_inputs", [](TriggerActivityHolder& self){ return self.ptr()->n_inputs; })
125 .def("__len__", [](TriggerActivityHolder& self){ return self.ptr()->n_inputs; })
126 .def("__getitem__",
127 [](TriggerActivityHolder &self, size_t i) -> const TriggerPrimitive& {
128 if (i >= self.ptr()->n_inputs) {
129 throw py::index_error();
130 }
131 return self.ptr()->inputs[i];
132 }, py::return_value_policy::reference_internal)
133 .def("sizeof", [](TriggerActivityHolder& self){ return self.m_size; })
134
135 ;
136}
137
138} // namespace python
139} // namespace trgdataformats
140} // namespace dunedaq
void register_trigger_activity(pybind11::module &)
TriggerObjectOverlay< TriggerActivityData, TriggerPrimitive > TriggerActivity
Including Qt Headers.
FELIX Initialization std::string initerror FELIX queue timed std::string queuename Unexpected chunk size
A single energy deposition on a TPC or PDS channel.