Compute Graph Framework SDK Reference  5.10
dwVehicleStateChannelNode.hpp
Go to the documentation of this file.
1
2//
3// Notice
4// ALL NVIDIA DESIGN SPECIFICATIONS AND CODE ("MATERIALS") ARE PROVIDED "AS IS" NVIDIA MAKES
5// NO REPRESENTATIONS, WARRANTIES, EXPRESSED, IMPLIED, STATUTORY, OR OTHERWISE WITH RESPECT TO
6// THE MATERIALS, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES OF NONINFRINGEMENT,
7// MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
8//
9// NVIDIA CORPORATION & AFFILIATES assumes no responsibility for the consequences of use of such
10// information or for any infringement of patents or other rights of third parties that may
11// result from its use. No license is granted by implication or otherwise under any patent
12// or patent rights of NVIDIA CORPORATION & AFFILIATES. No third party distribution is allowed unless
13// expressly authorized by NVIDIA. Details are subject to change without notice.
14// This code supersedes and replaces all information previously supplied.
15// NVIDIA CORPORATION & AFFILIATES products are not authorized for use as critical
16// components in life support devices or systems without express written approval of
17// NVIDIA CORPORATION & AFFILIATES.
18//
19// SPDX-FileCopyrightText: Copyright (c) 2022 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
20// SPDX-License-Identifier: LicenseRef-NvidiaProprietary
21//
22// NVIDIA CORPORATION, its affiliates and licensors retain all intellectual
23// property and proprietary rights in and to this material, related
24// documentation and any modifications thereto. Any use, reproduction,
25// disclosure or distribution of this material and related documentation
26// without an express license agreement from NVIDIA CORPORATION or
27// its affiliates is strictly prohibited.
28//
30
31#ifndef DWFRAMEWORK_DWNODES_SENSORS_DWVEHICLESTATENODE_DWVEHICLESTATECHANNELNODE_HPP_
32#define DWFRAMEWORK_DWNODES_SENSORS_DWVEHICLESTATENODE_DWVEHICLESTATECHANNELNODE_HPP_
33
34#include <dw/sensors/Sensors.h>
35#include <dw/sensors/canbus/CAN.h>
36#include <dw/sensors/data/Data.h>
37#include <dwcgf/node/Node.hpp>
41#include <dwcgf/pass/Pass.hpp>
43#include <dwcgf/port/Port.hpp>
51
52namespace dw
53{
54namespace framework
55{
56
58{
59public:
60 static constexpr char LOG_TAG[] = "dwVehicleStateChannelNode";
61
62 static constexpr auto describeInputPorts()
63 {
65 DW_DESCRIBE_PORT(dwVehicleIOCommand, "VEHICLE_IO_COMMAND"_sv),
66 DW_DESCRIBE_PORT(dwVehicleIOMiscCommand, "VEHICLE_IO_MISC_COMMAND"_sv),
67 DW_DESCRIBE_PORT(dwTime_t, "VIRTUAL_SYNC_TIME"_sv),
68 DW_DESCRIBE_PORT(dwVehicleIOSafetyState, "VEHICLE_IO_SAFETY_STATE"_sv),
69 DW_DESCRIBE_PORT(dwVehicleIONonSafetyState, "VEHICLE_IO_NON_SAFETY_STATE"_sv),
70 DW_DESCRIBE_PORT(dwVehicleIOActuationFeedback, "VEHICLE_IO_ACTUATION_FEEDBACK"_sv),
71 DW_DESCRIBE_PORT(dwVehicleIOState, "INPUT_FRAME"_sv));
72 };
73 static constexpr auto describeOutputPorts()
74 {
76 DW_DESCRIBE_PORT(dwSensorNodeProperties, "SENSOR_PROPERTIES"_sv),
77 DW_DESCRIBE_PORT(dwVehicleIOState, "PROCESSED_DATA"_sv, PortBinding::REQUIRED),
78 DW_DESCRIBE_PORT(dwSensorTsAndID, "TIMESTAMP"_sv),
79 DW_DESCRIBE_PORT(dwTime_t, "NEXT_TIMESTAMP"_sv),
80 DW_DESCRIBE_PORT(dwVehicleIOSafetyState, "VEHICLE_IO_SAFETY_STATE"_sv),
81 DW_DESCRIBE_PORT(dwVehicleIONonSafetyState, "VEHICLE_IO_NON_SAFETY_STATE"_sv),
82 DW_DESCRIBE_PORT(dwVehicleIOActuationFeedback, "VEHICLE_IO_ACTUATION_FEEDBACK"_sv),
83 DW_DESCRIBE_PORT(dwVehicleIOMiscCommand, "VEHICLE_IO_MISC_COMMAND_OUTPUT"_sv),
84 DW_DESCRIBE_PORT(dwVehicleIOCommand, "VEHICLE_IO_COMMAND_OUTPUT"_sv));
85 };
86
87 static constexpr auto describePasses()
88 {
90 describePass("SETUP"_sv, DW_PROCESSOR_TYPE_CPU),
91 describePass("PROCESSED_OUTPUT"_sv, DW_PROCESSOR_TYPE_CPU),
92 describePass("TEARDOWN"_sv, DW_PROCESSOR_TYPE_CPU));
93 };
94
95 dwSensorType getSensorType() const
96 {
97 return DW_SENSOR_CAN;
98 }
99
100 static std::unique_ptr<dwVehicleStateChannelNode> create(ParameterProvider& provider);
101
102 static constexpr auto describeParameters()
103 {
104 return describeConstructorArguments<VehicleStateNodeParams, const char*, dwRigHandle_t, dwSALHandle_t, dwContextHandle_t>(
110 DW_DESCRIBE_PARAMETER(dw::core::FixedString<32>, "frameSkipMask"_sv, &VehicleStateNodeParams::frameSkipMask)),
113 const char*,
117 dwRigHandle_t)),
120 dwSALHandle_t)),
123 dwContextHandle_t)));
124 }
125
126 dwVehicleStateChannelNode(const char* sensorName, dwConstRigHandle_t rigHandle,
127 dwSALHandle_t sal, dwContextHandle_t ctx, const FixedString<32>& frameSkipMask);
128 dwVehicleStateChannelNode(VehicleStateNodeParams const& params, const char* sensorName, dwConstRigHandle_t rigHandle,
129 dwSALHandle_t sal, dwContextHandle_t ctx);
130 dwVehicleStateChannelNode(const dwSensorParams& params,
131 dwSALHandle_t sal, dwContextHandle_t ctx);
132};
133}
134}
135#endif // DWFRAMEWORK_DWNODES_SENSORS_DWVEHICLESTATENODE_DWVEHICLESTATECHANNELNODE_HPP_
#define DW_DESCRIBE_UNNAMED_PARAMETER_WITH_SEMANTIC(TYPE_NAME, SEMANTIC_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.
dwVehicleStateChannelNode(VehicleStateNodeParams const &params, const char *sensorName, dwConstRigHandle_t rigHandle, dwSALHandle_t sal, dwContextHandle_t ctx)
dwVehicleStateChannelNode(const dwSensorParams &params, dwSALHandle_t sal, dwContextHandle_t ctx)
dwVehicleStateChannelNode(const char *sensorName, dwConstRigHandle_t rigHandle, dwSALHandle_t sal, dwContextHandle_t ctx, const FixedString< 32 > &frameSkipMask)
static std::unique_ptr< dwVehicleStateChannelNode > create(ParameterProvider &provider)
constexpr auto describePortCollection(Args &&... args)
constexpr std::tuple< dw::core::StringView, dwProcessorType > describePass(dw::core::StringView const &&name, dwProcessorType processorType)
constexpr auto describeConstructorArgument(const Args &&... args)
dwRigHandle_t rigHandle
Definition: dwRigNode.hpp:56
constexpr auto describePassCollection(const Args &&... args)
Definition: Buffer.hpp:40