13_AAC编码介绍
AAC(Advanced Audio Coding,译为:高级音频编码),是由Fraunhofer IIS、杜比实验室、AT&T、Sony、Nokia等公司共同开发的有损音频编码和文件格式。
对比MP3
AAC被设计为MP3格式的后继产品,通常在相同的比特率下可以获得比MP3更高的声音质量,是iPhone、iPod、iPad、iTunes的标准音频格式。
AAC相较于MP3的改进包含:
- 更多的采样率选择:8kHz ~ 96kHz,MP3为16kHz ~ 48kHz
- 更高的声道数上限:48个,MP3在MPEG-1模式下为最多双声道,MPEG-2模式下5.1声道
- 改进的压缩功能:以较小的文件大小提供更高的质量
- 改进的解码效率:需要较少的处理能力进行解码
- ......
规格
AAC是一个庞大家族,为了适应不同场合的需要,它有很多种规格可供选择。下面列举其中的9种规格(Profile):
- MPEG-2 AAC LC:低复杂度规格(Low Complexity)
- MPEG-2 AAC Main:主规格
- MPEG-2 AAC SSR:可变采样率规格(Scaleable Sample Rate)
- MPEG-4 AAC LC:低复杂度规格(Low Complexity)
- 现在的手机比较常见的MP4文件中的音频部分使用了该规格
 
- MPEG-4 AAC Main:主规格
- MPEG-4 AAC SSR:可变采样率规格(Scaleable Sample Rate)
- MPEG-4 AAC LTP:长时期预测规格(Long Term Predicition)
- MPEG-4 AAC LD:低延迟规格(Low Delay)
- MPEG-4 AAC HE:高效率规格(High Efficiency)
最早是基于MPEG-2标准,称为:MPEG-2 AAC。后来MPEG-4标准在原来基础上增加了一些新技术,称为:MPEG-4 AAC。
LC和HE
虽然上面列举了9种规格,但我们目前只需要把注意力放在常用的LC和HE上。下图很好的展示了从LC到HE的发展历程。


LC
LC适合中等比特率,比如96kbps ~ 192kbps之间。
MPEG-4 AAC LC等价于:
- MPEG-2 AAC LC + PNS
PNS(Perceptual Noise Substitution)译为:感知噪声替代。
- PNS可以提高AAC的编码效率
HE
HE有v1和v2两个版本,适合低比特率:
- v1:适合48kbps ~ 64kbps
- v2:适合低于32kbps,可在低至32kbps的比特率下提供接近CD品质的声音
v1
MPEG-4 AAC HE v1的别名:
- aacPlus v1
- eAAC
- AAC+
- CT-aacPlus(Coding Technologies)
- Coding Technologies是瑞典是一家技术公司,率先在AAC中使用了SBR技术
- 在2007年,被杜比实验室(Dolby Laboratories)以2.5亿美元收购
 
MPEG-4 AAC HE v1等价于:
- MPEG-4 AAC LC + SBR

SBR(Spectral Band Replication)译为:频段复制。
- 是一种增强的压缩技术
- 可以将高频信号存储在少量的SBR data中
- 解码器可以根据SBR data恢复出高频信号
v2
MPEG-4 AAC HE v2的别名:
- aacPlus v2
- AAC++
- eAAC+、Enhanced AAC+
MPEG-4 AAC HE v2等价于:
- MPEG-4 AAC HE v1 + PS

PS(Parametric Stereo)译为:参数立体声。
- 是一种有损的音频压缩算法,可以进一步提高压缩率
- 可以将左右声道信号组合成单声道信号,声道之间的差异信息存储到少量的PS data中(大概占2 ~ 3kbps)
- 解码器可以根据PS data中恢复出立体声信号
编解码器
如果想对PCM数据进行AAC编码压缩,那么就要用到AAC编码器(encoder)。
如果想将AAC编码后的数据解压出PCM数据,那么就要用到AAC解码器(decoder)。
这里只列举几款常用的AAC编解码器:
- 
- 支持LC/HE规格
- 目前已经停止开发维护
 
- FFmpeg AAC - 支持LC规格
- FFmpeg官方内置的AAC编解码器,在libavcodec库中
- 编解码器名字叫做aac
- 在开发过程中通过这个名字找到编解码器
 
 
- FAAC(Freeware Advanced Audio Coder) - 支持LC规格
- 可以集成到FFmpeg的libavcodec中
- 编解码器名字叫做libfaac
- 在开发过程中通过这个名字找到编解码器,最后调用FAAC库的功能
 
- 从2016年开始,FFmpeg已经移除了对FAAC的支持
 
- 
- 支持LC/HE规格
- 目前质量最高的AAC编解码器
- 可以集成到FFmpeg的libavcodec中
- 编解码器名字叫做libfdk_aac
- 在开发过程中通过这个名字找到编解码器,最后调用FDK AAC库的功能
 
 
编码质量排名:Fraunhofer FDK AAC > FFmpeg AAC > FAAC。
FDK AAC
在网上下载的编译版FFmpeg,通常都是没有集成libfdk_aac的。可以通过命令行查看FFmpeg目前集成的AAC编解码器。
# windows
ffmpeg -codecs | findstr aac
# mac
ffmpeg -codecs | grep aac
我这边的输出结果是:
DEAIL. aac                  AAC (Advanced Audio Coding) (decoders: aac aac_fixed )
D.AIL. aac_latm             AAC LATM (Advanced Audio Coding LATM syntax)
很显然,并没有包含libfdk_aac。
这里给出1个比较推荐的方案:自己手动编译FFmpeg源码,将libfdk_aac集成到FFmpeg中。
- 自己手动编译的话,想集成啥就集成啥
- 可以把你想要的东西都塞到FFmpeg中,不想要的就删掉
- 也就是根据自己的需要对FFmpeg进行裁剪
13_AAC编码介绍的更多相关文章
- Python编码介绍——encode和decode
		在 python 源代码文件中,如果你有用到非ASCII字符,则需要在文件头部进行字符编码的声明,声明如下: # code: UTF-8 因为python 只检查 #.coding 和编码字符串,所以 ... 
