ffmpeg学习2 H.264编码原理I/B/P帧

学习资料1 https://download.csdn.net/download/caofengtao1314/12588893

 

1、H.264编码原理I/B/P帧

1.1、I帧

1.1.1、I帧的说明

I帧帧内编码帧,I帧表示关键帧,你可以理解为这一帧画面的完整保留,解码时只需要本帧数据就可以完成(因为包含完整画面)

1.1.2、I帧的特点

  1. 它是一个全帧压缩编码帧,他将全帧图像信息镜像JPEG压缩编码及传输。
  2. 解码时仅用I帧的数据就可重构完整图像;
  3. I帧描述了图像背景和运动主题的详情;
  4. I帧不要参考其他画面而生成;
  5. I帧是P帧和B帧的参考帧(其质量直接影响到同组中以后各帧的质量);我们平时发送网络数据的时候2~3秒就需要一个I帧,否则可能会无法看到图像,I帧的量比较大。
  6. I帧是帧组GOP的基础帧(第一帧),在一组中只有一个I帧;
  7.  I帧不需要考虑运动矢量;
  8.  I帧所占数据的信息量比较大;

1.2、P帧:

1.2.1、I帧的说明  P帧:前向预测编码帧。

P帧表示的是这一帧跟之前的一个关键帧(或P帧)的差别。解码时需要用之前缓存的画面叠加上本帧定义的差别。生成最终画面。(也就是差别帧,P帧没有完整画面数据,只有与前一帧的画面差别数据)

1.2.2、P帧的预测与重构:

P帧是以I帧为参考帧,在I帧中找出P帧“某点”的预测值和运动矢量,取预测差值和运动矢量一起传送。在接收端根据运动矢量从I帧中找出P帧“某点”的预测值并与差值相加以得到P帧“某点”样值,从而可得到完整的P帧。

1.2.3、P帧的特点:

①P帧是I帧后面相隔1~2帧的编码帧;

②P帧采用运动补偿的方法传送它与前面的I或P帧的差值及运动矢量(预测误差);

③解码时必须将I帧中的预测值与预测误差求和后才能重构完整的P帧图像;

④P帧属于前向预测的帧间编码。它只参考前面最靠近它的I帧或P帧;

⑤P帧可以是其后面P帧的参考帧,也可以是其前后的B帧的参考帧;

⑥由于P帧是参考帧,它可能造成解码错误的扩散;

⑦由于差值传送,P帧的压缩比较高

1.3、B帧:

1.3.1、B帧说明

B帧双向预测内插编码帧。B帧是双向差别帧,也就是B帧记录的是本帧与墙厚帧的差别(具体比较复杂,有四种情况,但我说简单些)。换言之,要解码B帧,不仅仅要取得之前的缓存画面,还要解码之后的画面,通过前后画面的与本帧数据的叠加取得最终的画面。B帧压缩率高,但是解码时CPU比较累。

1.3.2、B帧的预测与重构

B帧以前面的I或P帧和后面的P帧为参考帧,“找出”B帧“某点”的预测值和两个运动矢量,并取预测差值和运动运动矢量传送。接收端根据运动矢量在两个参考帧中“找出(算出)”预测值并与差值求和得到B帧“某点”样值,从而可得到完整的B帧。

1.3.3、B帧特点

①B帧是由前面的I或P帧和后面的P帧来进行预测的;

②B帧传送的是它前面的P帧和后面的P帧之间的预测误差即运动矢量;

③B帧是双向预测编码帧;

④B帧压缩比最高,因为他只反应两参考帧间运动主题的变化情况,预测比较准确;

④B帧不是参考帧,不会造成解码错误的扩散。

 

1.4、总结:

I、B、P各帧是根据压缩算法的需要,是人为的定义的。他们都是实实在在的物理帧。一般来说,I帧的压缩率是7(跟JPG差不多),P帧格式20,B帧可以达到50。可见使用B帧能节省大量空间,节省出来的空间可以用来保存多一些I帧,这样在相同码率下,可以提供更好的画面。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值