多数的数字视频应用需要播放彩色的视频信号,所以需要捕获和重现颜色信息。一幅黑白图像的每一个采样点只需要一个像素表示明暗或亮度,而在彩色图像中至少需要3个像素来表示每个像素的色彩。表示亮度和色彩的不同方法,由不同的色彩空间确定。

RGB色度空间

在RGB彩色空间,彩色图像中用3个数来表示红、蓝、绿三种颜色的比例(光的三原色)。任何其他色彩都可以由这三种颜色的不同比例的混合构成。在RGB色彩空间,可以方便地对彩色图像进行捕获和显示。在捕捉图像的时候,首先要把场景中红蓝绿三种色彩分量提取出来,每一种分量单独使用一组传感器。色彩在阴极射线管显示器(CRT)和液晶显示器(LCD)中显示的时候,分别按照红蓝绿3种分量的强度显示每一个像素。当人们从一定距离观看时,独立的色彩分量相互混色就产生“真实的彩色”。

YCbCr色度空间

人类视觉系统(HVS,human vision system)对色度的敏感程度低于亮度。而在RGB色彩空间里,3种颜色分量的重要性相同,所以必须以相同的度量来存储它们,但事实上我们可以通过提高亮度的精度,降低色度的精度来更有效的表示颜色图像。

通常,YCbCr色彩空间和它的变形(YUV色彩空间)是用于有效表示彩色图像的对色彩空间度量的方法。Y指亮度(Luma),是不同权重的R,G,B的平均:

Y=krR+kgG+kbB                             (1)

k是权重。

色彩信息可以表示为色差(Chroma),每一个色差表示了RGB与Y的差:

Cb=B-Y

Cr=R-Y                                          (2)

Cg=G-Y                    

这样彩色图像的完整信息——亮度和色差就由Y和Cb,Cr,Cg分别给出了。

至此,这样的颜色空间并没有表现出明显的优点,因为处理后有四个分量,而RGB中只有三个色彩分量。但是,因为Cb+Cr+Cg是一个常数,所有我们只需要存储或传输其中的两个,第三个可以计算出来。在YCbCr空间,只有亮度和蓝色、红色的色差传输。YCbCr相对RGB而言有一个重大的优点,就是我们可以用比Y更低的分辨率来存储CbCr,因为人类视觉系统对色度敏感程度低于亮度。这样可以减少大量数据的同时对视觉质量没有明显的影响。对于普通的观察者,RGB图像与降低CbCr分辨率的YCbCr图像没有什么区别,所以这也是图像压缩中简单而有效的方式之一。

Y=krR+(1-kb-kr)G+kbB                                                      

Cb=(0.5/(1-kb)) (B-Y)                                                    (3)

Cr=(0.5/(1-kr)) (R-Y)                                                         


R=Y+((1-kr)/0.5) Cr                                                           

G=Y-(2Kb(1-Kb)/(1-kb-kr)) Cb-(2Kr(1-Kr)/(1-kb-kr)) Cr     (4)

B=Y+((1-kb)/0.5) Cb                                                          

得到RGB的图像之后,将现有的RGB图像转换成YCbCr图像是为了减少存储或传输数量,在显示图像之前,通常还要再转换成RGB。公式(3)和(4)给出了变换和逆变换的公式。注意系数kg并不存在(因为kb+kg+kr=1),G可以由Y减去Cb,Cr得到,这也说明了Cg分量是不需要保存或传输的。

ITU-R推荐的BT.601中定义kb=0.114,kr=0.299。代入以上的公式就得到下面的转换公式:

       Y=0.299R+0.587G+0.114B

      Cb=0.564(B-Y)                                          (5)      

Cr=0.713(R-Y)                                              


R=Y+1.402Cr                                                

G=Y-0.344Cb-0.714Cr                              (6)

B=Y+1.772Cb                                                

YCbCr的采样格式

1. 4:4:4采样是指每一分量(Y,Cb,Cr)都有相同的分辨率,因为都在所有的像素位置上进行了采样。数字表示的是每一部分在水平方向上的相对采样频率。4:4:4就是指每四个亮度点对应4个Cb和4个Cr。4:4:4采样保留了所有的色差分量。

2. 4:2:2采样格式中(有时又叫YUV2),色差在垂直方向的分辨率与亮度相同,而水平方向只有一半,每四个亮度点对应2个Cb和2个Cr。

3. 4:2:0,即水平方向和垂直方向上Cb,Cr的分辨率都只有亮度的一半。

4:2:0采样有时也被称为“12比特每像素”。例如对于每四个像素点来看,如果使用4:4:4采样则共有12个采样点,Y、Cb、Cr各有四个,一共需要12*8=96比特,平均每个像素96/4=24比特。而使用4:2:0采样,只有6个采样点,Y四个,Cb、Cr各一个,一共需要6*8=48比特,每个像素48/4=12比特。

end。

“生命的终结不是死亡,而是被所爱的人遗忘。”

