1. X264版本: 2004/06/03
  2. 函数作用:

将编码该宏块所需的信息加载到mb.pic、mb.cache两个结构体中,记录相邻宏块的存在性。

  1. 函数过程:
    1. 初始化坐标信息,这些坐标信息将在下面用作下标。
    2. 加载mb.pic:实质上是加载待编宏块的像素值、宏块在帧内预测时所需的相邻像素值、建立参考帧列表中同一位置宏块的地址列表。
    3. 加载mb.cache:加载存在的相邻宏块的属性,如宏块类型、预测模式、参考帧号、运动向量、运动向量差等。
    4. 记录16x16宏块中16个4x4块的可用邻块。
  2. 一些细节说明:
    1. mp.pic.p_fenc与mp.pic.p_fdec的数据存储格式

    mp.pic.p_fenc[3]分别存储待编宏块的Y/U/V成分,其内存表示如下图所示。图中,Y/B/R分别代表Y/U/V的一个4X4像素点阵。

YYYY

YYYY

YYYY

YYYY

BBRR

BBRR

    mp.pic.p_fdec[3]分别存储待解码宏块的Y/U/V成分,还有解码时需要的相邻像素值,其内存表示如下图所示(图出处暂缺)。图中,小写代表相邻像素值,大写代表待解码像素值。

  1. x264_scan8

    x264_scan8是一个偏移量查找表。0-15:宏块中16个4x4亮度块的偏移位置;16-19:宏块中4个4x4Cb块的偏移位置;20-23:宏块中4个Cr块的偏移位置。x264_scan8将在mb.cache的很多成员里做下标索引值。

  1. 坐标说明

    请见 http://qiudw1020.blog.163.com/blog/static/120913456200991811025859/

  1. 记录可用邻块的执行过程说明

先对照宏块里面块的编码数序看

] =h->mb.i_neighbour8[0] = (h->mb.i_neighbour & (MB_TOP|MB_LEFT|MB_TOPLEFT)) | ((h->mb.i_neighbour & MB_TOP) ? MB_TOPRIGHT : 0);

  的左、上、左上、右上参考块都不确定.但是为什么把TOPRIGHT单独列出来呢,如上图位置关系,0块就是当TOP有效时,TOPRIGHT才有效。以下同理。

] =h->mb.i_neighbour4[1] = MB_LEFT
| ((h->mb.i_neighbour & MB_TOP) ? (MB_TOP|MB_TOPLEFT|MB_TOPRIGHT) : 0);

、的左参考块确定,而上、左上、右上参考块都不确定

] =

h->mb.i_neighbour4[] =

h->mb.i_neighbour4[] =

h->mb.i_neighbour8[] = MB_TOP|MB_TOPRIGHT
| ((h->mb.i_neighbour & MB_LEFT) ? (MB_LEFT|MB_TOPLEFT) : 0);

  、、的上、右上参考块确定,而左、左上参考块都不确定

] =

h->mb.i_neighbour4[] = 

h->mb.i_neighbour4[] = 

h->mb.i_neighbour4[] =

h->mb.i_neighbour4[] = 

h->mb.i_neighbour8[3] = MB_LEFT|MB_TOP|MB_TOPLEFT;

这里有点让我看不懂,、、好理解,、、、的右上和0的右上是不同的,宏块编码顺序和块的编码顺序也是一样的,0的右上是右上角的宏块,而7、、的右上是右边的宏块。右边的宏块总是在左边的宏块之后编码。如下图宏块1在宏块2之前编码,宏块3在宏块2之后编码。)
、有点让人看不懂,、、放一起呢?
如果看下编码顺序就不难发现了,是在、、放在一起了。(11同理)

] =h->mb.i_neighbour8[1] = MB_LEFT | (h->mb.i_neighbour & MB_TOPRIGHT) | ((h->mb.i_neighbour & MB_TOP) ? MB_TOP|MB_TOPLEFT : 0);

  5左参考块确定,上、左上、右上参考块都不确定

] =

h->mb.i_neighbour4[] =

h->mb.i_neighbour4[] =

h->mb.i_neighbour4[] = MB_LEFT|MB_TOP|MB_TOPLEFT|MB_TOPRIGHT;

