(JPEG)编码算法及压缩过程的实现

合集下载

JPEG2000图像压缩算法标准

JPEG2000图像压缩算法标准

JPEG2000图像压缩算法标准摘要:JPEG2000是为适应不断发展的图像压缩应用而出现的新的静止图像压缩标准。

本文介绍了JPEG2000图像编码系统的实现过程, 对其中采用的基本算法和关键技术进行了描述,介绍了这一新标准的特点及应用场合,并对其性能进行了分析。

关键词:JPEG2000;图像压缩;基本原理;感兴趣区域引言随着多媒体技术的不断运用,图像压缩要求更高的性能和新的特征。

为了满足静止图像在特殊领域编码的需求,JPEG2000作为一个新的标准处于不断的发展中。

它不仅希望提供优于现行标准的失真率和个人图像压缩性能,而且还可以提供一些现行标准不能有效地实现甚至在很多情况下完全无法实现的功能和特性。

这种新的标准更加注重图像的可伸缩表述。

所以就可以在任意给定的分辨率级别上来提供一个低质量的图像恢复,或者在要求的分辨率和信噪比的情况下提取图像的部分区域。

1.JPEG2000的基本介绍及优势相信大家对JPEG这种图像格式都非常熟悉,在我们日常所接触的图像中,绝大多数都是JPEG格式的。

JPEG的全称为Joint Photographic Experts Group,它是一个在国际标准组织(ISO)下从事静态图像压缩标准制定的委员会,它制定出了第一套国际静态图像压缩标准:ISO 10918-1,俗称JPEG。

由于相对于BMP等格式而言,品质相差无己的JPEG格式能让图像文件“苗条”很多,无论是传送还是保存都非常方便,因此JPEG格式在推出后大受欢迎。

随着网络的发展,JPEG的应用更加广泛,目前网站上80%的图像都采用JPEG格式。

但是,随着多媒体应用领域的快速增长,传统JPEG压缩技术已无法满足人们对数字化多媒体图像资料的要求:网上JPEG图像只能一行一行地下载,直到全部下载完毕,才可以看到整个图像,如果只对图像的局部感兴趣也只能将整个图片载下来再处理;JPEG格式的图像文件体积仍然嫌大;JPEG格式属于有损压缩,当被压缩的图像上有大片近似颜色时,会出现马赛克现象;同样由于有损压缩的原因,许多对图像质量要求较高的应用JPEG无法胜任。

图像压缩算法原理:JPEG、PNG等压缩方式

图像压缩算法原理:JPEG、PNG等压缩方式

图像压缩算法原理:JPEG、PNG等压缩方式图像压缩算法旨在减小图像文件的大小,同时保持尽可能多的图像质量。

JPEG(Joint Photographic Experts Group)和PNG(Portable Network Graphics)是两种常见的图像压缩方式,它们有不同的原理和适用场景。

JPEG 压缩算法原理:离散余弦变换(DCT): JPEG 使用离散余弦变换将图像从空间域变换到频域。

DCT将图像分解为一系列频率分量,允许更多的信息被聚焦在低频分量上,这些低频分量对人眼更敏感。

量化:在DCT之后,通过量化将每个频率分量的数值映射为一个较低的精度。

高频分量被更多地量化为零,从而进一步减小数据。

哈夫曼编码:使用哈夫曼编码对量化后的数据进行熵编码。

哈夫曼编码对常见的值使用较短的编码,对不常见的值使用较长的编码,以进一步减小文件大小。

色彩空间转换: JPEG通常将RGB颜色空间转换为YCbCr颜色空间,其中Y表示亮度(灰度),Cb和Cr表示色度(颜色信息)。

这样可以将图像的亮度和色度分离,使得在色度上的降采样更容易。

PNG 压缩算法原理:无损压缩:与JPEG不同,PNG是一种无损压缩算法,它保留了原始图像的每一个像素的精确信息。

这使得PNG适用于需要完整性的图像,如图标、图形等。

