1 指数格伦布熵编码算法原理

1.1 无符号整数k阶指数格伦布算法编码过程:

  1) 将数字以二进制形式写出,去掉最低的k个比特位,之后加1
  2) 计算留下的比特数,将此数减一,即是需要增加的前导零个数
  3) 将第一步中去掉的最低k个比特位补回比特串尾部

  例子(1阶指数格伦布算法编码整数9):

  第1步以符号a0表示整数9: a0 = 9;

  第2步将整数9转化为二进制格式表示并以符号a1表示:  a1 = 1001;

  第3步去掉最低1个比特位并保存到符号r0中,剩余部分记作a2:r0 = 1; a2 = 100

  第4步将a2加1并记录为a3:a3 = 101

  第5步a3有3个比特位,减1等于2,所以补2个前导0,以符号a4表示为:a4 = 00101

  第6步将r0中的比特位补到a4的比特位的后面,以符号a5表示: a5 = 001011

  这样无符号整数9最后被编码为001011

1.2 无符号整数k阶指数格伦布算法解码过程:

解析k阶指数哥伦布码时,首先从比特流的当前位置开始寻找第一个非零比特leadingZeroBits,然后根据公式计算出code_num的值:

  code_num = 2^(leadingZeroBits + k) - 2^k + values;

  其中,values为第一个非零比特其后的(leadingZeroBits + k)个比特的值。

例子(1阶指数格伦布算法解码001):leadingZeroBits=2;values=011b=3;code_num=2^3-2^1+3=9

2 H264用到的4种指数哥伦布编码算法

ue(v):无符号指数哥伦布熵编码算法

se(v):有符号指数哥伦布熵编码算法

te(v):截断的指数哥伦布熵编码算法

me(v):映射的指数哥伦布熵编码算法

 注:H264只用了0阶指数哥伦布编码算法,由于其阶数为0所以其有更简化的算解码算法,(针对的是ue即无符号整数)简述如下:

  1)编码算法:将待编码的无符号整数加1,然后转化为二进制表示,计算其二进制位数,然后在前面补二进制位数减1个前缀0,举例:1编码为010,5编码为00110

  2)解码算法:code_num = 2^(leadingZeroBits) - 1 + values,举例:010解码为2^1-1+0=1,00110解码为2^2-1+2=5

  3) 0阶指数哥伦布编码算法即ue(v)编解码过程。

3 se(v)

  1) 编码时先将有符号待编码值转化为无符号待编码值,然后无符号待编码值按ue(v)编码规则编码,其中有符号待编码值转化为无符号待编码值规则为:如果有符号待编码值为正数则乘以2-1,否则直接乘以2以其决对值。举例:-3转化为6,4转化为7

  2)解码时,先用ue(v)解码规则解码,然后将ue(v)输出值记为k,测解码后的有附号解码值为:(–1)k+1 ceil( k÷2 )

4 te(v)

  1) te(v) 只适合非负整数编解码

  2) 编码时先判断待编码值的取值范围的上限,如果大于1,则用ue(v)规则直接编码,否则如果待编码值为1编码后的值为0,如果待编码的值为0则编码后的值为1

  3)解码时先判断待编码值的取值范围的上限,如果大于1,则用ue(v)规则直接解码,否则如果待解码值为1解码后的值为0,如果待解码的值为0则解码后的值为1

5  me(v)

  1) 在H264中用于编码语法元素coded_block_pattern

  2) 编解码时的映射规则参见H264标准9.1.2

总结:H264中采用0阶指数哥伦布编解码算法,其本身即ue(v),其它se(v),te(v),me(v),都是结合其身的规则处理后调用ue(v)完成最终的编解码任务。

