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. Mahout应用(一)

    Mahout应用(一) Mahout 是应用于hadoop上的数据挖掘工具(废话不多说) 这里先简单介绍一下mahout的一般使用方法. 拿kmeans为列子 Mahout中的kmeans所需要的输入 ...

  2. hadoop HDFS 写入吞吐量

    最近一个项目 在大把大把的使用hadoop-HDFS,关于HDFS 的优势网上都快说烂了,这里不再说了,免得被.. 呵呵 废话少说,开整 1.场景描述: 服务器A 监听 服务器B分发任务socket. ...

  3. -bash: ./radar.sh: /bin/sh^M: bad interpreter: 没有那个文件或目录

    运行shell脚本时,报下面这个错误:   -bash: ./radar.sh: /bin/sh^M: bad interpreter: 没有那个文件或目录 错误分析: 因为操作系统是windows, ...

  4. 最近的bug列表总结(C++)

    最近写了一大段代码,抽象得厉害,容易绕进去,因为写单测的代价很大(借口),所以很多问题到联调的是否才发现. 而且花费了很大的经历才查出来,主要问题有如下几个问题 1. 变量未初始化 具体来说,就是指针 ...

  5. 【转】并发编程之Operation Queue

    http://blog.xcodev.com/blog/2013/10/28/operation-queue-intro/ 随着移动设备的更新换代,移动设备的性能也不断提高,现在流行的CPU已经进入双 ...

  6. C:移位运算符

    1在向右移位时,空出的位是由0填充,还是由符号位的副本填充? 如果被移位的对象是无符号数,那么空出的位将被0填充.如果被位移的对象是有符号数,那么C语言实现既可以用0填充空出的位,也可以用符号位的副本 ...

  7. codeforces 653A Bear and Three Balls

    A. Bear and Three Balls time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  8. Running Solr with Maven

    Solr is an open source search server which is built by using the indexing and search capabilities of ...

  9. myGeneration代码生成器

    转自:http://www.cnblogs.com/leitwolf/archive/2007/07/27/833255.html http://blog.csdn.net/happyhippy/ar ...

  10. MSSQL索引优化

    转自:http://blog.itpub.net/16436858/viewspace-589275/ http://www.cnblogs.com/jams742003/archive/2011/1 ...