venc_create_chn
Applicability
|
Product |
Supported (√/x) |
|---|---|
|
|
√ |
|
|
√ |
|
|
x |
|
|
√ |
|
|
√ |
Function Usage
Creates an encoding channel.
Prototype
- C Prototype
1hi_s32 hi_mpi_venc_create_chn(hi_venc_chn chn, const hi_venc_chn_attr *attr);
- Python Function
1ret = acl.himpi.venc_create_chn(chn, attr)
Parameter Description
|
Parameter |
Description |
|---|---|
|
chn |
Int, decoding channel ID.
NOTE:
For Ascend virtual instances on the For Ascend virtual instances on the For Ascend virtual instances on the You can run the npu-smi info -t template-info command on the server where Ascend AI Processor is installed to view the computing power specifications of the Ascend virtual instance in each scenario. |
|
attr |
Dict, dictionary of the encoding channel attributes. For details, see hi_venc_chn_attr. |
Return Value Description
|
Return Value |
Description |
|---|---|
|
ret |
Int, error code.
|
Restrictions
- The channel ID of a single device cannot exceed the maximum channel ID.
- An encoding channel has the encoder attributes, rate controller (RC) attributes, and group of pictures (GOP) attributes.
- In the encoder attributes, the stream buffer depth, stream fetching mode, and encoding profile must be set according to Table 1.
- The recommended encoding sizes are 3840 x 2160 (4K), 1920 x 1080 (1080p), and 1280 x 720 (720p).
- For H.264/H.265 encoding, a frame buffer consists of YHeaderSize, CHeaderSize, YSize, CSize, PmeSize, PmeInfoSize, and TmvSize. The encoder calculates the buffer allocation based on the maximum width and height by default. When configuring the channel width and height, ensure that each frame buffer calculated based on the channel width and height does not exceed that calculated based on the maximum channel width and height.
- The input/output frame rate (src_frame_rate/dst_frame_rate) in the attributes of the bit rate controller is used to allocate the bit rate (bit_rate) during encoding, but not the final display frame rate of the player. For details about how to set the display frame rate, see acl.himpi.venc_set_h264_vui or acl.himpi.venc_set_h265_vui.
You are advised to set the control frame rate to be the same as the display frame rate. Otherwise, the playback bit rate may be different from the configured encoding bit rate. The playback bit rate will vary with the configured display frame rate.
References
|
Encode Protocol |
Encode Mode |
Stream Buffer Depth |
Stream Fetching Mode |
Encode Profile |
|---|---|---|---|---|
|
H.264 |
Frame |
|
Frame/Slice |
Baseline Main Profile High Profile |
|
JPEG |
Frame |
|
Frame/Ecs |
Baseline |
|
H.265 |
Frame |
|
Frame/Slice |
Main Profile Main 10 Profile (not supported currently) |
|
Frame/Slice |
Main 10 profile (not supported currently) |