LCOV - code coverage report
Current view: top level - trgdataformats/pybindsrc - trigger_candidate.cpp (source / functions) Coverage Total Hit
Test: code.result Lines: 0.0 % 114 0
Test Date: 2025-12-21 13:07:08 Functions: 0.0 % 25 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 TriggerCandidateHolder {
      25              : 
      26              : 
      27            0 :   TriggerCandidateHolder(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 :   TriggerCandidate* ptr() { return reinterpret_cast<TriggerCandidate*>(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_candidate(py::module& m)
      42              : {
      43              : 
      44            0 :   m.def("string_to_trigger_candidate_type", &trgdataformats::string_to_trigger_candidate_type);
      45            0 :   m.def("trigger_candidate_type_to_string", &trgdataformats::trigger_candidate_type_to_string);
      46              : 
      47            0 :   py::class_<TriggerCandidateData> trigger_candidate_data(m, "TriggerCandidateData", py::buffer_protocol());
      48            0 :   trigger_candidate_data
      49            0 :     .def(py::init())
      50            0 :     .def(py::init([](py::capsule capsule) {
      51            0 :         auto tp = *static_cast<TriggerCandidateData*>(capsule.get_pointer());
      52            0 :         return tp;
      53              :                   } ))
      54            0 :     .def(py::init([](py::bytes bytes){
      55            0 :       py::buffer_info info(py::buffer(bytes).request());
      56            0 :       auto tp = *static_cast<TriggerCandidateData*>(info.ptr);
      57            0 :       return tp;
      58            0 :     }))
      59            0 :     .def_property_readonly("version", [](TriggerCandidateData& self) -> uint16_t {return self.version;})
      60            0 :     .def_property_readonly("time_start", [](TriggerCandidateData& self) -> uint64_t {return self.time_start;})
      61            0 :     .def_property_readonly("time_end", [](TriggerCandidateData& self) -> uint64_t {return self.time_end;})
      62            0 :     .def_property_readonly("time_candidate", [](TriggerCandidateData& self) -> uint64_t {return self.time_candidate;})
      63            0 :     .def_property_readonly("detid", [](TriggerCandidateData& self) -> uint16_t {return self.detid;})
      64            0 :     .def_property_readonly("type", [](TriggerCandidateData& self) -> TriggerCandidateData::Type {return self.type;})
      65            0 :     .def_property_readonly("algorithm", [](TriggerCandidateData& self) -> TriggerCandidateData::Algorithm {return self.algorithm;})
      66            0 :     .def_static("sizeof", [](){ return sizeof(TriggerCandidateData); })
      67              :     ;
      68              : 
      69            0 :   py::enum_<TriggerCandidateData::Type>(trigger_candidate_data, "Type")
      70            0 :     .value("kUnknown", TriggerCandidateData::Type::kUnknown)
      71            0 :     .value("kTiming", TriggerCandidateData::Type::kTiming)
      72            0 :     .value("kTPCLowE", TriggerCandidateData::Type::kTPCLowE)
      73            0 :     .value("kSupernova", TriggerCandidateData::Type::kSupernova)
      74            0 :     .value("kRandom", TriggerCandidateData::Type::kRandom)
      75            0 :     .value("kPrescale", TriggerCandidateData::Type::kPrescale)
      76            0 :     .value("kADCSimpleWindow", TriggerCandidateData::Type::kADCSimpleWindow)
      77            0 :     .value("kHorizontalMuon", TriggerCandidateData::Type::kHorizontalMuon)
      78            0 :     .value("kMichelElectron", TriggerCandidateData::Type::kMichelElectron)
      79            0 :     .value("kPlaneCoincidence", TriggerCandidateData::Type::kPlaneCoincidence)
      80            0 :     .value("kBundle", TriggerCandidateData::Type::kBundle)
      81            0 :     .value("kChannelDistance", TriggerCandidateData::Type::kChannelDistance)
      82            0 :     .value("kDBSCAN", TriggerCandidateData::Type::kDBSCAN)
      83            0 :     .value("kCTBFakeTrigger", TriggerCandidateData::Type::kCTBFakeTrigger)
      84            0 :     .value("kCTBBeam", TriggerCandidateData::Type::kCTBBeam)
      85            0 :     .value("kCTBBeamChkvHL", TriggerCandidateData::Type::kCTBBeamChkvHL)
      86            0 :     .value("kCTBCustomD", TriggerCandidateData::Type::kCTBCustomD)
      87            0 :     .value("kCTBCustomE", TriggerCandidateData::Type::kCTBCustomE)
      88            0 :     .value("kCTBCustomF", TriggerCandidateData::Type::kCTBCustomF)
      89            0 :     .value("kCTBCustomG", TriggerCandidateData::Type::kCTBCustomG)
      90            0 :     .value("kCTBBeamChkvHLx", TriggerCandidateData::Type::kCTBBeamChkvHLx)
      91            0 :     .value("kCTBBeamChkvHxL", TriggerCandidateData::Type::kCTBBeamChkvHxL)
      92            0 :     .value("kCTBBeamChkvHxLx", TriggerCandidateData::Type::kCTBBeamChkvHxLx)
      93            0 :     .value("kNeutronSourceCalib", TriggerCandidateData::Type::kNeutronSourceCalib)
      94            0 :     .value("kChannelAdjacency", TriggerCandidateData::Type::kChannelAdjacency)
      95            0 :     .value("kCIBFakeTrigger", TriggerCandidateData::Type::kCIBFakeTrigger)
      96            0 :     .value("kCIBLaserTriggerP1", TriggerCandidateData::Type::kCIBLaserTriggerP1)
      97            0 :     .value("kCIBLaserTriggerP2", TriggerCandidateData::Type::kCIBLaserTriggerP2)
      98            0 :     .value("kCIBLaserTriggerP3", TriggerCandidateData::Type::kCIBLaserTriggerP3)
      99            0 :     .value("kCTBOffSpillSnapshot", TriggerCandidateData::Type::kCTBOffSpillSnapshot)
     100            0 :     .value("kCTBOffSpillCosmicJura", TriggerCandidateData::Type::kCTBOffSpillCosmicJura)
     101            0 :     .value("kCTBOffSpillCRTCosmic", TriggerCandidateData::Type::kCTBOffSpillCRTCosmic)
     102            0 :     .value("kCTBBeamSpillStart", TriggerCandidateData::Type::kCTBBeamSpillStart)
     103            0 :     .value("kCTBBeamSpillSnapshot", TriggerCandidateData::Type::kCTBBeamSpillSnapshot)
     104            0 :     .value("kCTBCustomC", TriggerCandidateData::Type::kCTBCustomC)
     105            0 :     .value("kCTBCustomPulseTrain", TriggerCandidateData::Type::kCTBCustomPulseTrain)
     106            0 :     .value("kDTSPulser", TriggerCandidateData::Type::kDTSPulser)
     107            0 :     .value("kDTSCosmic", TriggerCandidateData::Type::kDTSCosmic)
     108            0 :     .value("kSSPLEDCalibration", TriggerCandidateData::Type::kSSPLEDCalibration);
     109              : 
     110            0 :   py::enum_<TriggerCandidateData::Algorithm>(trigger_candidate_data, "Algorithm")
     111            0 :     .value("kUnknown", TriggerCandidateData::Algorithm::kUnknown)
     112            0 :     .value("kSupernova", TriggerCandidateData::Algorithm::kSupernova)
     113            0 :     .value("kHSIEventToTriggerCandidate", TriggerCandidateData::Algorithm::kHSIEventToTriggerCandidate)
     114            0 :     .value("kPrescale", TriggerCandidateData::Algorithm::kPrescale)
     115            0 :     .value("kADCSimpleWindow", TriggerCandidateData::Algorithm::kADCSimpleWindow)
     116            0 :     .value("kHorizontalMuon", TriggerCandidateData::Algorithm::kHorizontalMuon)
     117            0 :     .value("kMichelElectron", TriggerCandidateData::Algorithm::kMichelElectron)
     118            0 :     .value("kPlaneCoincidence", TriggerCandidateData::Algorithm::kPlaneCoincidence)
     119            0 :     .value("kCustom", TriggerCandidateData::Algorithm::kCustom)
     120            0 :     .value("kDBSCAN", TriggerCandidateData::Algorithm::kDBSCAN)
     121            0 :     .value("kChannelDistance", TriggerCandidateData::Algorithm::kChannelDistance)
     122            0 :     .value("kBundle", TriggerCandidateData::Algorithm::kBundle)
     123            0 :     .value("kChannelAdjacency", TriggerCandidateData::Algorithm::kChannelAdjacency);
     124              : 
     125            0 :   py::class_<TriggerCandidate>(m, "TriggerCandidateOverlay", py::buffer_protocol())
     126            0 :       .def(py::init([](py::capsule capsule) {
     127            0 :         auto tp = *static_cast<TriggerCandidate*>(capsule.get_pointer());
     128            0 :         return tp;
     129              :                   } ))
     130            0 :       .def_property_readonly("data", [](TriggerCandidate& self) -> TriggerCandidateData& {return self.data;})
     131            0 :       .def("__len__", [](TriggerCandidate& self){ return self.n_inputs; })
     132            0 :       .def("sizeof", [](TriggerCandidate& self){ return sizeof(TriggerCandidate)+self.n_inputs*sizeof(TriggerActivityData); })
     133              :     ;
     134              : 
     135              : 
     136            0 :     py::class_<TriggerCandidateHolder>(m, "TriggerCandidate", py::buffer_protocol())
     137            0 :       .def(py::init([](py::capsule capsule) {
     138            0 :            auto tc_ptr = static_cast<TriggerCandidate*>(capsule.get_pointer());
     139            0 :            TriggerCandidateHolder tch(tc_ptr, sizeof(TriggerCandidate)+tc_ptr->n_inputs*sizeof(TriggerActivityData));
     140            0 :            return tch;
     141              :         }))
     142            0 :       .def(py::init([](py::bytes bytes){
     143            0 :           py::buffer_info info(py::buffer(bytes).request());
     144              : 
     145            0 :           TriggerCandidateHolder tch(info.ptr, info.size);
     146              : 
     147            0 :           return tch;
     148            0 :         }))
     149              : 
     150            0 :       .def("get_bytes",
     151            0 :           [](TriggerCandidateHolder& tch) -> py::bytes {
     152            0 :             return py::bytes(reinterpret_cast<char*>(tch.ptr()), tch.m_size);
     153            0 :           }, py::return_value_policy::reference_internal
     154              :       )
     155            0 :       .def_property_readonly("data", [](TriggerCandidateHolder& self) -> TriggerCandidateData& {return self.ptr()->data;})
     156            0 :       .def("n_inputs", [](TriggerCandidateHolder& self){ return self.ptr()->n_inputs; })
     157            0 :       .def("__len__", [](TriggerCandidateHolder& self){ return self.ptr()->n_inputs; })
     158            0 :       .def("__getitem__",
     159            0 :             [](TriggerCandidateHolder &self, size_t i) -> const TriggerActivityData& {
     160            0 :                 if (i >= self.ptr()->n_inputs) {
     161            0 :                     throw py::index_error();
     162              :                 }
     163            0 :                 return self.ptr()->inputs[i];
     164            0 :             }, py::return_value_policy::reference_internal)
     165            0 :       .def("sizeof", [](TriggerCandidateHolder& self){ return self.m_size; })
     166              :       ;
     167            0 : }
     168              : 
     169              : } // namespace python
     170              : } // namespace trgdataformats
     171              : } // namespace dunedaq
        

Generated by: LCOV version 2.0-1