2022-07-20 14:58:48 +02:00
|
|
|
#include "lasp_daq.h"
|
|
|
|
#include <pybind11/numpy.h>
|
|
|
|
#include <pybind11/stl.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
using std::cerr;
|
|
|
|
namespace py = pybind11;
|
|
|
|
|
|
|
|
void init_daq(py::module &m) {
|
|
|
|
|
|
|
|
/// Daq
|
|
|
|
py::class_<Daq, DaqConfiguration, DeviceInfo> daq(m, "Daq");
|
2022-07-29 09:32:26 +02:00
|
|
|
|
|
|
|
/// Daq::StreamStatus
|
2022-09-27 17:20:45 +02:00
|
|
|
py::class_<Daq::StreamStatus> ss(daq, "StreamStatus");
|
2022-07-20 14:58:48 +02:00
|
|
|
ss.def("error", &Daq::StreamStatus::error);
|
|
|
|
ss.def("runningOK", &Daq::StreamStatus::runningOK);
|
|
|
|
ss.def_readonly("isRunning", &Daq::StreamStatus::isRunning);
|
|
|
|
|
2022-07-29 09:32:26 +02:00
|
|
|
/// Daq::StreamStatus::StreamError
|
2022-07-20 14:58:48 +02:00
|
|
|
py::enum_<Daq::StreamStatus::StreamError>(ss, "StreamError")
|
|
|
|
.value("noError", Daq::StreamStatus::StreamError::noError)
|
|
|
|
.value("inputXRun", Daq::StreamStatus::StreamError::inputXRun)
|
|
|
|
.value("outputXRun", Daq::StreamStatus::StreamError::outputXRun)
|
|
|
|
.value("driverError", Daq::StreamStatus::StreamError::driverError)
|
|
|
|
.value("systemError", Daq::StreamStatus::StreamError::systemError)
|
|
|
|
.value("threadError", Daq::StreamStatus::StreamError::threadError)
|
2023-01-04 14:21:39 +01:00
|
|
|
.value("logicError", Daq::StreamStatus::StreamError::logicError);
|
2022-07-20 14:58:48 +02:00
|
|
|
|
2022-09-27 17:20:45 +02:00
|
|
|
ss.def("errorMsg", &Daq::StreamStatus::errorMsg);
|
|
|
|
|
2022-07-29 09:32:26 +02:00
|
|
|
/// Daq
|
2023-01-04 14:21:39 +01:00
|
|
|
daq.def("neninchannels", &Daq::neninchannels,
|
|
|
|
py::arg("include_monitor") = true);
|
|
|
|
|
2022-07-20 14:58:48 +02:00
|
|
|
daq.def("nenoutchannels", &Daq::nenoutchannels);
|
|
|
|
daq.def("samplerate", &Daq::samplerate);
|
|
|
|
daq.def("dataType", &Daq::dataType);
|
|
|
|
daq.def("framesPerBlock", &Daq::framesPerBlock);
|
|
|
|
daq.def("getStreamStatus", &Daq::getStreamStatus);
|
|
|
|
}
|