差分预测: PNG使用差分预测(Delta Predictive Coding)来减小冗余。

通过预测每个像素值与其周围像素值之间的差异,PNG可以用较小的数据表示图像。

LZ77压缩: PNG使用LZ77算法进行数据压缩。

该算法通过查找并用指向先前出现的相似数据的指针替换当前数据,从而减小文件大小。

无调色板和透明度支持: PNG支持真彩色图像,并且可以存储图像的透明度信息。

这使得PNG在需要保留图像质量的同时支持透明背景。

总体而言,JPEG适用于需要较小文件大小,且可以容忍一些信息损失的场景,而PNG适用于需要无损压缩和透明度支持的场景。

jpeg 编码原理 -回复

jpeg 编码原理 -回复

jpeg 编码原理-回复JPEG(Joint Photographic Experts Group)是一种图像压缩算法,被广泛应用于数字图像的存储和传输中。

JPEG编码原理是将图像分块、转换为频域表示、量化和熵编码等一系列步骤的组合,以尽可能地减小图像文件的大小同时保持图像质量。

JPEG编码的步骤如下:1. 图像分块:JPEG编码将输入图像划分为8×8个像素的块,每个块都经过单独的处理。

这样的划分能够更好地保持图像的局部特征,并使得后续的处理更加有效。

2. 转换为频域表示:每个划分的图像块通过应用离散余弦变换(Discrete Cosine Transform,DCT)来转换为频域表示。

DCT能够将像素值的空域表示转换为一系列频率分量的频域表示。

经过DCT变换后,低频分量会集中在左上角,而高频分量则分布在右下角。

3. 量化:DCT变换后得到的频域表示,对于高频分量的维度信息对图像视觉感知的贡献较小。

因此,JPEG采用了量化表来将高频分量进行抑制。

量化过程即通过除以一个量化矩阵,将频域表示的每个系数分量变为整数。

4. 压缩和熵编码:通过量化后的频域表示得到的整数系数矩阵,一般情况下会有许多零值,这是由于量化矩阵的零值化导致的。

这些零值可以被很好地压缩。

JPEG 采用了霍夫曼编码来实现熵编码,通过对系数的零值进行编码,从而将图像数据进行高效的压缩。

5. 解码:JPEG解码是编码过程的逆过程。

解码时,将经过熵编码的图像数据解压为量化后的频域表示系数。

然后通过反量化和反DCT变换得到每个图像块的空域表示。

最后,将所有块合并,得到完整的解码图像。

JPEG编码通过利用人类视觉系统的特性来设计其压缩算法,使得图像在被压缩的同时尽量减少人眼可察觉的细节损失。

这使得JPEG编码成为了一种非常常见的图像压缩算法,被广泛应用于数字图像的存储、传输和显示中。

无论是从存储空间的角度考虑,还是为了在网络中高效传输图像数据,JPEG编码都在图像处理中扮演着关键的角色。

JPEG图像压缩算法基本介绍

JPEG图像压缩算法基本介绍

JPEG图像压缩算法基本介绍JPEG压缩算法可以用失真的压缩方式来处理图像,但失真的程度却是肉眼所无法辩认的。

这也就是为什么JPEG会有如此满意的压缩比例的原因。

下面主要讨论,JPEG基本压缩法。

一、图像压缩算法之JPEG压缩过程JPEG压缩分四个步骤实现:1.颜色模式转换及采样;2.DCT变换;3.量化;4.编码。

二、图像压缩算法具体操作1、图像压缩算法之颜色模式转换及采样RGB色彩系统是我们最常用的表示颜色的方式。

JPEG采用的是YCbCr色彩系统。

想要用JPEG基本压缩法处理全彩色图像,得先把RGB颜色模式图像数据,转换为YCbCr颜色模式的数据。

Y代表亮度,Cb和Cr则代表色度、饱和度。

通过下列计算公式可完成数据转换。

