多数的数字视频应用需要播放彩色的视频信号,所以需要捕获和重现颜色信息。一幅黑白图像的每一个采样点只需要一个像素表示明暗或亮度,而在彩色图像中至少需要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. Linux系统实时数据同步inotify+rsync

    一.inotify简介 inotify是Linux内核的一个功能,它能监控文件系统的变化,比如删除.读.写和卸载等操作.它监控到这些事件的发生后会默认往标准输出打印事件信息.要使用inotify,Li ...

  2. http轮询,长轮询

    轮询,长轮询 轮询 轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接. 优点:后端程序编写比较容易. 缺点:请求中有大半是无用,浪费带宽和服务器资源. 实例:适于小 ...

  3. 如何用Git.io来生成自定义后缀名的短网址

    如何用Git.io来生成自定义后缀名的短网址 git.io是Github的官方短网址,它是用来缩短Github上项目的网址. 效果:Git.io/wacsh将会跳转到https://xhemj.git ...

  4. Zabbix3.4搭建过程

    一.安装之前把firewall 和 selinux关闭. 二.具体的搭建过程可以看zabbix官网的文档,www.zabbix.com(有中文的文档)注意如果复制官网的命令直接使用的话,不会安装mys ...

  5. 安卓开发实战-记账本APP(三)

    本次实现的是有关登录,注册和整体页面的改观,实现下方选项导致页面的切换效果. 利用到的技术有Sqlite数据库的增删改查,与fragment实现.由于暂时没有找到合适的图标,先借用微信的图标暂代一下. ...

  6. 《快乐编程大本营》java语言训练班-第4课:java流程控制

    <快乐编程大本营>java语言训练班-第4课:java流程控制 第1节. 顺序执行语句 第2节. 条件分支语句:if条件语句 第3节. 条件分支语句:switch 条件语句 第4节. 条件 ...

  7. 免费丨十大IT热门学科在线直播体验课正式来袭,全免费!!!

    一场突如其来的疫情阻挡了人与人之间的接触,在这一系列困难面前,无数勇敢的人们挺身而出,千里驰援,默默承担,用行动践行责任与信念,希望与祖国和家人一道共渡难关. 传智播客作为一家致力于“高精尖”IT科技 ...

  8. selenium高级应用 - 结束Windows中浏览器的进程

    结束Windows中浏览器的进程 #-*- coding:utf-8 #结束Windows中浏览器的进程 from selenium import webdriver import unittest ...

  9. Codeforces gym101755H Safe Path(bfs)

    题意: 给以一个网格图,有起点终点和一些怪兽,可以上下左右走,不能走到距离怪兽曼哈顿距离为d以内的地方,问到终点最短路径 n*m<=2e5,d<=2e5 思路: 因为n*m的范围,不能直接 ...

  10. python库之matplotlib学习---关于坐标轴

    首先定·定义x, y创建一个figure import numpy as np import matplotlib.pyplot as plt x = np.linspace(-1, 1, 10) y ...