vdec_create_chn
产品支持情况
产品 |
是否支持 |
---|---|
|
√ |
|
√ |
|
x |
|
√ |
|
√ |
|
x |
功能说明
根据设置的通道属性创建解码通道。
函数原型
- C函数原型
1
hi_s32 hi_mpi_vdec_create_chn(hi_vdec_chn chn, const hi_vdec_chn_attr *attr);
- python函数
1
ret = acl.himpi.vdec_create_chn(chn, attr)
参数说明
参数名 |
说明 |
---|---|
chn |
int,解码通道号 。
说明:
对于 对于 对于 昇腾虚拟化实例(Ascend Virtual Instance)在各场景下的算力资源规格,在安装昇腾AI处理器的服务器上使用npu-smi info -t template-info命令查看。 |
attr |
dict,解码通道属性字典,具体请参见hi_vdec_chn_attr。
|
返回值说明
返回值 |
说明 |
---|---|
ret |
int,错误码。
|
约束说明
- 单个Device上的通道号不能超出最大的通道号范围。
- 在创建解码通道之前必须保证通道未创建(或者已经销毁),否则会直接返回错误。
- 系统内存不足时会返回“HI_ERR_VDEC_NO_MEM”的错误码,可考虑扩展操作系统内存。
- 如果需要解码的H.264码流有B帧,或者需要解码的H.265码流支持时域运动矢量预测(sps_temporal_mvp_enabled_flag = 1),则创建通道时需要设置此通道支持时域运动矢量预测(temporal_mvp_en 设置为 1),还需要为其分配输出每一帧Tmv(Temporal Motion Vector)信息的VB(Video Buffer)块,该VB块的大小比图像VB块小很多,所需个数为RefFrameNum + 1,具体大小通过调用函数acl.himpi.vdec_get_tmv_buf_size获取,否则会导致解码出现花屏等错误。
- H.264、H.265解码每个解码通道所需VB个数至少为参考帧+显示帧+1,JPEG解码每个解码通道所需VB个数至少为显示帧+1。不同协议解码所需的图像VB块大小不同,具体大小通过调用函数acl.himpi.vdec_get_pic_buf_size获取。
- 如果 H.264解码不需要解码B帧,或者 H.265解码不需要解码支持时域运动矢量预测(sps_temporal_mvp_enabled_flag = 1)的码流,则创建通道时可设置此通道不支持时域运动矢量预测(“temporal_mvp_en”设置为“0”),此种情况不输出Tmv信息,可以不用创建Tmv VB池,节省内存。
- 用户需要根据解码码流配置解码所需的帧存VB大小“frame_buf_size”和个数“frame_buf_cnt”,以及存放Tmv信息的VB大小 “tmv_buf_size”,解码器内部按此配置创建相应的私有VB池。
- 只要帧存Buffer和Tmvbuffer足够大,解码通道能解码在最大最小分辨率范围内的任意分辨率码流。通道宽高当前只与码流Buffer、SCDbuffer(start code detector buffer)大小有关。