Compute Graph Framework SDK Reference  5.12
dwRadarDopplerMotionNode.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) 2020-2023 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_DWRADARDOPPLERMOTIONNODE_DWRADARDOPPLERMOTIONNODE_HPP_
32#define DWFRAMEWORK_DWNODES_DWRADARDOPPLERMOTIONNODE_DWRADARDOPPLERMOTIONNODE_HPP_
33
34#include <dwcgf/node/Node.hpp>
38#include <dwcgf/port/Port.hpp>
40#include <dwframework/dwnodes/common/channelpackets/DopplerMotionEstimator.hpp>
41#include <dwframework/dwnodes/common/channelpackets/Radar.hpp>
42
43namespace dw
44{
45namespace framework
46{
47
49{
50 bool enable;
51 cudaStream_t cudaStream;
52};
53
58{
59public:
60 // TODO(csketch): FP -- This is used when the logger is called and not just at assignment.
61 // coverity[autosar_cpp14_a0_1_1_violation] FP: nvbugs/2980283
62 // coverity[autosar_cpp14_m0_1_4_violation] FP: nvbugs/2980283
63 static constexpr char8_t LOG_TAG[]{"dwRadarDopplerMotionNode"};
64
65 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-1984
66 static constexpr auto describeInputPorts()
67 {
68 // TODO(csketch): RFD -- user defined literal being interpreted as c style cast.
69 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
71 DW_DESCRIBE_PORT(dwRadarScan, "RADAR_SCAN"_sv, PortBinding::REQUIRED));
72 };
73 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-1984
74 static constexpr auto describeOutputPorts()
75 {
76 // TODO(csketch): RFD -- user defined literal being interpreted as c style cast.
77 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
79 DW_DESCRIBE_PORT(dwRadarDopplerMotion, "RADAR_DOPPLER_MOTION"_sv, PortBinding::REQUIRED));
80 };
81
82 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-1984
83 static constexpr auto describePasses()
84 {
86 describePass(StringView{"SETUP"}, DW_PROCESSOR_TYPE_CPU),
87 describePass(StringView{"PROCESS_RADAR_GPU_ASYNC"}, DW_PROCESSOR_TYPE_GPU),
88 describePass(StringView{"PROCESS_RADAR_CPU_SYNC"}, DW_PROCESSOR_TYPE_CPU),
89 describePass(StringView{"TEARDOWN"}, DW_PROCESSOR_TYPE_CPU));
90 };
91
92 static std::unique_ptr<dwRadarDopplerMotionNode> create(ParameterProvider& provider);
93
94 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-1984
95 static constexpr auto describeParameters()
96 {
97 // TODO(csketch): RFD -- user defined literal being interpreted as c style cast.
98 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
99 return describeConstructorArguments<dwRadarDopplerMotionNodeParams, dwContextHandle_t>(
102 size_t,
103 "index"_sv),
105 bool,
106 "enabled"_sv,
107 9),
109 int64_t,
110 "radarDopplerMotionCudaStreamIndices"_sv,
111 9)),
114 dwContextHandle_t)));
115 }
116
117 dwRadarDopplerMotionNode(const dwRadarDopplerMotionNodeParams& param, const dwContextHandle_t ctx);
118};
119} // namespace framework
120} // namespace dw
121
122#endif // DWFRAMEWORK_DWNODES_DWRADARDOPPLERMOTIONNODE_DWRADARDOPPLERMOTIONNODE_HPP_
#define DW_DESCRIBE_ABSTRACT_ARRAY_PARAMETER(TYPE_NAME, PARAM_NAME, ARRAY_SIZE, args...)
#define DW_DESCRIBE_UNNAMED_PARAMETER(TYPE_NAME, args...)
#define DW_DESCRIBE_ABSTRACT_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 std::unique_ptr< dwRadarDopplerMotionNode > create(ParameterProvider &provider)
dwRadarDopplerMotionNode(const dwRadarDopplerMotionNodeParams &param, const dwContextHandle_t ctx)
constexpr auto describeConstructorArgument(const Args &&... args) -> dw::core::Tuple< Args... >
constexpr std::tuple< dw::core::StringView, dwProcessorType > describePass(dw::core::StringView const &&name, dwProcessorType processorType)
constexpr auto describePassCollection(const Args &&... args) -> std::tuple< Args... >
constexpr auto describePortCollection(Args &&... args) -> dw::core::Tuple< Args... >
Definition: Buffer.hpp:40