H264所采用的指数格伦布熵编码算法原理及应用的更多相关文章

  1. 格伦布编码——rice编码无非是golomb编码M为2^x的特例

    格伦布编码 格伦布编码是一种无失真资料压缩方法,由数学家所罗门·格伦布在1960年代提出. Rice编码 Robert F. Rice提出Rice 编码,是以哥伦布编码为基础做改良而更简易的前置码.R ...

  2. 【视频编解码·学习笔记】7. 熵编码算法:基础知识 & 哈夫曼编码

    一.熵编码概念: 熵越大越混乱 信息学中的熵: 用于度量消息的平均信息量,和信息的不确定性 越是随机的.前后不相关的信息,其熵越高 信源编码定理: 说明了香农熵越信源符号概率之间的关系 信息的熵为信源 ...

  3. 已知长度为n的线性表采用顺序结构,写一算法删除该线性表中所有值为item的元素

    /** * @author:(LiberHome) * @date:Created in 2019/2/27 23:34 * @description: * @version:$ */ /*已知长度为 ...

  4. 【视频编解码·学习笔记】8. 熵编码算法:基本算法列举 & 指数哥伦布编码

    一.H.264中的熵编码基本方法: 熵编码具有消除数据之间统计冗余的功能,在编码端作为最后一道工序,将语法元素写入输出码流 熵解码作为解码过程的第一步,将码流解析出语法元素供后续步骤重建图像使用 在H ...

  5. 【H.264/AVC视频编解码技术具体解释】十三、熵编码算法(4):H.264使用CAVLC解析宏块的残差数据

    <H.264/AVC视频编解码技术具体解释>视频教程已经在"CSDN学院"上线,视频中详述了H.264的背景.标准协议和实现,并通过一个实战project的形式对H.2 ...

  6. celery-分布式任务队列-原理

    # 转自:https://www.cnblogs.com/forward-wang/p/5970806.html 在学习Celery之前,我先简单的去了解了一下什么是生产者消费者模式. 生产者消费者模 ...

  7. LeetCode算法题解

    1.给定两个正整数(二进制形式表示)A和B,问把A变为B需要改变多少位(bit)?也就是说,整数A和B的二进制表示中有多少位是不同的?(181) 解法一:举例说明,为了减少复杂度,就使用八位二进制吧. ...

  8. simhash文章排重

    原文链接:https://www.cnblogs.com/baochuan/p/9089244.html  背景     提升产品体验,节省用户感知度.——想想,如果看到一堆相似性很高的新闻,对于用户 ...

  9. h264 profile & level

    转自:http://blog.csdn.net/sphone89/article/details/17492433 H.264 Profiles H.264有四种profile,每个profile支持 ...

随机推荐

  1. 深入浅出 ThreadLocal(一)

    本文参考http://lavasoft.blog.51cto.com/62575/51926/,对其中的程序进行了改写 一.概述 ThreadLocal是什么呢?其实ThreadLocal并非是一个线 ...

  2. 给Activity切换加入动画

    在startActivity或finish()后,调用overridePendingTransition方法,可以加入动画效果.例如: 使用Android自带的淡入淡出:android.R.anim. ...

  3. iOS 测试驱动开发

    测试驱动开发是敏捷开发的一部分,它一般有“red-green- refactor”步骤 iOS测试驱动开发的工具 一. OCUnit 是Xcode自带的测试工具 其使用步骤分为 1 建立测试的Targ ...

  4. C语言面试题汇总

    1.   阅读下面程序并写出输出结果(10分). main() { int a[5]={1,2,3,4,5}; int *ptr=(int *)(&a+1); printf("%d, ...

  5. C#通过外部别名,解决DLL冲突问题

    今天遇到一个有两个DLL文件,命名空间,部分类名与部分方法名一样,但是方法的功能实现不一样.调用方法时,无法调用指定DLL的指定方法.在网上找了好多,简单总结一下. 1.首先添加引用,不细说. 2.右 ...

  6. Windows Server 2003下配置IIS6.0+php5+MySql5+PHPMyAdmin环境

    配置环境: 操作系统:Windows Server 2003 sp2企业版 Web服务器:系统自带的IIS6.0 所需工具: PHP:php-5.2.12-Win32.zip(官方网址:http:// ...

  7. Robot Framework使用技巧

    1.变量的使用 变量可以在命令行中设置,个别变量设置使用--variable (-v)选项,变量文件的选择使用--variablefile (-V)选项.通过命令行设置的变量是全局变量,对其所有执行的 ...

  8. C# 无边框窗口实现拖动

    原文地址:http://blog.csdn.net/sky___ice/article/details/11533321 Form1.Designer.cs: // //Form1 // this.M ...

  9. js中角度计算

    -. js 关于三角函数算法  弧度 和 角度的理解, 以及相互转换   角的两种单位 度 和 弧      1.弧度的定义       我们知道"度"的定义是,"两条射 ...

  10. Leetcode-33-Search in Rotated Sorted Array (Hard)

    二分查找算法以及旋转之后的数组二分查找算法: #!/usr/local/bin/python3 # -*- coding: utf-8 -*- __author__ = 'author' class ...