转载请注明出处:http://blog.csdn.net/luoshixian099/article/details/50392230

CSDN-勿在浮沙筑高台

为了满足不同应用的需求,JPEG标准包含两种主要的压缩方法:1.基于DCT的有损压缩算法;2.基于预測方法的无损压缩算法。

基于DCT的基线系统有损压缩技术是到眼下为止应用最为广泛的一种压缩方法,本文将具体解析此算法。

1.基于DCT有损压缩原理

以下是编码器和解码器的流程图。压缩过程:原图分成8×8的子块,分别进行正向离散余弦变换(FDCT)。对每一个8×8子块的系数採用量化表进行量化。Zig-Zag扫描,最后使用熵编码。输出比特流。解码器是完整的逆过程。本文章不再赘述!

1.1离散余弦变换(DCT)

首先把原始图像切割成8×8的子块(假设宽或高不是8的整数倍,能够用黑色边框填充),每一个子块进行独立编码处理。

在进行FDCT变换之前,把64个无符号整型灰度值[0,255]平移到[-128,+127]范围中。

通过DCT变换,8×8个灰度值被转换为8×8个频率谱值,分别相应不同频率。

DCT变换系数值均为实数。

低频谱值位于左上部分,高频谱值位于右下部分。通过下述公式可知。左上角F(0,0)相应频率为0,被称为DC系数,其它63个系数称为AC系数。

至于为什么子块大小选择8×8。因为当时制定JPEG标准时,8×8是集成电路所能支持的最大尺寸,同一时候8×8的大小效果非常好。

下述定义的b[x,y]为DCT的基函数。以下画出了6个基函数在8×8的子块上的幅值b[x,y]。当中,x,y为空间域的坐标,u,v相应频率域的坐标。

1.2 量化

注意:图像信息损失是在量化阶段而不是DCT阶段。经过上述FDCT,生成了64个频率系数,通过抑制高频成分,来达到压缩的目的。一个主要原因是因为人眼对高频成分不敏感,故能够移除部分高频成分。而对图像感官质量影响非常小;还有一个原因是大多数图像中的灰度值是个渐变的过程。而频率高的部分携带的信息非常少。

通过使用量化矩阵Q(u,v)对F(u,v)进行量化,大部分高频系数会被量化成0。JPEG标准没有指定量化矩阵的数值,能够依据须要自定义,以下是JPEG标准提供的两种量化矩阵作为參考。一种为低压缩,还有一个为高压缩。

1.3 熵编码

☆ Zig-Zag扫描

通过上述量化矩阵,大部分高频系数被量化为0。为了方便进行熵编码,把8×8的系数矩阵转化为1×64的一维数据,并且採用的方式为Zig-Zag扫描法,採用Z字型的优点是能够把低频系数和高频系数分别集中在一起。而随着频率的添加,高频系数基本上都是0,方便採用0行程编码从而压缩数据。

☆Huffman编码----->Huffman具体原理

1.DC系数-DPCM

因为DC系数是整个8×8块的均值。所以相邻块的DC系数有非常大的相关性,同一时候DC系数通常比AC系数要大得多,JPEG标准对DC系数採用相邻DC差分(DPCM)。通常Diff具有非常小的数值,然后进行Huffman编码。

例如以下图所看到的(第一个块的DC定义为0)。

2.AC系数-行程编码

採用Zig-Zag扫描后,高频成分被量化为0,并且基本集中在一起,能够对AC系数採用0行程编码。即记录此数值前的连续数值0的个数。

以下是个对AC系数压缩的样例。

2. An example--JPEG压缩&解压缩

以下是一个压缩算法过程,对彩色图像,採用分层处理,即对不同通道分别压缩。解压缩是一个逆向的过程:

---------------------------------------------------------------------------------------------------------------------------------------------------

-------------------------------------------------------------------------------------------------------------------------------------------------------

參考:

The JPEG Still Picture Compression Standard,IEEE Transactions on Consumer Electronics,1991.

Basic Image Compression Algorithm and Introduction to JPEG Standard,Pao-Yen Lin.

