对x264_macroblock_cache_load的理解
- X264版本: 2004/06/03
- 函数作用:
将编码该宏块所需的信息加载到mb.pic、mb.cache两个结构体中,记录相邻宏块的存在性。
- 函数过程:
- 初始化坐标信息,这些坐标信息将在下面用作下标。
- 加载mb.pic:实质上是加载待编宏块的像素值、宏块在帧内预测时所需的相邻像素值、建立参考帧列表中同一位置宏块的地址列表。
- 加载mb.cache:加载存在的相邻宏块的属性,如宏块类型、预测模式、参考帧号、运动向量、运动向量差等。
- 记录16x16宏块中16个4x4块的可用邻块。
- 一些细节说明:
- 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成分,还有解码时需要的相邻像素值,其内存表示如下图所示(图出处暂缺)。图中,小写代表相邻像素值,大写代表待解码像素值。
- x264_scan8
x264_scan8是一个偏移量查找表。0-15:宏块中16个4x4亮度块的偏移位置;16-19:宏块中4个4x4Cb块的偏移位置;20-23:宏块中4个Cr块的偏移位置。x264_scan8将在mb.cache的很多成员里做下标索引值。
- 坐标说明
请见 http://qiudw1020.blog.163.com/blog/static/120913456200991811025859/
- 记录可用邻块的执行过程说明
先对照宏块里面块的编码数序看
] =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的理解的更多相关文章
- 理解CSS视觉格式化
前面的话 CSS视觉格式化这个词可能比较陌生,但说起盒模型可能就恍然大悟了.实际上,盒模型只是CSS视觉格式化的一部分.视觉格式化分为块级和行内两种处理方式.理解视觉格式化,可以确定得到的效果是应 ...
- 彻底理解AC多模式匹配算法
(本文尤其适合遍览网上的讲解而仍百思不得姐的同学) 一.原理 AC自动机首先将模式组记录为Trie字典树的形式,以节点表示不同状态,边上标以字母表中的字符,表示状态的转移.根节点状态记为0状态,表示起 ...
- 理解加密算法(三)——创建CA机构,签发证书并开始TLS通信
接理解加密算法(一)--加密算法分类.理解加密算法(二)--TLS/SSL 1 不安全的TCP通信 普通的TCP通信数据是明文传输的,所以存在数据泄露和被篡改的风险,我们可以写一段测试代码试验一下. ...
- node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理
一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...
- 如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念
一.前言 DDD(领域驱动设计)的一些介绍网上资料很多,这里就不继续描述了.自己使用领域驱动设计摸滚打爬也有2年多的时间,出于对知识的总结和分享,也是对自我理解的一个公开检验,介于博客园这个平 ...
- 学习AOP之透过Spring的Ioc理解Advisor
花了几天时间来学习Spring,突然明白一个问题,就是看书不能让人理解Spring,一方面要结合使用场景,另一方面要阅读源代码,这种方式理解起来事半功倍.那看书有什么用呢?主要还是扩展视野,毕竟书是别 ...
- ThreadLocal简单理解
在java开源项目的代码中看到一个类里ThreadLocal的属性: private static ThreadLocal<Boolean> clientMode = new Thread ...
- JS核心系列:理解 new 的运行机制
和其他高级语言一样 javascript 中也有 new 运算符,我们知道 new 运算符是用来实例化一个类,从而在内存中分配一个实例对象. 但在 javascript 中,万物皆对象,为什么还要通过 ...
- 深入理解JS 执行细节
javascript从定义到执行,JS引擎在实现层做了很多初始化工作,因此在学习JS引擎工作机制之前,我们需要引入几个相关的概念:执行环境栈.全局对象.执行环境.变量对象.活动对象.作用域和作用域链等 ...
随机推荐
- Google C++ 编程规范总结
一.头文件 #define 的保护 项目 foo 中的头文件 foo/src/bar/baz.h 按如下方式保护: #ifndef FOO_BAR_BAZ_H_ #define FOO_BAR_BAZ ...
- mac搭建PHP开发环境
在Mac系统上搭建Php服务器环境: LAMP: Linux Apache MySQL PHP MAMP: MACOS APACHE(自带) MYSQL(需自己安装) PHP(自带) 一.APACHE ...
- C++问题-无法打开某个自定义源文件
问题经过:需要做一个工具,是在某个产品的基础上做的,所以要来了同事的代码.用VS打开后,提示如下问题.1>c1xx : fatal error C1083: 无法打开源文件:“..\..\GUX ...
- [MAC OSX - 1] OSX10.10不能安装JKD8,不能使用eclipse
(1)电脑升级为10.10后,打开eclipse总是提示"您需要安装旧 Java SE 6 运行环境才能打开"Eclipse". 解决:安装JKD (2)不能安装JK ...
- Linux中监控命令top命令使用方法详解
收集了两篇关于介绍Linux中监控命令top命令的详细使用方法的文章.总的来说,top命令主要用来查看Linux系统的各个进程和系统资源占用情况,在监控Linux系统性能方面top显得非常有用,下面就 ...
- iOS-图片png
把图片添加到工程里面:就报了108个警告!!! 然后我发现我添加的图片有很多命名是这样子的: xcode去找图片的时候是按照什么方式找的呢????? 还发现有好几张同名的图片..... ------- ...
- MVC神韵---你想在哪解脱!(十四)
修正票价字段的精度 前面我们追加数据的时候遗留下来一个问题,就是在追加数据的时候,票价(Price)字段中输入的是9.99元,但是电影清单显示画面中该数据的票价字段显示为10元,这是为什么?这个问题发 ...
- Nginx NLB 及Redis学习
负载均衡: ARR: 微软的应用级别的负载均衡方案 NLB:服务器级别的负载均衡方案 Nginx:反向代理 达到负载均衡. Redis:用作缓存(Redis 主从配置和参数详解 http://www. ...
- memcached构建集群分析之一
memcached本身是不支持集群的,集群所关注的容灾.容错.宕机恢复机制统统都没有,实战中需要自己实现容灾机制. memcached集群相比memcached的优势: 巨量数据分布到集群的多台应用主 ...
- 剑指OFFER之矩形覆盖(九度OJ1390)
题目描述: 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 输入: 输入可能包含多个测试样例,对于每个测试案例, 输入 ...