LCOV - code coverage report
Current view: top level - trgdataformats/pybindsrc - trigger_activity.cpp (source / functions) Coverage Total Hit
Test: code.result Lines: 0.0 % 81 0
Test Date: 2025-12-21 13:07:08 Functions: 0.0 % 31 0

            Line data    Source code
       1              : /**
       2              :  * @file trigger_primitive.cpp Python bindings for the trigger primitive formats
       3              :  *
       4              :  * This is part of the DUNE DAQ Software Suite, copyright 2020.
       5              :  * Licensing/copyright details are in the COPYING file that you should have
       6              :  * received with this code.
       7              :  */
       8              : 
       9              : #include "trgdataformats/TriggerObjectOverlay.hpp"
      10              : 
      11              : #include <pybind11/pybind11.h>
      12              : #include <pybind11/stl.h>
      13              : #include <cstring>
      14              : 
      15              : namespace py = pybind11;
      16              : 
      17              : namespace dunedaq {
      18              : namespace trgdataformats {
      19              : namespace python {
      20              : 
      21              : /*
      22              :  Doesn't work
      23              : */
      24              : struct TriggerActivityHolder {
      25              : 
      26              : 
      27            0 :   TriggerActivityHolder(void* ptr, size_t size) {
      28            0 :     m_size = size;
      29            0 :     m_data.reset(new uint8_t[m_size]);
      30            0 :     std::memcpy(m_data.get(), ptr, size);
      31            0 :   }
      32              : 
      33            0 :   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              : 
      40              : void
      41            0 : register_trigger_activity(py::module& m)
      42              : {
      43              : 
      44              : 
      45            0 :   py::class_<TriggerActivityData> trigger_activity_data(m, "TriggerActivityData", py::buffer_protocol());
      46            0 :   trigger_activity_data
      47            0 :     .def(py::init())
      48            0 :     .def(py::init([](py::capsule capsule) {
      49            0 :         auto tp = *static_cast<TriggerActivityData*>(capsule.get_pointer());
      50            0 :         return tp;
      51              :                   } ))
      52            0 :     .def(py::init([](py::bytes bytes){
      53            0 :       py::buffer_info info(py::buffer(bytes).request());
      54            0 :       auto tp = *static_cast<TriggerActivityData*>(info.ptr);
      55            0 :       return tp;
      56            0 :     }))
      57            0 :     .def_property_readonly("version", [](TriggerActivityData& self) -> uint16_t {return self.version;})
      58            0 :     .def_property_readonly("time_start", [](TriggerActivityData& self) -> uint64_t {return self.time_start;})
      59            0 :     .def_property_readonly("time_end", [](TriggerActivityData& self) -> uint64_t {return self.time_end;})
      60            0 :     .def_property_readonly("time_peak", [](TriggerActivityData& self) -> uint64_t {return self.time_peak;})
      61            0 :     .def_property_readonly("time_activity", [](TriggerActivityData& self) -> uint64_t {return self.time_activity;})
      62            0 :     .def_property_readonly("channel_start", [](TriggerActivityData& self) -> int32_t {return self.channel_start;})
      63            0 :     .def_property_readonly("channel_end", [](TriggerActivityData& self) -> int32_t {return self.channel_end;})
      64            0 :     .def_property_readonly("channel_peak", [](TriggerActivityData& self) -> int32_t {return self.channel_peak;})
      65            0 :     .def_property_readonly("adc_integral", [](TriggerActivityData& self) -> uint32_t {return self.adc_integral;})
      66            0 :     .def_property_readonly("adc_peak", [](TriggerActivityData& self) -> uint32_t {return self.adc_peak;})
      67            0 :     .def_property_readonly("detid", [](TriggerActivityData& self) -> uint16_t {return self.detid;})
      68            0 :     .def_property_readonly("type", [](TriggerActivityData& self) -> TriggerActivityData::Type {return self.type;})
      69            0 :     .def_property_readonly("algorithm", [](TriggerActivityData& self) -> TriggerActivityData::Algorithm {return self.algorithm;})
      70            0 :     .def_static("sizeof", [](){ return sizeof(TriggerActivityData); })
      71              :     ;
      72              : 
      73              : 
      74            0 :   py::enum_<TriggerActivityData::Type>(trigger_activity_data, "Type")
      75            0 :     .value("kUnknown", TriggerActivityData::Type::kUnknown)
      76            0 :     .value("kTPC", TriggerActivityData::Type::kTPC)
      77            0 :     .value("kPDS", TriggerActivityData::Type::kPDS);
      78              : 
      79            0 :   py::enum_<TriggerActivityData::Algorithm>(trigger_activity_data, "Algorithm")
      80            0 :     .value("kUnknown", TriggerActivityData::Algorithm::kUnknown)
      81            0 :     .value("kSupernova", TriggerActivityData::Algorithm::kSupernova)
      82            0 :     .value("kPrescale", TriggerActivityData::Algorithm::kPrescale)
      83            0 :     .value("kADCSimpleWindow", TriggerActivityData::Algorithm::kADCSimpleWindow)
      84            0 :     .value("kHorizontalMuon", TriggerActivityData::Algorithm::kHorizontalMuon)
      85            0 :     .value("kMichelElectron", TriggerActivityData::Algorithm::kMichelElectron)
      86            0 :     .value("kDBSCAN", TriggerActivityData::Algorithm::kDBSCAN)
      87            0 :     .value("kPlaneCoincidence", TriggerActivityData::Algorithm::kPlaneCoincidence)
      88            0 :     .value("kBundle", TriggerActivityData::Algorithm::kBundle)
      89            0 :     .value("kChannelDistance", TriggerActivityData::Algorithm::kChannelDistance)
      90            0 :     .value("kChannelAdjacency", TriggerActivityData::Algorithm::kChannelAdjacency);
      91              : 
      92            0 :   py::class_<TriggerActivity>(m, "TriggerActivityOverlay", py::buffer_protocol())
      93            0 :       .def(py::init())
      94            0 :       .def(py::init([](py::capsule capsule) {
      95            0 :         auto tp = *static_cast<TriggerActivity*>(capsule.get_pointer());
      96            0 :         return tp;
      97              :                   } ))
      98            0 :       .def_property_readonly("data", [](TriggerActivity& self) -> TriggerActivityData& {return self.data;})
      99            0 :       .def("__len__", [](TriggerActivity& self){ return self.n_inputs; })
     100            0 :       .def("sizeof", [](TriggerActivity& self){ return sizeof(TriggerActivity)+self.n_inputs*sizeof(TriggerPrimitive); })
     101              :     ;
     102              : 
     103              : 
     104            0 :     py::class_<TriggerActivityHolder>(m, "TriggerActivity", py::buffer_protocol())
     105              :       // .def(py::init())
     106            0 :       .def(py::init([](py::capsule capsule) {
     107            0 :           auto ta_ptr = static_cast<TriggerActivity*>(capsule.get_pointer());
     108            0 :           TriggerActivityHolder tah(ta_ptr, sizeof(TriggerActivity)+ta_ptr->n_inputs*sizeof(TriggerPrimitive));
     109            0 :           return tah;
     110              :         }))
     111            0 :       .def(py::init([](py::bytes bytes){
     112            0 :           py::buffer_info info(py::buffer(bytes).request());
     113            0 :           TriggerActivityHolder tah(info.ptr, info.size);
     114              : 
     115            0 :           return tah;
     116            0 :         }))
     117              : 
     118            0 :       .def("get_bytes",
     119            0 :           [](TriggerActivityHolder& tah) -> py::bytes {
     120            0 :             return py::bytes(reinterpret_cast<char*>(tah.ptr()), tah.m_size);
     121            0 :           }, py::return_value_policy::reference_internal
     122              :       )
     123            0 :       .def_property_readonly("data", [](TriggerActivityHolder& self) -> TriggerActivityData& {return self.ptr()->data;})
     124            0 :       .def("n_inputs", [](TriggerActivityHolder& self){ return self.ptr()->n_inputs; })
     125            0 :       .def("__len__", [](TriggerActivityHolder& self){ return self.ptr()->n_inputs; })
     126            0 :       .def("__getitem__",
     127            0 :             [](TriggerActivityHolder &self, size_t i) -> const TriggerPrimitive& {
     128            0 :                 if (i >= self.ptr()->n_inputs) {
     129            0 :                     throw py::index_error();
     130              :                 }
     131            0 :                 return self.ptr()->inputs[i];
     132            0 :             }, py::return_value_policy::reference_internal)
     133            0 :       .def("sizeof", [](TriggerActivityHolder& self){ return self.m_size; })
     134              :       
     135              :       ;
     136            0 : }
     137              : 
     138              : } // namespace python
     139              : } // namespace trgdataformats
     140              : } // namespace dunedaq
        

Generated by: LCOV version 2.0-1