NVIDIA DRIVE SDK学习(二)——NvMedia

NvMedia整体介绍

图像处理和管理

NvMedia支持以下几个处理:

  • 处理NvSciBufObj带过来的图像数据
  • 支持注册NvSciBufObj进行处理。
  • 支持按图像特定的元数据作为NvSciBufObj的一部分。

NvMedia分为下面几个部分:

Image 2D

该组件支持对图像进行拷贝、缩放、裁剪等操作。它操作的图像格式为RGB或者YUV,也支持两种格式的转化。它支持图像聚合操作。

IEP

该组件支持将YUV格式图像编码成H.264/H.265/AV1格式视频流。
详细内容参考:IEP描述

IJPE

  • Baseline ITU-T T.81 / ISO/IEC 10918-1
  • Programmable Huffman Table
  • Programmable Quant Table
  • 8bit YUV420 semi-planar Input Format
  • 8bit YUV420 planar input format
  • Rate control i.e. target image size
  • Quality factor parameter from 1 (lowest quality) to 100 (highest quality)

IJPD

详细内容参考:IJPD描述

OFA

OFA可以分为两种模式:
立体视差模式:在这种模式下,该模块通过左图像和右图像来产生立体视差,从而进行物体深度测量。
光追模式:该模块通过前后两幅图像,来产生光流向量。
应用场景:
在这里插入图片描述

在这里插入图片描述
详细内容见链接:OFA描述

SIPL

SIPL框架是用来提供HDR摄像头数据来给用户或者机器视觉。它可以处理单个相机,也可以处理多个相机链接到聚合器的场景。

NvMedia Tensor

目前,NvMedia仅支持4维张量:
NvMedia Tensor与NvMedia DLA组件一起使用
可以通过使用NvSciBuf API通过NvMedia Tensor属性分配NvSciBuf来创建NvMedia张量。由于NvSciBuf API有助于NvMedia和NVIDIA®CUDA®之间的数据共享,这使得分配的张量可以在NvSciBuf API允许的情况下重复使用。

NvSciSync

NvSciSync组件使得NvMedia组件可以与其他组件保持同步,比如CUDA组件、基于NvSciSync的组件等。
NvSciSync支持针对高级驾驶员辅助系统(ADAS)和自主应用程序开发的image组件。它们不支持NvMedia视频组件。
有NvSciSync扩展的组件支持:

  • Accepting an NvSciSyncFence object when the NvMedia engine is used as a waiter
  • Returning an NvSciSyncFence object when the NvMedia engine is used as a signaler

其中的定义:
Frame:硬件加速引擎可以操作的最小数据单元。
SOF Fence:表示硬件加速引擎已经开始处理数据。
EOF Fence:表示硬件加速引擎已经把数据处理完了,并切有数据可用了。
PRE Fence:一个fence开始处理之后被blocked住,然后直到fence结束。

SIPL介绍

SIPL在用户层可以抽象为下面两种功能:

  • 配置外部摄像头、EEPROM、加串器、解串器等。
  • 配置硬件和对应pipeline来捕获处理图像数据。

SIPL各组件输出格式

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
NvMedia库可以通过RAW8格式进行YUV数据的传输。以下是一个简单示例,展示了如何使用NvMedia以RAW8格式传输YUV数据: ```cpp #include <iostream> #include <nvmedia.h> int main() { // 创建NvMedia设备 NvMediaDevice *device = nullptr; if (NvMediaDeviceCreate(&device) != NVMEDIA_STATUS_OK) { // 创建NvMedia设备失败的错误处理 } // 创建YUV图像 NvMediaImage *image = nullptr; NvMediaImageAdvancedConfig imageConfig{}; imageConfig.width = 1920; // 设置图像宽度 imageConfig.height = 1080; // 设置图像高度 imageConfig.surfaceType = NvMediaSurfaceType_Image_YUV_420; // 设置图像类型 imageConfig.colorFormat = NvMediaSurfaceColorFormat_YUV420; // 设置颜色格式 imageConfig.dataFormat = NVMEDIA_IMAGE_CLASS_SINGLE_IMAGE; // 设置数据格式 if (NvMediaImageCreate(device, &imageConfig, &image) != NVMEDIA_STATUS_OK) { // 创建YUV图像失败的错误处理 } // 创建原始数据缓冲区 uint8_t *rawData = new uint8_t[imageConfig.width * imageConfig.height]; // 填充原始数据缓冲区(以RAW8格式为例) // ... // 将原始数据传输到YUV图像中 NvMediaImageSurfaceMap surfaceMap; if (NvMediaImageLock(image, NVMEDIA_IMAGE_ACCESS_WRITE, &surfaceMap) != NVMEDIA_STATUS_OK) { // 锁定图像失败的错误处理 } // 将原始数据拷贝到图像中 memcpy(surfaceMap.surface[0].mapping, rawData, imageConfig.width * imageConfig.height); NvMediaImageUnlock(image); // 释放资源 delete[] rawData; NvMediaImageDestroy(image); NvMediaDeviceDestroy(device); return 0; } ``` 在上述示例代码中,我们首先创建了NvMedia设备,使用`NvMediaDeviceCreate`函数进行创建。 然后,我们使用`NvMediaImageCreate`函数创建了一个YUV图像,通过设置`NvMediaImageAdvancedConfig`结构体中的参数来指定图像的属性,包括宽度、高度、图像类型、颜色格式和数据格式。 接下来,我们创建了一个原始数据缓冲区,可以根据实际情况分配和填充原始数据。 然后,我们使用`NvMediaImageLock`函数锁定图像,并通过`memcpy`函数将原始数据拷贝到图像的映射内存中。 最后,我们释放了所有资源,包括原始数据缓冲区和图像,并销毁了NvMedia设备。 请注意,上述示例代码仅展示了如何使用NvMedia以RAW8格式传输YUV数据,实际情况可能会根据具体需求进行调整和扩展。此外,还需要根据具体情况进行错误处理和资源释放。 希望这个示例代码能够帮助您实现以RAW8格式传输YUV数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值