• <xmp id="om0om">
  • <table id="om0om"><noscript id="om0om"></noscript></table>
  • Compute Graph Framework SDK Reference  5.8
    All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
    dwRadarNode.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) 2019-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 DW_FRAMEWORK_RADAR_NODE_HPP_
    32#define DW_FRAMEWORK_RADAR_NODE_HPP_
    33
    34#include <dwcgf/node/Node.hpp>
    38#include <dwcgf/port/Port.hpp>
    40#include <dwcgf/pass/Pass.hpp>
    43/* Need to include the appropriate ChannelPacketTypes.hpp since port initialization requires
    44 the parameter_trait overrides. Otherwise, it will be considered as a packet of generic type. */
    46
    47#include <dw/sensors/Sensors.h>
    48#include <dw/sensors/radar/Radar.h>
    49
    50namespace dw
    51{
    52namespace framework
    53{
    54
    59{
    60public:
    61 // TODO(dwplc): FP -- This is used when the logger is called and not just at assignment.
    62 // coverity[autosar_cpp14_a0_1_1_violation]
    63 static constexpr char8_t LOG_TAG[] = "dwRadarNode";
    64
    65 // TODO(dwplc): RFD -- This function returns auto as it is a wrapper for a template function.
    66 // coverity[autosar_cpp14_a7_1_5_violation] RFD Pending: TID-1984
    67 static constexpr auto describeInputPorts()
    68 {
    69 // TODO(dwplc): RFD -- user defined literal being interpreted as c style cast.
    70 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
    72 DW_DESCRIBE_PORT(dwCalibratedExtrinsics, "SENSOR_EXTRINSICS"_sv),
    73 DW_DESCRIBE_PORT(dwTime_t, "VIRTUAL_SYNC_TIME"_sv));
    74 };
    75
    76 // TODO(dwplc): RFD -- This function returns auto as it is a wrapper for a template function.
    77 // coverity[autosar_cpp14_a7_1_5_violation] RFD Pending: TID-1984
    78 static constexpr auto describeOutputPorts()
    79 {
    80 // TODO(dwplc): RFD -- user defined literal being interpreted as c style cast.
    81 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
    83 DW_DESCRIBE_PORT(dwSensorNodeProperties, "SENSOR_PROPERTIES"_sv),
    84 DW_DESCRIBE_PORT(dwRadarScan, "PROCESSED_DATA"_sv),
    86 DW_DESCRIBE_PORT(dwSensorTsAndID, "TIMESTAMP"_sv),
    87 DW_DESCRIBE_PORT(dwTime_t, "NEXT_TIMESTAMP"_sv));
    88 };
    89
    90 // TODO(dwplc): RFD -- This function returns auto as it is a wrapper for a template function.
    91 // coverity[autosar_cpp14_a7_1_5_violation] RFD Pending: TID-1984
    92 static constexpr auto describePasses()
    93 {
    94 // TODO(dwplc): RFD -- user defined literal being interpreted as c style cast.
    95 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
    97 describePass("SETUP"_sv, DW_PROCESSOR_TYPE_CPU),
    98 describePass("RAW_OUTPUT"_sv, DW_PROCESSOR_TYPE_CPU),
    99 describePass("PROCESSED_OUTPUT"_sv, DW_PROCESSOR_TYPE_CPU),
    100 describePass("TEARDOWN"_sv, DW_PROCESSOR_TYPE_CPU));
    101 };
    102
    103 dwSensorType getSensorType() const
    104 {
    105 return DW_SENSOR_RADAR;
    106 }
    107
    108 static std::unique_ptr<dwRadarNode> create(ParameterProvider const& provider);
    109
    110 // TODO(dwplc): RFD -- This function returns auto as it is a wrapper for a template function.
    111 // coverity[autosar_cpp14_a7_1_5_violation] RFD Pending: TID-1984
    112 static constexpr auto describeParameters()
    113 {
    114 // TODO(dwplc): RFD -- user defined literal being interpreted as c style cast.
    115 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
    116 return describeConstructorArguments<char8_t const*, dwRigHandle_t, dwSALHandle_t, dwContextHandle_t>(
    119 const char*,
    121 "sensorId"_sv)),
    124 dwRigHandle_t)),
    127 dwSALHandle_t)),
    130 dwContextHandle_t)));
    131 }
    132
    133 dwRadarNode(char8_t const* sensorName, dwConstRigHandle_t rigHandle,
    134 dwSALHandle_t sal, dwContextHandle_t ctx);
    135 dwRadarNode(dwSensorParams const& params,
    136 dwSALHandle_t sal, dwContextHandle_t ctx);
    137
    138 ~dwRadarNode() override = default;
    139 dwRadarNode(dwRadarNode const& other) = default;
    140 dwRadarNode(dwRadarNode&& other) = default;
    143};
    144} // namespace framework
    145} // namespace dw
    146#endif // DW_FRAMEWORK_RADAR_NODE_HPP_
    #define DW_DESCRIBE_INDEX_PARAMETER_WITH_SEMANTIC(TYPE_NAME, SEMANTIC_TYPE_NAME, args...)
    #define DW_DESCRIBE_UNNAMED_PARAMETER(TYPE_NAME, args...)
    #define DW_DESCRIBE_PORT(TYPE_NAME, args...)
    The interface to access parameter values identified by name and/or (semantic) type.
    dwSensorType getSensorType() const
    dwRadarNode(dwSensorParams const &params, dwSALHandle_t sal, dwContextHandle_t ctx)
    dwRadarNode(dwRadarNode const &other)=default
    dwRadarNode(char8_t const *sensorName, dwConstRigHandle_t rigHandle, dwSALHandle_t sal, dwContextHandle_t ctx)
    dwRadarNode & operator=(dwRadarNode const &)=default
    dwRadarNode(dwRadarNode &&other)=default
    ~dwRadarNode() override=default
    static constexpr auto describePasses()
    Definition: dwRadarNode.hpp:92
    static std::unique_ptr< dwRadarNode > create(ParameterProvider const &provider)
    static constexpr auto describeOutputPorts()
    Definition: dwRadarNode.hpp:78
    static constexpr auto describeInputPorts()
    Definition: dwRadarNode.hpp:67
    dwRadarNode & operator=(dwRadarNode &&)=default
    static constexpr auto describeParameters()
    static constexpr char8_t LOG_TAG[]
    Definition: dwRadarNode.hpp:63
    constexpr auto describePortCollection(Args &&... args)
    constexpr std::tuple< dw::core::StringView, dwProcessorType > describePass(dw::core::StringView const &&name, dwProcessorType processorType)
    CalibratedExtrinsics { CalibrationExtrinsicProfileName extrinsicProfileName dwCalibratedExtrinsics
    dwSensorNodeProperties { uint64_t sensorId dwSensorNodeProperties
    constexpr auto describeConstructorArgument(const Args &&... args)
    dwRigHandle_t rigHandle
    Definition: dwRigNode.hpp:63
    constexpr auto describePassCollection(const Args &&... args)
    Definition: Exception.hpp:47
    人人超碰97caoporen国产