RV1126+FFMPEG推流项目(8)AENC音频编码模块

本节分享的是AENC音频编码模块,是负责在AI模块通道里面取出收集到的音频数据,进行编码。了解AENC模块之前,先来看一个数据结构"RV1126_AENC_CONFIG",这个数据结构是自己封装的,里面有AENC通道号,和内部描述AENC模块的结构体:AENC_CHN_ATTR_S。

复制代码
typedef struct
{
    unsigned int id;   ///< 音频编码通道ID,用于标识不同的音频编码通道
    AENC_CHN_ATTR_S attr; ///< 音频编码通道属性,包含通道的具体配置信息
} RV1126_AENC_CONFIG;

AENC_CHN_ATTR_S:
复制代码
typedef struct rkAENC_CHN_ATTR_S {
  CODEC_TYPE_E enCodecType; //音频编码类型
  RK_U32 u32Bitrate;  //音频编码码率
  RK_U32 u32Quality;  //音频编码质量
  union {
    AENC_ATTR_AAC_S stAencAAC;  //AAC结构体
    AENC_ATTR_MP2_S stAencMP2;  //MP2结构体
    AENC_ATTR_G711A_S stAencG711A; //G711A结构体
    AENC_ATTR_G711U_S stAencG711U; //G711U结构体
    AENC_ATTR_G726_S stAencG726;   //G726结构体
  };

} AENC_CHN_ATTR_S;
CODEC_TYPE_E enCodecType:硬盘编码类型,这个项目选择AAC。

RK_U32 u32Bitrate; 音频编码码率

u32Bitrate:音频码率指的是:音频压缩数据在单位时间内传输的数据量,比特率越大声音质量越好,和视频的码率一样,码率越大视频越清晰,AAC 推荐音频码率(64kbps、512kbps、1536kbps(AAC推荐))、 G711 推荐的码率(64KBPS)、 G726

推荐的比特率(32kbps )。这个它不像视频的编码器一样可以动态调节,这里基本是固定的。

RK_U32 u32Quality; //音频编码质量

**RK_U32 u32Quality,**默认是1就可以了,


union:

联合体有五个数据结构,上面三个可以说是一个公共的配置,不管选择联合体里面的那应该都要设置配的三个参数。

AENC_ATTR_AAC_S stAencAAC; //AAC结构体

AENC_ATTR_MP2_S stAencMP2; //MP2结构体

AENC_ATTR_G711A_S stAencG711A; //G711A结构体

AENC_ATTR_G711U_S stAencG711U; //G711U结构体

AENC_ATTR_G726_S stAencG726; //G726结构体


AENC_ATTR_AAC_S:AAC 编码属性结构体

  • u32Channels:AENC 音频编码通道,AAC 编码通道默认值为 2
  • u32SampleRate:AENC 音频采样率,采样率范围为 [7350, 96000]。
  • 推荐采样率:48000 和 44100
  • 注意:AENC 的采样率和 AI 的采样率要一致

AENC_ATTR_MP2_S:MP2 编码属性结构体

  • u32Channels:AENC 音频编码通道,MP2 编码通道数为 2
  • u32SampleRate:AENC 音频采样率,采样率范围为 [0, 48000]。

AENC_ATTR_G711A_S:G711A 编码属性结构体

(G.711 是一种由国际电信联盟(ITU-T)制定的音频编码方式,广泛运用于电话领域。G711A 指的是 13Bit 转换为 8Bit)

  • u32Channels:AENC 音频编码通道,G711A 使用 1 个通道
  • u32SampleRate:AENC 音频采样率,采样率默认为 8KHZ
  • u32NbSample:音频帧的采样个数,默认为 320。

AENC_ATTR_G711U_S:G711U 编码属性结构体

(G.711 是一种由国际电信联盟(ITU-T)制定的音频编码方式,广泛运用于电话领域。G711U 指的是 14Bit 转换为 8Bit)

  • u32Channels:AENC 音频编码通道,G711U 使用 1 个通道
  • u32SampleRate:AENC 音频采样率,采样率默认为 8KHZ
  • u32NbSample:音频帧的采样个数,默认为 320。

AENC_ATTR_G726_S:G726 编码属性结构体

(G.726 是 ITU-T 定义的音频编码算法,能够将 64kbps 的信号转换为 40kbps、32kbps、24kbps、16kbps,这个协议广泛运用于电话中)

  • u32Channels:AENC 音频编码通道,默认使用 1 个通道
  • u32SampleRate:AENC 音频采样率,采样率为 8KHZ。
  • u32NbSample:音频帧的采样个数,默认为 320。

创建ANEC:

复制代码
{
    //AENC音频编码模块
    RV1126_AENC_CONFIG rv_aenc;
    rv_aenc.id = 0; //默认都是从0开始
    //AVEN公共参数
    rv_aenc.attr.enCodecType = RK_CODEC_TYPE_AAC; //选择AAC编码器
    rv_aenc.attr.u32Bitrate = 153600;//AENC的音频码率
    rv_aenc.attr.u32Quality = 1; //编码质量
    rv_aenc.attr.stAencAAC.u32Channels = 2; //通道数
    rv_aenc.attr.stAencAAC.u32SampleRate =  48000;//音频采样率,和AI模块要一样
    ret = rkmedia_aenc_init(&rv_aenc);//初始化aenc
    if(ret != 0)
    {
        printf("初始化aenc失败\n");
    } 
    else
    {
        printf("aenc初始化成功\n");
        //设置容器保存aenc的通道号
        RV1126_AENC_CONTAINER aenc_container;
        aenc_container.id = 0;//索引
        aenc_container.aenc_id = rv_aenc.id;
        ret = set_aenc_container(0, &aenc_container); //设置容器里面
        if(ret != 0)
        {
            printf("aenc保存到容器失败\n");
        }
    }
    
    return 0;
}
相关推荐
OperateCode3 小时前
AutoVideoMerge:让二刷更沉浸的自动化视频处理脚本工具
python·opencv·ffmpeg
早睡身体好~1 天前
【lubancat】鲁班猫4实现开机后自动播放视频
音视频·linux开发
小幽余生不加糖1 天前
电路方案分析(二十二)适用于音频应用的25-50W反激电源方案
人工智能·笔记·学习·音视频
胡耀超1 天前
DataOceanAI Dolphin(ffmpeg音频转化教程) 多语言(中国方言)语音识别系统部署与应用指南
python·深度学习·ffmpeg·音视频·语音识别·多模态·asr
byxdaz1 天前
FFmpeg QoS 处理
ffmpeg
shix .1 天前
bilibili视频总结
音视频
lovep12 天前
音频-文本对比学习:LARGE-SCALE CONTRASTIVE LANGUAGE-AUDIO PRETRAINING论文翻译和理解
音视频·glap·音频理解·音频对比学习·laion-audio·音频检索
codelancera2 天前
ffmpeg-调整视频分辨率
ffmpeg·音视频
天向上2 天前
手机端的音视频界面或者图片文档界面共享给大屏
智能手机·音视频·多平台·手机投屏·多屏互动
ECC&SM93 天前
Video_AVI_Packet(1)
笔记·音视频