#《H.264和MPEG-4视频压缩》# 一. 色彩空间的更多相关文章

  1. 03:H.264编码原理以及视频压缩I、P、B帧

    一:前言 H264是新一代的编码标准,以高压缩高质量和支持多种网络的流媒体传输著称,在编码方面,我理解的他的理论依据是:参照一段时间内图像的统计结果表明,在相邻几幅图像画面中, 一般有差别的像素只有1 ...

  2. H.264视频压缩标准

    H.264 这部分一直在讲,但是却没有系统的来说.接下来要详细. 参看:H.264视频压缩标准 一.简介 H.264是最新的视频压缩标准,它也称为MPEG-4 Part 10或AVC(高级视频编码). ...

  3. H.264 与 MPEG-4 压缩格式的变革

    h.264 和 mpeg-4 的关系: h.264 /avc ( advanced video coding )标准,是 mpeg-4 的第 10 部分. mpeg-4的初衷是将dvd质量的图像码流从 ...

  4. H.264码流结构解析

    from:http://wenku.baidu.com/link?url=hYQHJcAWUIS-8C7nSBbf-8lGagYGXKb5msVwQKWyXFAcPLU5gR4BKOVLrFOw4bX ...

  5. #《H.264和MPEG-4视频压缩》# 二. 图像质量

    为了规范.评价.比较不同的视频通信系统,我们需要建立评价图像质量的准则.视觉效果的测量非常困难,而且并不精确,因为影响结果的因素众多.图像质量的认定是一个主观化的东西,许多影响它的因素都难以给出完整而 ...

  6. H.264 / MPEG-4 Part 10 White Paper-翻译

    1. Introduction Broadcast(广播) television and home entertainment(娱乐) have been revolutionised(彻底改变) b ...

  7. H.264简介

    H.264/MPEG-4 AVC (H.264) 是1995年自MPEG-2视频压缩标准发布以后最新的, 最有前途的视频压缩标准. H.264是由ITU-U和ISO/IEC联合开发组共同开发的最新国际 ...

  8. H.264视频的RTP荷载格式

    Status of This Memo This document specifies an Internet standards track protocol for the   Internet ...

  9. 直播一:H.264编码基础知识详解

    一.编码基础概念 1.为什么要进行视频编码? 视频是由一帧帧图像组成,就如常见的gif图片,如果打开一张gif图片,可以发现里面是由很多张图片组成.一般视频为了不让观众感觉到卡顿,一秒钟至少需要16帧 ...

  10. H.264开源解码器评测

    转自:http://wmnmtm.blog.163.com/blog/static/38245714201142883032575/ 要播放HDTV,就首先要正确地解开封装,然后进行视频音频解码.所以 ...

随机推荐

  1. Day7-Python3基础-面向对象进阶

    内容: 面向对象高级语法部分异常处理 经典类vs新式类 静态方法.类方法.属性方法 类的特殊方法 反射 Socket开发基础 面向对象高级语法部分 静态方法       通过@staticmethod ...

  2. vscode中内置集成终端显示为git(bash.exe)

    按下快捷键 ctrl+` (其中的点是esc键下英文状态的点)调出vscode集成终端,也可从菜单栏的“查看→终端”中调出,默认显示的是系统cmd: 在设置中搜索 integrated shell 将 ...

  3. SpringCloud与微服务Ⅴ --- Eureka服务注册与发现

    一.Eureka是什么 Eureka是Netflix的一个子模块,也是核心模块之一.Eureka是一个基于REST的服务,用于定位服务,以实现云端中间层服务发现和故障转移.服务注册与发现对于微服务架构 ...

  4. NodeJS+axios上传图片

    前端js部分 changeEvent (e) { ------ //change事件方法 let oFile = e.target.files[0] ------ //获取文件对象 let param ...

  5. Redis | 使用redis存储对象反序列化异常SerializationFailedException

    案例 使用Redis进行对象存储,在处理业务逻辑的时候,丛Redis获取对象发现反序列化失败,抛出如下异常: Caused by: org.springframework.data.redis.ser ...

  6. [白话解析] Flink的Watermark机制

    [白话解析] Flink的Watermark机制 0x00 摘要 对于Flink来说,Watermark是个很难绕过去的概念.本文将从整体的思路上来说,运用感性直觉的思考来帮大家梳理Watermark ...

  7. 如何使用jmeter做一个功能的性能测试

    一.为什么又再次写类似的文章? 在博客园和公号写文章,已经快两年了,所以自然在公号和博客园都能联系到我的. 也就是几天前,有个人加我微信,对于总有人加我好友,我已经觉得不奇怪了,为什么呢? 加我好友的 ...

  8. Flutter 入门 --- 内部分享

    八月部门给分配的分享任务,由于项目太赶,推迟一个月. 选 Flutter 这个主题,是因为现在它慢慢流行起来了,而我却不了解,故而借此契机,上手试试. 简介 Flutter 是 Google 推出的跨 ...

  9. 深入理解python(一)python语法总结:基础知识和对python中对象的理解

    用python也用了两年了,趁这次疫情想好好整理下. 大概想法是先对python一些知识点进行总结,之后就是根据python内核源码来对python的实现方式进行学习,不会阅读整个源码,,,但是应该会 ...

  10. 【WPF学习】第四十二章 透明

    WPF支持真正的透明效果.这意味着,如果在一个性质或元素上层叠另外几个形状或元素,并让所有这些形状和元素具有不同的透明度,就会看到所期望的效果.通过该特性能够创建透过上面的元素可以看到的的图像背景,这 ...