【数据压缩】JPEG标准与原理解析的更多相关文章

  1. 标准Trie字典树学习一:原理解析

    特别声明: 博文主要是学习过程中的知识整理,以便之后的查阅回顾.部分内容来源于网络(如有摘录未标注请指出).内容如有差错,也欢迎指正! 系列文章: 1. 字典树Trie学习一:原理解析 2.字典树Tr ...

  2. Batik - 将svg转换成其他格式图片或PDF - [导出服务器配置] 导出服务器原理解析

    导出服务器原理解析 Highcharts图表导出(或下载)本质上是将SVG代码转换为不同文件格式的过程,用到的工具是batik,所以所谓导出服务器,只不过是调用batik,将SVG代码转换并下载.下图 ...

  3. [原][Docker]特性与原理解析

    Docker特性与原理解析 文章假设你已经熟悉了Docker的基本命令和基本知识 首先看看Docker提供了哪些特性: 交互式Shell:Docker可以分配一个虚拟终端并关联到任何容器的标准输入上, ...

  4. JSONP跨域的原理解析

    JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重要的安全性限制,被称为“Same- Origin Policy”(同源策略).这一策略对于Jav ...

  5. 爱加密Android APk 原理解析

    转载请标明出处:http://blog.csdn.net/u011546655/article/details/45921025 爱加密Android APK加壳原理解析 一.什么是加壳? 加壳是在二 ...

  6. JSONP跨域的原理解析及其实现介绍

    JSONP跨域的原理解析及其实现介绍 作者: 字体:[增加 减小] 类型:转载 时间:2014-03-22 JSONP跨域GET请求是一个常用的解决方案,下面我们来看一下JSONP跨域是如何实现的,并 ...

  7. Java Web每天学之Servlet的原理解析

    Java Web每天学之Servlet的工作原理解析,上海尚学堂Java技术文章Java Web系列之二上一篇文章Java Web每天学之Servlet的工作原理解析是之一,欢迎点击阅读. Servl ...

  8. 基于OpenCV进行图像拼接原理解析和编码实现(提纲 代码和具体内容在课件中)

    一.背景 1.1概念定义 我们这里想要实现的图像拼接,既不是如题图1和2这样的"图片艺术拼接",也不是如图3这样的"显示拼接",而是实现类似"BaiD ...

  9. (转)Apache和Nginx运行原理解析

    Apache和Nginx运行原理解析 原文:https://www.server110.com/nginx/201402/6543.html Web服务器 Web服务器也称为WWW(WORLD WID ...

随机推荐

  1. STM32CubeMx的使用分享

    1. 新建立工程(以F103ZET6为例) 2. 配置引脚(以PA0为例)   3. 配置外设(以串口为例) 4. 配置时钟 5. 外设.GPIO.中断初始化 6. 生成工程 7. 添加自己的代码 8 ...

  2. H5新增的标签总结

    1:便于排版的Form表单 HTML5为了方便排版,可以使form的表单标签脱离form的嵌套. 方法:form指定id,所有的标签标签都添加form= id属性. 例如: <form acti ...

  3. 【BZOJ 1221】 [HNOI2001] 软件开发

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] /* 设一个超级源点S和超级汇点T S和2*i-1各连一条容量为ni的边. 花费为0 表示每天都会产生ni条要洗的毛巾 S和2*i各 ...

  4. JAVA集合类型(二)

    JAVA集合类型 (现代的变量集群) watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0J ...

  5. POJ 1721

    好像不需要用到开方什么的... 可以知道,一副牌即是一个循环,那么,由于GCD(L,K)=1,所以一次洗牌后,亦是一个循环.其实,K次洗牌等于是T^(2^K)了.既然是循环,必定有周期.那么,周期是多 ...

  6. 【BZOJ3270】博物馆 概率DP 高斯消元

    链接: #include <stdio.h> int main() { puts("转载请注明出处[辗转山河弋流歌 by 空灰冰魂]谢谢"); puts("网 ...

  7. 安卓中经常使用控件遇到问题解决方法(持续更新和发现篇幅)(在textview上加一条线、待续)

    TextView设置最多显示30个字符.超过部分显示...(省略号),有人说分别设置TextView的android:signature="true",而且设置android:el ...

  8. codevs 3372 选学霸(hash+并查集+多重背包)

    先通过并查集处理出来有多少种不同的集合,每一个集合有多少人.一定要不要忘记了与别的没有联系的独立点. 并查集的时候能够通过hash处理出来每一个数目同样的集合的个数. 这样以人数为权值.个数为限制进行 ...

  9. 超便携式截屏录屏软件FastStone Capture

    超便携式截屏录屏软件FastStone Capture

  10. CentOS Linux 加硬盘,分区和设置自动挂载

    sda 表示第1块SCSI硬盘hda 表示第1块IDE硬盘(即连接在第1个IDE接口的Master口上)scd0 表示第1个USB光驱当添加了新硬盘后,在/dev目录下会有相应的设备文件产生.ccis ...