Y=0.2990R+0.5870G+0.1140BCb=-0.1687R-0.3313G+0.5000B+128Cr=0.5000R-0.4187G-0.0813B+128人类的眼晴对低频的数据比对高频的数据具有更高的敏感度,事实上,人类的眼睛对亮度的改变也比对色彩的改变要敏感得多,也就是说Y成份的数据是比较重要的。

既然Cb成份和Cr成份的数据比较相对不重要,就可以只取部分数据来处理。

以增加压缩的比例。

JPEG 通常有两种采样方式:YUV411和YUV422,它们所代表的意义是Y、Cb和Cr三个成份的数据取样比例。

2、图像压缩算法之DCT变换DCT变换的全称是离散余弦变换(Discrete Cosine Transform),是指将一组光强数据转换成频率数据,以便得知强度变化的情形。

若对高频的数据做些修饰,再转回原来形式的数据时,显然与原始数据有些差异,但是人类的眼睛却是不容易辨认出来。

压缩时,将原始图像数据分成8*8数据单元矩阵,例如亮度值的第一个矩阵内容如下:JPEG将整个亮度矩阵与色度Cb矩阵,饱和度Cr矩阵,视为一个基本单元称作MCU。

每个MCU所包含的矩阵数量不得超过10个。

JPEG文件解码详解

JPEG文件解码详解

JPEG文件解码详解JPEG(Joint Photographic Experts Group)是联合图像专家小组的英文缩写。

它由国际电话与电报咨询委员会CCITT(The International Telegraph and Telep hone Consultative Committee)与国际标准化组织ISO于1986年联合成立的一个小组,负责制定静态数字图像的编码标准。

小组一直致力于标准化工作,开发研制出连续色调、多级灰度、静止图像的数字图像压缩编码方法,即JPEG算法。

JPEG算法被确定为国际通用标准,其适用范围广泛,除用于静态图像编码外,还推广到电视图像序列的帧内图像压缩。

而用JPEG算法压缩出来的静态图片文件称为JPEG文件,扩展名通常为*.jpg、*. jpe、*.jpeg。

JPEG专家组开发了两种基本的压缩算法、两种数据编码方法、四种编码模式。

具体如下:压缩算法:●有损的离散余弦变换(Discrete Cosine Transform,DCT);●无损的预测技术压缩。

数据编码方法:●哈夫曼编码;●算术编码;编码模式:●基于DCT顺序模式:编/解码通过一次扫描完成;●基于DCT递进模式:编/解码需要多次扫描完成,扫描效果从粗糙到精细,逐级递进;●无损模式:基于DPCM,保证解码后完全精确恢复到原图像采样值;●层次模式:图像在多个空间多种分辨率进行编码,可以根据需要只对低分辨率数据作解码,放弃高分辨率信息。

在实际应用中,JPEG图像使用的是离散余弦变换、哈夫曼编码、顺序模式。

JPEG压缩编码算法的主要计算步骤如下:(0) 8*8分块。

(1) 正向离散余弦变换(FDCT)。

(2) 量化(quantization)。

(3) Z字形编码(zigzag scan)。

(4) 使用差分脉冲编码调制(DPCM)对直流系数(DC)进行编码。

(5) 使用行程长度编码(RLE)对交流系数(AC)进行编码。

JPEG图像压缩与编码解析

JPEG图像压缩与编码解析

JPEG图像压缩与编码解析
JPEG(Joint Photographic Experts Group)压缩格式,以其易于使用、压缩率高而著称,是应用最为广泛的一种图像压缩格式。

JPEG压缩
算法把图像分为内容和质量两个维度来进行压缩。

下面将详细论述JPEG
图像编码与解码的基本原理。

1.JPEG图像编码过程
(1)空间域转换
空间域转换是将原始图像由空间域变换成更加节省存储空间的频域。

JPEG压缩采用的是离散余弦变换(DCT)这种空间域转换方法,它可以把
图像表示成一系列正交基函数的线性组合,每一个函数表示的是对应的图
像量化值。