- Golang的字符编码介绍
		Golang的字符编码介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Go里面内建仅支持UTF8字符串编码,因此如果你用fmt.Printf之类的函数无法将GBK,GB2312 ... 
- AAC帧格式及编码介绍
		参考资料: AAC以adts格式封装的分析:http://wenku.baidu.com/view/45c755fd910ef12d2af9e74c.html aac编码介绍:http://wenku ... 
- 字符编码介绍及java中的应用
		字符编码,就是对日常的控制符号.文字和常用符号的二进制表示.为了准确的表示如何编号,怎么生产八位字节流,Unicode Technical Report (UTR) #17提出现代编码模型的5个层次: ... 
- Quoted-printable 编码介绍、编码解码转换
		求教,“=B9=A4=D7=F7=BC=F2=B1=A8” 这种是什么编码方式? Quoted-printable 可译为“可打印字符引用编码”.“使用可打印字符的编码”,我们收邮件,查看信件原始信息 ... 
- Base-64编码介绍
		Base-64编码保证了二进制数据的安全 Base-64编码可以将任意一组字节转换为较长的常见文本字符序列,从而可以合法地作为首部字段值.Base-64编码将用户输入或二进制数据,打包成一种安全格式, ... 
- python语言简介、解释器、字符编码介绍
		一.为什么要选择python作为学习语言: 各个语言的对比: C和python.java.C#等 C语言:代码编译得到机器码,机器码在处理器上直接执行,每一条指令控制cpu工作 其他语言:代码编译得到 ... 
- 编码介绍(ANSI、GBK、GB2312、UTF-8、GB18030和 UNICODE)
		转载:http://blog.jobbole.com/30526/(前面内容)和http://www.ruanyifeng.com/blog/2007/10/ascii_unicode_and_utf ... 
- linux下查看文件编码及修改编码介绍
		1.在Vim中可以直接查看文件编码:set fileencoding即可显示文件编码格式.如果你只是想查看其它编码格式的文件或者想解决用Vim查看文件乱码的问题,那么你可以在~/.vimrc 文件中添 ... 
- python字符编码转换说明及深浅copy介绍
		编码说明: 常用编码介绍: ascii 数字,字母 特殊字符. 字节:8位表示一个字节. 字符:是你看到的内容的最小组成单位. abc : a 一个字符. 中国:中 一个字符. a : 0000 10 ... 
随机推荐
- Linux centos7.6 在线及离线安装postgresql12 详细教程(rpm包安装)
			一.在线安装 官网找到对应的版本 PostgreSQL: https://www.postgresql.org/ 1.配置yum源 sudo yum install -y https://downl ... 
- Pandas分组聚合
			groupby分组操作详解 在数据分析中,经常会遇到这样的情况:根据某一列(或多列)标签把数据划分为不同的组别,然后再对其进行数据分析.比如,某网站对注册用户的性别或者年龄等进行分组,从而研究出网站用 ... 
- Power BI 5 DAY
			目录 Power BI 数据建模与数据汇总分析 多维数据模型 搭建多维数据模型 搭建方法 注意事项 搭建数据模型思考 数据变量类型 主键ID特点(非空不重复) 星型结构 交叉筛选器方向 单一/两个 连 ... 
- JS leetcode 杨辉三角Ⅱ 题解分析
			壹 ❀ 引 今天是的题目来自leetcode的119. 杨辉三角 II,还记得几天前,我第一次遇到118. 杨辉三角,一段代码调试半天写不出来,这次遇到升级版终于开开心心快快乐乐轻松解题,题目描述如下 ... 
- NVME(学习笔记七)—Atomicity Operation
			5.21.1.10 Write Atomicity Normal 这个特性控制AWUN和NAWUN参数的操作.设置的属性值在set Feature命令的Dword 11中表明. 如果提交Get Fea ... 
- 使用sqlmap执行SQL注入并获取数据库用户名
			Sqlmap介绍 sqlmap支持MySQL, Oracle,PostgreSQL, Microsoft SQL Server, Microsoft Access, IBM DB2, SQLite, ... 
- Oracle 中LONG RAW BLOB CLOB类型介绍
			说明: RAW: 未加工类型,可存储二进制数据或字节符 LONG: 可变长的字符串数据,最长2G,LONG具有VARCHAR2列的特性,可以存储长文本一个表中最多一个LONG列[不建议使用] LONG ... 
- C++ sentry 如何压缩日志文件
			项目中在使用 sentry 上传事件的 attachment 函数过程中发现,附带的 log 文件是未压缩的,于是有了需求,即需要在 sentry 内部将未压缩的文件流压缩后再上传给服务器 这个需求看 ... 
- windows下redis安装与使用
			下载 redis下载地址 步骤,一直下一步按就完事了,记得勾选添加到环境配置 其中建议自定义路径吧,文件夹名字Redis,一定要大写,小写不来事. 安装完后 启动命令 找到你安装redis的文件夹,在 ... 
- ElkStack-MACOS搭建
			目录 简介 Elasticsearch Logstash/Filebeats Kibana 架构流程 安装配置 版本 先决条件 brew Elasticsearch mac安装elasticsearc ... 
