2017-11-27

【嵌牛导读】今天为大家讲解视频的编码原理。

【嵌牛鼻子】视觉暂留现象,有损图像压缩,运动预测,图像组和视频文件,视频容器

【嵌牛提问】计算机如何生成图像,视频

【嵌牛正文】

视觉暂留现象

人的眼睛是一个非常巧妙的成像系统,来自自然界的光经由晶状体,投射到感光细胞上,感光细胞将光转化为神经电流,通过视神经传到大脑,引起人体视觉。受制于视觉神经的反应速度,当光停止作用后,在一段时间内,图像仍将短暂地停留,称为“后像“,这便是视觉暂留现象。

IT之家学院:文件格式系列科普之视频编码基本原理

正因为人的视觉系统有着这样的特性,当我们将一组动作连续的静态图片放在眼前快速切换时,人眼会感觉它“动起来了“。事实上,我们看到的视频,就是由一张又一张的静态图像组成的。

有损图像压缩

前面我们已经提到,视频是由一张又一张的静态图片组成的,要压缩视频,首先就要压缩这些组成视频的静态图像,在关于JPEG图片格式的科普中,我们已经讲解了JPEG的压缩原理,事实上,视频中的静态图片,它的压缩原理和JPEG颇为相似。

首先,就是将色彩空间由RGB转化为YCbCr,和RGB色彩空间通过红绿蓝三种颜色来组成大千世界不同,YCbCr将画面分解成明度(亮度信息)和色度(色彩信息),在YCbCr的色彩空间下,把Cb(蓝)和Cr(红)去掉,只留Y(亮度),那么图像依然可以正常显示,只是此时显示的图像是黑白的,把亮度信息和色彩信息分离所带来的好处,就是解决了彩色显示器和黑白显示器的兼容问题。

IT之家学院:文件格式系列科普之视频编码基本原理

色彩空间转换完成后,就要对图像进行离散余弦变换(DCT)了,在DCT时,图像将被分割成一个个8*8的像素块,每个8*8的像素块都将通过复杂的公式转换为数字编码,随后,这些数字编码将通过一系列的处理进一步丢掉对人眼来讲并不重要的数据(人眼对高频区的辨识能力较差,这部分的数据可以酌情丢掉),经过这番折腾,原始的8*8像素块将被转化为结尾有很多连续的0的一串数字编码。这串编码经过冗余数据精简后,再进行一些处理,将生成一张经过压缩的图片。这张图片就是视频中的I帧。

运动预测

I帧,又称帧内编码帧,这是个独立帧,自带全部信息;P帧,又称帧间预测编码帧,它里面包含的是当前帧与前一帧之间的差别,在解码时,需要以之前的画面为基础,叠加上两幅画面之间的差异部分,才能生成最终的画面。B帧,又称双向预测编码帧,它不仅记录了当前帧与前一帧之间的差别,还记录了当前帧与下一帧之间的差别,B帧的压缩率通常更高,不过对解码性能的要求也更高。

IT之家学院:文件格式系列科普之视频编码基本原理

P帧的生成过程,实际上就是运动预测的过程,在这个过程中,图像将被分割成一个个16*16的像素块,然后,我们将计算当前帧的这个16*16像素块的信息与下一帧中哪个16*16像素块中的信息最为相似,然后记录下它们之间的位置差别(运动预测矢量),简单地说,运动预测的过程,就是使用当前帧位于不同起始位置的16*16像素块,拼凑出下一帧的图像来。B帧的生成原理和P帧大致相同,只不过B帧是同时结合前后两帧来实现运动预测的。

图像组和视频文件

所谓的图像组,就是由I帧打头,后面跟了一系列的P帧或者B帧的图像的编组,看起来差不多是这个样子的:I,P,P,P,P,P,P,P,P,P,P,如果有B帧,则是这个样子的:I,P,B,B,P,B,B,P,B,B,P。

视频文件是由一个接着一个的图像组构成的。在播放视频时,每个图像组的第一帧必须是I帧,若第一帧不是I帧,后面的P帧或者B帧将无法被还原成正常的图像,视频也就无法正常播放了。

IT之家学院:文件格式系列科普之视频编码基本原理

如果一个P帧是由某帧通过运动预测来生成的,那么这里的“某帧”就是该P帧的参考帧,关于参考帧的选择,也是有讲究的。

这里有一个图像组,I1,P1,P2,P3,P4,P5,P6,P7,P8,P9,P10,我们参考I1生成了P1,又参考了P1生成了P2,紧接着参考P2生成了P3,以此类推,最后生成了P10,由于运动预测本身就是有误差的,如果我们每一帧都参考前一帧进行运动预测,那么从P1到P10,误差会越来越大,最后生成的P10可能就面目全非了。为了避免这个问题,在选择参考帧时,我们可以这样做,P1~P10,全部参考I1来生成,或者P1~P5参考I1来生成,然后P6~P10参考P5来生成,步子迈得小一点,扯到蛋的风险自然就会降低。

到这里,视频编码基本原理的介绍就告一段落了,不同的编码标准,它具体的编码方式也不尽相同,这个需要具体标准具体分析。常见的视频编码标准有MPEG-1、MPEG-2、MPEG-3、MPEG-4、H.264等。

视频容器

如果说视频是个图书馆,那么一帧一帧的图像就是书的一页一页,一个一个的图像组,就是一本又一本的书,我们还缺少什么东西啊?书架。图书馆里没有书架怎么行?

所谓视频容器,就是将图像组,声音以及视频的附属信息(比如字幕、分辨率、作者、加密信息等)封装在一起的标准,这就正是我们要找的书架。

视频容器,又叫封装格式,提到封装格式(对应相应的文件扩展名),相信大家一定非常眼熟,举几个例子,大家感受一下:avi、rmvb、mp4、flv、mkv……

IT之家学院:文件格式系列科普之视频编码基本原理

封装格式对视频质量的影响不大,决定视频质量的还是它的编码数据,就像前面举的图书馆的例子,书架不管是豪华还是简陋,只要它上面摆放的书是好书,那这个图书馆就是个好图书馆。

IT之家的用户是多层次的,这篇文章的受众是零基础的读者,本着浅显易懂的原则,在一些方面我们并没有深入讨论和展开讨论。如果你是相关行业的工作者,或者你是相关专业的高校学生,那么这篇文章可能不适合你。

好的,今天关于视频压缩原理的文章就到这里,文件格式系列科普至此完结,想了解更多的常识科普和实用教程,请关注IT之家学院。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,743评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,296评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,285评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,485评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,581评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,821评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,960评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,719评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,186评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,516评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,650评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,329评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,936评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,757评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,991评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,370评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,527评论 2 349

推荐阅读更多精彩内容