利用DCT将一幅图像分成8×8(也有可能是16×16)大小的块,每一个块由64(或者256)个相互独立的像素构成,被称为DCT子块。

(2)频段选择
JPEG图像压缩算法采用频段选择的原则,根据图像中的特征,把空
间域转换之后的低频分量即低频信息传��有损,而只把高频分量即高频
信息传递以达到保留重要信息的目的,在JPEG中,特征的保留按照“从
重要的到不重要的”的顺序进行。

(3)变换。

jpeg编码原理

jpeg编码原理

JPEG编码原理1. 简介JPEG是一种常见的图像压缩算法,它能够将图像文件的大小大幅度压缩,同时保持图像质量。

JPEG编码原理是指将图像从原始的RGB色彩空间转换为亮度和色度分量,并对这些分量进行离散余弦变换(DCT)和量化,最后使用熵编码进行压缩。

2. RGB到YCbCr色彩空间的转换JPEG编码首先将图像从RGB色彩空间转换为YCbCr色彩空间。

RGB色彩空间由红色、绿色和蓝色三个分量组成,而YCbCr色彩空间由亮度(Y)分量和两个色度(Cb和Cr)分量组成。

转换公式如下:Y = 0.299R + 0.587G + 0.114BCb = -0.1687R - 0.3313G + 0.5B + 128Cr = 0.5R - 0.4187G - 0.0813B + 128其中R、G、B分别为原始图像的红色、绿色和蓝色分量。

3. 亮度和色度分量的子采样亮度分量对图像的细节表示更为重要,而色度分量对颜色信息的表示更为重要。

为了进一步减小图像文件的大小,JPEG编码会对色度分量进行子采样。

常见的子采样方法有4:2:0和4:2:2。

4:2:0子采样表示每个4x4像素块中,亮度分量有16个样本值,而色度分量Cb和Cr分别有4个样本值。

4:2:2子采样表示每个4x2像素块中,亮度分量有8个样本值,而色度分量Cb和Cr分别有2个样本值。

4. 离散余弦变换(DCT)离散余弦变换(DCT)是JPEG编码中的核心步骤,它将图像数据从空间域转换为频域。

DCT通过将亮度和色度分量划分成8x8的非重叠块,并对每个块进行DCT变换。

DCT将每个块中的像素值分解为一系列不同频率的余弦函数。

这样做的目的是提取图像中的重要频率分量,将高频分量置零以实现压缩。

5. 量化量化是JPEG编码中的另一个重要步骤,它通过将DCT系数除以一个量化表中对应的量化因子将图像数据进一步压缩。

量化因子的值越大,表示对该频域系数的量化程度越强,从而导致更多的数据被丢弃。

JPEG图像数据格式简明分析

JPEG图像数据格式简明分析

