请问什么是算术编码
发布网友
发布时间:2022-04-20 15:56
我来回答
共1个回答
热心网友
时间:2023-12-06 02:39
上面对算术编码的解释进行了一些简化。尤其是,这种写法看起来好像算术编码首先使用无限精度精度的数值计算总体上表示最后节点的分数,然后在编码结束的时候将这个分数转换成最终的形式。许多算术编码器使用优先精度的数值计算,而不是尽量去模拟无限精度,因为它们知道解码器能够匹配、并且将所计算的分数在那个精度四舍五入到对应值。一个例子能够说明一个模型要将间隔[0,1]分成三份并且使用8位的精度来实现。注意既然精度已经知道,我们能用的二进制数值的范围也已经知道。
一个称为再归一化的过程使有限精度不再是能够编码的字符数目的*。当范围减小到范围内的所有数值共享特定的数字时,那些数字就送到输出数据中。尽管计算机能够处理许多位数的精度,编码所用位数少于它们的精度,这样现存的数据进行左移,在右面添加新的数据位以尽量扩展能用的数据范围。注意这样的结果出现在前面三个例子中的两个里面。 许多算术编码所用的不同方法受美国专利的保护。其中一些专利对于实现一些国际标准中定义的算术编码算法是很关键的。在这种情况下,这些专利通常按照一种合理和非歧视(RAND)授权协议使用(至少是作为标准委员会的一种策略)。在一些著名的案例中(包括一些涉及 IBM的专利)这些授权是免费的,而在另外一些案例中,则收取一定的授权费用。RAND条款的授权协议不一定能够满足所有打算使用这项技术的用户,因为对于一个打算生产拥有所有权软件的公司来说这项费用是“合理的”,而对于自由软件和开源软件项目来说它是不合理的。
在算术编码领域做了很多开创性工作并拥有很多专利的一个著名公司是IBM。一些分析人士感到那种认为没有一种实用并且有效的算术编码能够在不触犯IBM和其它公司拥有的专利条件下实现只是数据压缩界中的一种持续的urban legend(尤其是当看到有效的算术编码已经使用了很长时间最初的专利开始到期)。然而,由于专利法没有提供“明确界线”测试所以一种威慑心理总让人担忧法庭将会找到触犯专利的特殊应用,并且随着对于专利范围的详细审查将会发现一个不好的裁决将带来很大的损失,这些技术的专利保护然而对它们的应用产生了一种阻止的效果。至少一种重要的压缩软件bzip2,出于对于专利状况的担心,故意停止了算术编码的使用而转向Huffman编码。
关于算术编码的美国专利列在下面。
Patent 4,122,440 — (IBM) 提交日期 March 4, 1977, 批准日期 Oct 24, 1978 (现在已经到期)
Patent 4,286,256 — (IBM) 批准日期 Aug 25, 1981 (大概已经到期)
Patent 4,467,317 — (IBM) 批准日期 Aug 21, 1984 (大概已经到期)
Patent 4,652,856 — (IBM) 批准日期 Feb 4, 1986 (大概已经到期)
Patent 4,891,643 — (IBM) 提交时间 1986/09/15, 批准日期 1990/01/02
Patent 4,905,297 — (IBM) 批准日期 Feb 27, 1990
Patent 4,933,883 — (IBM) 批准日期 Jun 12, 1990
Patent 4,935,882 — (IBM) 批准日期 Jun 19, 1990
Patent 4,989,000 — (???) 提交时间 1989/06/19, 批准日期 1991/01/29
Patent 5,099,440
Patent 5,272,478 — (Ricoh)
注意:这个列表没有囊括所有的专利。关于更多的专利信息请参见后面的链接。
算术编码的专利可能在其它国家司法领域存在,参见软件专利中关于软件在世界各地专利性的讨论。
请问什么是算术编码
1
论述什么是信源编码、信道编码?
最原始的信源编码就是莫尔斯电码,另外还有ASCII码和电报码都是信源编码。但现代通信应用中常见的信源编码方式有:Huffman编码、算术编码、L-Z编码,这三种都是无损编码,另外还有一些有损的编码方式。信源编码的目标就是使信源减少冗余,更加有效、经济地传输,最常见的应用形式就是压缩。另外,在数字电...
如何进行算术解码
o: (0.6, 0.8)u: (0.8, 0.9)!: (0.9, 1.0)然后你看0.32256落在哪个区间,就是哪个字符,现在它落在(0.2, 0.5)之内,所以第一个字符是e 然后再把e的(0,2, 0.5)按照概率分成6分,再看0.32256落在哪个范围内,以此类推 当然,算术编码有一些变种,比如概率是否是自适应性...
请问dzip是什么软件?
4、算术编码:算术编码是一种将数据表示为实数的方法,其中较常见的序列被赋予较低的数字,较不常见的序列被赋予较高的数字。这种方法有助于压缩大量数据。5、熵编码:熵编码是无损数据压缩的一种形式,它利用了数据的熵(即数据的随机性或混乱程度)。这种方法通常用于图像和音频压缩,因为它可以有效地...
信源编码、信道编码的区别是什么?
2,信源编码的作用一是将模拟信号转化为数字信号,二是对数据进行压缩;信道编码则是通过添加一定的校验位,来提高码自身的纠错能力的手段。不管你在什么通信中,信道编码的目的都是为了传输的可靠性。信道编码和信源编码的差别是,信源编码考虑的是如何编码能够尽量利用信道,好的信源编码可以达到信道容量...
请问DjVu的编码格式,谁有描述?代码?
DjVu图像压缩格式:DjVu图像压缩格式包含多个子格式,如IW44、JB2、JBZ、JBIG2等,用于实现不同的压缩算法。其中,JB2格式是最常用的一种。它是一种二进制图像压缩格式,将图像分成多个小块,压缩每个小块的像素值和运动信息,并使用一些技术,如哈夫曼编码、上下文建模、算术编码等,将压缩后的数据进行...
请问有关"手机中的图像压缩技术"这个题目,谁有资料可以告诉我一下么...
经常使用的无损压缩方法有Shannon-Fano编码法、Huffman编码法、游程(Run-length)编码法、LZW编码法(Lempel-Ziv-Welch)和算术编码法等。数据压缩研究中应注意的问题是,首先,编码方法必须能用计算机或VLSI硬件电路高速实现;其次,要符合当前的国际标准。下面介绍三种流行的数据压缩国际标准。1、JPEG-静止图像压缩标准这是...
在网上下载的1080高清影片的视听效果是不是和那种正版蓝光碟子一模一...
H.264中熵编码有两种方法,一种是对所有的待编码的符号采用统一的VLC(UVLC :Universal VLC),另一种是采用内容自适应的二进制算术编码(CABAC:Context-Adaptive Binary Arithmetic Coding)。CABAC是可选项,其编码性能比UVLC稍好,但计算复杂度也高。UVLC使用一个长度无限的码字集,设计结构非常有规则,用相同的码表可以对...
谁能详细介绍一下各种高清视频格式?
H.264中熵编码有两种方法,一种是对所有的待编码的符号采用统一的VLC(UVLC :Universal VLC),另一种是采用内容自适应的二进制算术编码(CABAC:Context-Adaptive Binary Arithmetic Coding)。CABAC是可选项,其编码性能比UVLC稍好,但计算复杂度也高。UVLC使用一个长度无限的码字集,设计结构非常有规则,用相同的码表可以对...
请问“压缩质量比”该怎么算?
4.编码(有算术编码和霍夫曼编码两种,这里采用霍夫曼编码),用VB语言编程实现以上四个步骤,即完成了JPEG压缩过程,这里假设给定的源图像是一幅24位真彩色的BMP图像。 一、颜色转换及采样 1.颜色转换:对BMP图像中的颜色数据进行由RGB一YCbCr的转换,Y表示亮度,CbCr分别表示蓝色度和红色度。 转换公式: Y=0.2990R+0.5...