• <xmp id="om0om">
  • <table id="om0om"><noscript id="om0om"></noscript></table>
  • Compute Graph Framework SDK Reference  5.22
    All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
    dwSelfCalibrationCameraBasedIMUNode.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-2024 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_SELFCALIBRATION_DWSELFCALIBRATIONCAMERAIMUNODE_DWSELFCALIBRATIONCAMERAIMUNODE_HPP_
    32#define DWFRAMEWORK_DWNODES_SELFCALIBRATION_DWSELFCALIBRATIONCAMERAIMUNODE_DWSELFCALIBRATIONCAMERAIMUNODE_HPP_
    33
    34#include <dw/calibration/cameramodel/CameraModel.h>
    36#include <dwcgf/node/Node.hpp>
    39#include <dwcgf/port/Port.hpp>
    41#include <dwframework/dwnodes/common/channelpackets/EgomotionState.hpp>
    42#include <dwframework/dwnodes/common/channelpackets/FeatureList.hpp>
    43#include <dwframework/dwnodes/common/channelpackets/IMU.hpp>
    44#include <dwframework/dwnodes/common/channelpackets/SelfCalibrationTypes.hpp>
    45#include <dwframework/dwnodes/common/channelpackets/SensorCommonTypes.hpp>
    46#include <dwframework/dwnodes/common/channelpackets/VehicleIOValStructures.hpp>
    47#include <dwframework/dwnodes/common/SelfCalibrationTypes.hpp>
    48
    49namespace dw
    50{
    51namespace framework
    52{
    53
    58{
    59 dwConstRigHandle_t rigHandle;
    63 uint32_t imuSensorIndex;
    66 uint32_t channelFifoSize;
    67 dwConstCameraModelHandle_t cameraHandle;
    68 cudaStream_t cudaStream;
    69};
    70
    77{
    78public:
    79 // TODO(csketch): FP -- This is used when the logger is called and not just at assignment.
    80 // coverity[autosar_cpp14_a0_1_1_violation] FP: nvbugs/2980283
    81 // coverity[autosar_cpp14_m0_1_4_violation] FP: nvbugs/2980283
    82 static constexpr char8_t LOG_TAG[]{"dwSelfCalibrationCameraBasedIMUNode"};
    83
    84 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-2201
    85 static constexpr auto describeInputPorts()
    86 {
    87 // TODO(csketch): RFD -- user defined literal being interpreted as c style cast.
    88 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
    90 DW_DESCRIBE_PORT(dwEgomotionStateHandle_t, "EGOMOTION_STATE_ODO_IMU"_sv, PortBinding::REQUIRED),
    91 DW_DESCRIBE_PORT(dwVehicleIOASILStateE2EWrapper, "VEHICLE_IO_ASIL_STATE"_sv, PortBinding::OPTIONAL), // unused, consider removing
    92 DW_DESCRIBE_PORT(dwFeatureHistoryArray, "CAMERA_FEATURE_DETECTION"_sv, PortBinding::REQUIRED),
    93 DW_DESCRIBE_PORT(dwCameraTwoViewTransformation, "CAMERA_TWO_VIEW_TRANSFORMATION"_sv, PortBinding::OPTIONAL), // unused, consider removing
    94 DW_DESCRIBE_PORT(dwIMUFrame, "IMU_FRAME"_sv, PortBinding::REQUIRED),
    95 DW_DESCRIBE_PORT(bool, "SERVICE_CALIB_ENABLE"_sv, PortBinding::OPTIONAL));
    96 };
    97
    98 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-2201
    99 static constexpr auto describeOutputPorts()
    100 {
    101 // TODO(csketch): RFD -- user defined literal being interpreted as c style cast.
    102 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
    104 DW_DESCRIBE_PORT(dwCalibratedExtrinsics, "IMU_EXTRINSICS"_sv, PortBinding::REQUIRED),
    105 DW_DESCRIBE_PORT(bool, "SERVICE_CALIB_ACTIVE"_sv, PortBinding::OPTIONAL));
    106 }
    107
    108 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-2201
    109 static constexpr auto describePasses()
    110 {
    112 describePass(StringView{"SETUP"}, DW_PROCESSOR_TYPE_CPU),
    113 describePass(StringView{"GET_INPUTS"}, DW_PROCESSOR_TYPE_CPU),
    114 describePass(StringView{"PROCESS_GPU_ASYNC"}, DW_PROCESSOR_TYPE_GPU),
    115 describePass(StringView{"PROCESS_CPU_SYNC"}, DW_PROCESSOR_TYPE_CPU),
    116 describePass(StringView{"TEARDOWN"}, DW_PROCESSOR_TYPE_CPU));
    117 }
    118
    119 static std::unique_ptr<dwSelfCalibrationCameraBasedIMUNode> create(ParameterProvider const& provider);
    120
    121 // coverity[autosar_cpp14_a7_1_5_violation] RFD Accepted: TID-2201
    122 static constexpr auto describeParameters()
    123 {
    124 // TODO(csketch): RFD -- user defined literal being interpreted as c style cast.
    125 // coverity[autosar_cpp14_a5_2_2_violation] RFD Pending: TID-1983
    127 describeConstructorArgument<dwSelfCalibrationCameraBasedIMUNodeParams>(
    129 dwConstRigHandle_t,
    132 size_t,
    133 "cameraSensorIndex"_sv,
    136 uint32_t,
    137 "imuSensorIndex"_sv,
    140 bool,
    141 "enableCalibration"_sv,
    144 uint32_t,
    145 "channelFifoSize"_sv,
    148 cudaStream_t,
    149 "cameraSensorStreamIndex"_sv,
    151 describeConstructorArgument<dwContextHandle_t>(
    153 dwContextHandle_t)));
    154 }
    155
    157 void onChannelsConnected() override;
    158};
    159
    160} // namespace framework
    161} // namespace dw
    162
    163#endif // DWFRAMEWORK_DWNODES_SELFCALIBRATION_DWSELFCALIBRATIONCAMERAIMUNODE_DWSELFCALIBRATIONCAMERAIMUNODE_HPP_
    #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, NAME, args...)
    The interface to access parameter values identified by name and/or (semantic) type.
    This node computes the IMU's extrinsic properties (rotation) with respect to the configured nominal.
    dwSelfCalibrationCameraBasedIMUNode(dwSelfCalibrationCameraBasedIMUNodeParams const &param, dwContextHandle_t const ctx)
    static std::unique_ptr< dwSelfCalibrationCameraBasedIMUNode > create(ParameterProvider const &provider)
    uint32_t imuSensorIndex
    Sensor type index (e.g. imu [0-2]), provided as parameter.
    constexpr std::tuple describeConstructorArguments()
    constexpr PassDescriptorT< 0 > describePass(dw::core::StringView &&name, dwProcessorType processorType)
    constexpr auto describePassCollection(const Args &&... args) -> std::tuple< Args... >
    uint32_t imuSensorRigIndex
    Sensor rig index (e.g. sensor [0-127]), auto-populated by RR2 Loader.
    constexpr auto describePortCollection(Args &&... args) -> dw::core::Tuple< Args... >
    uint32_t cameraSensorRigIndex
    Sensor rig index (e.g. sensor [0-127]), auto-populated by RR2 Loader.
    size_t cameraSensorIndex
    TODO(lmoltrecht): AVC-2389 Consider changing to uint32_t after node split is finished,...
    uint32_t channelFifoSize
    Size of the input channel FIFO queues (must be >0)
    Definition: Buffer.hpp:41
    人人超碰97caoporen国产