总结
总的来说,JPEG图像数据格式凭借其高压缩比、兼容性强和适用范围广等优 点,成为图像处理、数字摄影、网络传输和科学数据可视化等领域的首选格式。 然而,我们也应意识到其存在的损失细节和速度较慢等缺点。未来,随着技术的 不断发展和新的图像格式的出现,JPEG可能会面临挑战。但就目前而言,JPEG仍 然是图像处理和存储领域的重要支柱。
3、离散余弦变换:接下来,图像数据将经过离散余弦变换(DCT)。DCT将 图像的像素值从空间域转换到频域,使得图像的能量集中在一些低频区域。
4、量化和编码:在完成DCT后,JPEG算法对DCT系数进行量化,将它们转换 为更小的值。然后对这些值进行编码,以产生最终的压缩数据。编码过程中使用 的哈夫曼编码(Huffman Coding)是一种无损压缩技术,它可以根据数据的统计 特性来生成更短的编码。
%读取原始图像
%将原始图像转换为灰度图像
%对灰度图像进行DCT变换
%设定量化表
quantization_table = [16 11 10 16 24 40 51 61;
12 12 14 19 26 58 60 55;
14 13 16 24 40 57 69 56;
14 17 22 29 51 87 80 62;
参考内容
JPEG静态图像压缩算法是一种重要的数字图像处理技术,它通过去除图像中 的冗余信息来减小图像的文件大小,从而方便了图像的存储和传输。JPEG算法采 用了一种基于离散余弦变换(DCT)的压缩方法,将图像数据转化为一种更有效 的表示形式,从而实现了图像的压缩。
JPEG算法主要由以下几个步骤构成:
组成结构
JPEG图像数据格式的组成结构包括三个主要部分:头部、图像部分和尾部。 头部包含关于图像的一些基本信息,如文件号、量化表、色彩空间等。图像部分 是实际的图像数据,包括经DCT变换和量化的像素值。尾部包含一些附加信息, 如压缩方法、图像大小等。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1
1.1.2 图象压缩的几种方法 1.统计和字典的压缩方法 常规程序和计算机熵的数据对于那些基于利用统计变种的压缩,效果很好,
这些统计变种表现在单个符号的频率以及符号或短语字符串的频率等方面,而基于字典 的系统实际山就是假扮统计程序。可是遗憾的是,这类压缩对于连续色调图象的作用并 不很好。
这些程序的主要问题产生于这样的一个事实:照片图象的象素广泛地分布在整个 范围。如果将图象中的彩色用频率分布画出,那么频率分布图中,没有我们在统计压缩 的成功的情况下所看到的“尖峰”状,实际上,如果延长这个分布图,那么从类似于电 视那样的生活图象源中得出的分布图会趋于平展。这意味着,每个象素代码彼此是大约 相同的出现机会,决定不存在挖掘熵差的任何机会。
第二章 JPEG 编码算法
2.1JPEG 压缩编码基础 七十年代末八十年代初,研究工作开始着眼于新的图像压缩类型,希望能够大大地 优于前面所讨论过的那些非常一般的压缩技术。到八十年代末,开始可为桌面系统的图 像处理而寻找应用的工作,大多是是为 UNIX 和 Macintosh 工作站加入的协处理器卡的 形式,这些卡的图象质量没有任何可见退化的情况下,可以以 95%的比率执行图像的 有损压缩。 同时,另一部分人开始发展一个国际标准,它能够包括这些新的压缩的种类。如果 标准允许方便的图形格式的互换,那么,显然,对于各方面都是有利的,关于标准化工 作,早期的担心是:它会限制进一步革新的可能性。两个标准化组织,CCITT 和 ISO, 分别从涉及图像压缩的工业和学术两个入手,并且,似乎已经潜在的阻止了工作的负结 果。 2.2.1JPEG 算法于 JPEG 小组简介 JPEG(Joint Photographic Experts Group)是由 ISO/IEC JTC1/SC2/WG8 和 CCITT VIII/NIC 于 1986 年底联合组成的专家小组。JPEG 小组的工组事研究具有连续色调的图 像(包括灰度及彩色图像)的压缩算法,并将其制定为适用于大多数图像存储及通信局 设备的标准算法,JPEG 小组于 1990 年提出 JPEG 算法的建议,并决定对建议中的算法 不再修改,除非发现了危害压缩算法标准的问题。 作为静态图像压缩的标准算法,JPEG 算法必须满足以下要求:算法独立于图像的 分辨率;具有低于 1bit/象素的编码率,并且能够在五秒钟内建立图像,以满足实时要 求;在压缩比大约是 2 的情况下能够无失真地恢复原图像;支持顺序编解码和渐进编解
}
6
2.3DCT 的实现 测验 DCT 算法时所表现出的首要的问题之一是计算 DCT 中每个元素所需要的
世界紧紧地依赖于矩阵的大小。由于使用双层嵌套循环,所以计算量为:随着 N 的增 长,处理 DCT 输出数组中每个元素所要的时间也将增长。DCT 的实现将图像分成更小 更能处理的块,JPEG 小组选用 8×8 的块大小进行 DCT 计算。
3.差分调制 差分调制依赖余模拟数据趋于“平缓” 的变化,信号幅度撒谎那个的大的跳变是例外,而不是常规。在音频数据中,只 要信号的采样率一定程度地高于信息本身的最大的频率分量,那么大的跳变就不会产 生。 音频信号的差分调制通过编码一个样点与前一个样点的不同来利用这一个特点。 例如,如果单频样点位 8 位,差分编码系统可能用 4 位来编码样点之差,这就将输入数 据压缩了 50%。这种压缩方法中所产生的损失是来自于:使用标准的差分方法不可能 总是精确地编码。信号的增长可能快于比编码的允许,或者,编码可能太粗而不能容纳 下的差别,差分编码的有损性可以很好的处理,以产生出好的信号。 当压缩图形数据时,差分调制有很多问题。首先,图形中的象素依赖于平缓的增 加或减少时不可靠的,一幅图中不同的分量间的明显界限时常有的事情。这意味着,使 用差分编码的系统需要接受样点间的大的不同和小的不同。这就限制了压缩的效率。带 有数据长结构的许多图象可以压缩的很好。长结构中的象素,彼此之间没有什么差别或 差别很少;但时,带有突变部分的那些图象不可能压缩的很好。 通常,图形图象的差分的编码似乎不产生非常强于最好的无损算法的压缩结果,
但开始研究图形压缩时,人们也试图用相似的技术压缩数字化的图象,取得了一 些成功。最初,研究人员进行栅格化数据流的压缩,如显示在电视机栅的数据。
图形数据栅格化时,图形显示成一个象素流,每次一行地显示在屏幕上,从左到 右,从上到下。这样,当完成一行时 位到 24 位,如今的琢磨图形常常使用 8 位来定义一个象 素。
2
但并没有达到所希望的那么好,原因之一是音频数据和视频数据根本不同。 用常规格式采样的音频数据是趋于反复的,声音,包括讲话,是由每次几秒的重
复的正弦波组成的。虽然计算机上 DAC 的输入流可能由许多不同的频率叠加在一起而 成,但是正弦波通常产生反复的波形。
音频反复的本性自然使他利于压缩,线性预言编码和自适应差分脉冲编码调制等 技术就利于了这一点,因此将音频数据流压缩了 50%到 95%。
JPEG 中允许四种编解码模式: (1)基于 DCT 的顺序模式(sequential DCT-based) (2)基于 DCT 的渐进模式(progressive DCT-based) (3)无失真模式(Lossless) (4) 层次模式(hierarchical). 其中,(1)和(2)是基于 DCT 的有损压缩;(3)是基于线性预测的无损压缩;(4) 可以是 DCT 与线性预测的分层混合。 JPEG 算法可分为基本 JPEG 和扩展,即 Baseline System 与 Extended System。在 Baseline System 中生成的编码文件,在 Extended System 中一定可以正确解码。 2.1.2 JPEG 压缩 JPEG 有损压缩算法在三个成功的阶段中操作,见图 2-1
for ( j = 0 ;j < 8 : j + + ){ temp = 0.0; for ( x = 0 ; x < 8 ; x ++ ) for ( y = 0 ; y < 8 ; y ++ ){ temp += Cosines [ x ] [ i ]*Cosines[ y ][ j ]*pixel[ x ][ y ]; } temp * = sqrt ( 2 * 8 ) * Coefficient[ i ][ j ]; DCT [ i ][ j ] = INT_ROUND (temp);
1.1.1 图象压缩的目的 图象采样后,如果对之进行简单的 8bit 量化和 PCM 编码,其数据量是巨大的。
以 CIF(Common Intermediate Format)格式的彩色视频信号为例,若采样速率为 25 帧/ 秒,采样样点的 Y、U、V 分量均为 8bit 量化,则一秒钟的数据量为:
2.有损压缩 类似于音频数据,图形图象也同样有一个比常规计算机数据文件优越的地方:在 压缩/扩展的循环中,他们可以被略微改动,而不会影响用户的立即质量。如果仔细修 改,那么各处象素的精确灰度可以完全不被注意地进行小的改变。由于计算机栅的图形 图象通常来自对真实世界源的扫描,所有他们通常表达一个已经不完美的照片的表达或 是不完美的其他打印接着的表达。没有改变图象基本性能的有损压缩程序应该是可行 的。 假设图形图象的有损压缩是可能的,那么它是如何实现的呢?研究人员最初试验 了用于语音信号的同样的技术,如差分编码和自适应编码,虽然这些技术对图象有帮助,
5
边到 8 的整数倍。 下面(式 2-1)给出了二维 DCT 的实用公式。式 2-2 是反离散余弦变化(IDCT)
公式。式中表示的是 8×8 个象素值的矩阵进行计算的,产生出 8×8 频率系数的矩阵。 8×8 的 DCT 及 IDCT 公式如下:
这个公式初看起来让人害怕,但它可以用相当直接的代码段来表示。 for ( i = 0 ; i < 8 ; i + + )
DCT Transformation →
Coefficient Quantization →
Lossless Compression
这三个步骤形成了一个强有力的压缩器。,可以将连续色调图像压缩到少于原大小 的 10%,同时丢失很少的原始逼真度。
2.2 JPEG 中的二维 DCT 本文所讨论的压缩过程的关键是被称为离散余弦变换(Discrete Cosine Transform, DCT)的数学变换。Baseline System 中的 DCT 要求输入数据是一个 8×8 的矩阵,且每 个矩阵元素具有 8bit 精度,分为从-128 到 127,故 DCT 变换前,象素值先要减去 128。 所谓 8×8 的二维 DCT 是指将 8×8 的象素值矩阵变换成 8×8 系数矩阵。8×8 象素值 矩阵是由输入图像分块得到的,若图像的高或宽不是 8 的整数倍,必须扩展其下边或右
图象压缩(JPEG)编码算法及压缩过程的实现
摘要 本文首先介绍了静态图像压缩(JPEG)编码算法的基本原理、压缩的实现过程及 其重要过程的离散余弦变换(DCT)算法的实现原理及软件实现的例程,其次着重介绍 了压缩过程中的 DCT、量化和编码三个重要步骤的实现原理。 关键词:图像压缩 有损压缩 JPEG 离散余弦变换 DCT 量化
基于字典的压缩程序的运行也有类似的问题,基于扫描照片的图象决定没有任何 类型的数据特征以产生相同的短语的多次出现。例如,一个栅格化的图象,类似房子墙 边的垂直部分,在图片的许多连续的行中可能可以给出相似的字符串。但不幸的是,由 于真实世界是变化多端的,每行中的相同的性能将彼此地略有不同,对于 20 个象素的 一个字符串,其中的一两个象素会因扫描而彼此出现一步长的变化,虽然这些不同点小 到人眼不能探测或对人眼不起作用,但他们毕竟妨碍了基于字典压缩的工作,对于这类 压缩方法来说,字符串必须严格匹配,由于小的变化,而使匹配的字符串长度趋于很小, 这就限制了压缩的效率。
3
他当然也不会产生所需要的、对压缩的数量级上的改进。
4.自适应编码
自适应编码(常常于差分编码一同使用)根据前面看到的一些象素而对将要到来 的一些象素的信息做预言。例如,如果一幅灰度级照片中的最新的十个象素的值都在 45 到 50 之间,那么自适应压缩系统可能预言,下一个象素很大可能也在这个范围中, 之后,类似于霍夫曼或算术编码那样的基于熵的编码方案可能给将来到来的各种代码赋 以概率值。可以代替地使用压缩-扩展方法,将最细的粒度赋给最接近预言猜测的范围。
相关文档
最新文档