31#ifndef DWFRAMEWORK_DWNODES_SELFCALIBRATION_DWSELFCALIBRATIONCAMERANODE_DWSELFCALIBRATIONCAMERANODE_HPP_
32#define DWFRAMEWORK_DWNODES_SELFCALIBRATION_DWSELFCALIBRATIONCAMERANODE_DWSELFCALIBRATIONCAMERANODE_HPP_
34#include <dw/calibration/cameramodel/CameraModel.h>
41#include <dwframework/dwnodes/common/channelpackets/EgomotionState.hpp>
42#include <dwframework/dwnodes/common/channelpackets/FeatureList.hpp>
43#include <dwframework/dwnodes/common/channelpackets/SelfCalibrationTypes.hpp>
44#include <dwframework/dwnodes/common/channelpackets/SensorCommonTypes.hpp>
45#include <dwframework/dwnodes/common/channelpackets/VehicleIOValStructures.hpp>
46#include <dwframework/dwnodes/common/SelfCalibrationTypes.hpp>
86 static constexpr char8_t LOG_TAG[]{
"dwSelfCalibrationCameraNode"};
116 describePass(StringView{
"SETUP"}, DW_PROCESSOR_TYPE_CPU),
117 describePass(StringView{
"PROCESS_NONCAMERA"}, DW_PROCESSOR_TYPE_CPU),
118 describePass(StringView{
"PROCESS_CAMERA_GPU_ASYNC"}, DW_PROCESSOR_TYPE_GPU),
119 describePass(StringView{
"PROCESS_CAMERA_CPU_SYNC"}, DW_PROCESSOR_TYPE_CPU),
120 describePass(StringView{
"TEARDOWN"}, DW_PROCESSOR_TYPE_CPU));
130 return describeConstructorArguments<dwSelfCalibrationCameraNodeParam, dwContextHandle_t>(
141 "enableCalibration"_sv,
145 "cameraCalibrationMethod"_sv,
149 "cameraCalibrationSignals"_sv,
153 "rotationHistogramRangeDeg"_sv,
157 "channelFifoSize"_sv,
161 "cameraSensorStreamIndex"_sv,
165 dwContextHandle_t)));
#define DW_DESCRIBE_INDEX_PARAMETER(TYPE_NAME, args...)
#define DW_DESCRIBE_UNNAMED_PARAMETER(TYPE_NAME, args...)
#define DW_DESCRIBE_PARAMETER(TYPE_NAME, args...)
#define DW_DESCRIBE_PORT(TYPE_NAME, args...)
The interface to access parameter values identified by name and/or (semantic) type.
static constexpr char8_t LOG_TAG[]
static constexpr auto describeOutputPorts()
static constexpr auto describePasses()
dwSelfCalibrationCameraNode(dwSelfCalibrationCameraNodeParam const ¶m, dwContextHandle_t const ctx)
static constexpr auto describeInputPorts()
static std::unique_ptr< dwSelfCalibrationCameraNode > create(ParameterProvider &provider)
static constexpr auto describeParameters()
dwCameraProperties cameraProps
constexpr auto describeConstructorArgument(const Args &&... args) -> dw::core::Tuple< Args... >
dwSelfCalibrationNodeCameraParams cameraParams
float32_t rotationHistogramRangeDeg
dwCameraModelHandle_t cameraHandle
uint32_t calibrationSignals
constexpr auto describePassCollection(const Args &&... args) -> std::tuple< Args... >
constexpr auto describePortCollection(Args &&... args) -> dw::core::Tuple< Args... >
uint32_t calibrationMethod
size_t sensorIndex
TODO(lmoltrecht): AVC-2389 Consider changing to uint32_t after node split is finished,...
constexpr PassDescriptorT< 0 > describePass(dw::core::StringView const &&name, dwProcessorType processorType)
uint32_t trackerMaxHistorySize
uint32_t trackerMaxFeatureCount
dwConstRigHandle_t rigHandle
TODO(lmoltrecht): AVC-2389 Check whether there's a reason to keep two separate parameter structs.