对x264_macroblock_cache_load的理解的更多相关文章

  1. 理解CSS视觉格式化

    前面的话   CSS视觉格式化这个词可能比较陌生,但说起盒模型可能就恍然大悟了.实际上,盒模型只是CSS视觉格式化的一部分.视觉格式化分为块级和行内两种处理方式.理解视觉格式化,可以确定得到的效果是应 ...

  2. 彻底理解AC多模式匹配算法

    (本文尤其适合遍览网上的讲解而仍百思不得姐的同学) 一.原理 AC自动机首先将模式组记录为Trie字典树的形式,以节点表示不同状态,边上标以字母表中的字符,表示状态的转移.根节点状态记为0状态,表示起 ...

  3. 理解加密算法(三)——创建CA机构,签发证书并开始TLS通信

    接理解加密算法(一)--加密算法分类.理解加密算法(二)--TLS/SSL 1 不安全的TCP通信 普通的TCP通信数据是明文传输的,所以存在数据泄露和被篡改的风险,我们可以写一段测试代码试验一下. ...

  4. node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理

    一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...

  5. 如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念

    一.前言     DDD(领域驱动设计)的一些介绍网上资料很多,这里就不继续描述了.自己使用领域驱动设计摸滚打爬也有2年多的时间,出于对知识的总结和分享,也是对自我理解的一个公开检验,介于博客园这个平 ...

  6. 学习AOP之透过Spring的Ioc理解Advisor

    花了几天时间来学习Spring,突然明白一个问题,就是看书不能让人理解Spring,一方面要结合使用场景,另一方面要阅读源代码,这种方式理解起来事半功倍.那看书有什么用呢?主要还是扩展视野,毕竟书是别 ...

  7. ThreadLocal简单理解

    在java开源项目的代码中看到一个类里ThreadLocal的属性: private static ThreadLocal<Boolean> clientMode = new Thread ...

  8. JS核心系列:理解 new 的运行机制

    和其他高级语言一样 javascript 中也有 new 运算符,我们知道 new 运算符是用来实例化一个类,从而在内存中分配一个实例对象. 但在 javascript 中,万物皆对象,为什么还要通过 ...

  9. 深入理解JS 执行细节

    javascript从定义到执行,JS引擎在实现层做了很多初始化工作,因此在学习JS引擎工作机制之前,我们需要引入几个相关的概念:执行环境栈.全局对象.执行环境.变量对象.活动对象.作用域和作用域链等 ...

随机推荐

  1. redis的lists类型

    List是一个链表结构 , 主要功能是push . pop .获取一个范围的所有值等等 , 操作中key理解为链表的名字 . redis 的 list类型其实就是一个每个子元素都是string类型的双 ...

  2. 一些常用的IOS开发网站

    开发教程: 即便过了入门阶段,还是要经常看看一些不错的实例教程.1.http://mobile.tutsplus.com/category/tutorials/iphone/ 比较新的一个网站,以前没 ...

  3. RHEL安装配置JAVA

    查看当前java版本 [root@esb-mmplus-04 ~]# java -version java version "1.6.0_24" OpenJDK Runtime E ...

  4. TQJson序列和还原clientdataset.data

    TQJson是QDAC开源项目的JSON对象,其特点是跨平台,功能强大. 序列 procedure TForm2.Button2Click(Sender: TObject);var AJson: TQ ...

  5. 微软企业库5.0学习-Security.Cryptography模块

    一.微软企业库加密应用模块提供了两种加密: 1.Hash providers :离散加密,即数据加密后无法解密 2.Symmetric Cryptography Providers:密钥(对称)加密法 ...

  6. EF入门 IQueryable和IEnumberable的区别

    IEnumerable接口 公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代.也就是说:实现了此接口的object,就可以直接使用foreach遍历此object: IQueryable 接口 ...

  7. POJ1189钉子和小球(DP)

    对钉子DP,如果钉子存在DP[i+1][j]+=DP[i][j]; DP[i+1][j+1]+=DP[i][j]; 如果不存在DP[i+2][j+1]+=4*DP[i][j]; 见代码:(有一个比较坑 ...

  8. jquery页面加载的时候加载函数

    http://blog.csdn.net/tjcyjd/article/details/6713474 jQuery 页面加载初始化的方法有3种 ,页面在加载的时候都会执行脚本,应该没什么区别,主要看 ...

  9. Java学习笔记(四):流程控制

    if语句 if判断语句比较简单,具体有下面的几种写法: int i = 0; // if 判断 if (i == 0) { // to do something } // if else 判断 if ...

  10. Lua学习笔记(五):面向对象的实现

    Lua本身是没有class之类的关键字的,但是我们可以巧妙利用function也是值和table的特性来实现面向对象的特性. 通过复制表的实现 Lua中的类也是一个table对象,下面我们看看一个简单 ...