什么是压缩算法及压缩算法定义

news/2024/7/7 20:19:50

目录

一、什么是压缩算法

文件存储

 二、压缩算法定义


一、什么是压缩算法

我想必都有过 压缩 解压缩 文件的经历,当文件太大时,我会使用文件压缩来降低文件的占用空间,比如微信上传文件的限制是100 MB,我这有个文件无法上传,是我解压完后的交件一定小于100MB,么的文件可以上传了。

此外,我们把相机拍完的照片保存到计算上的时候,也会使用压缩算法进行文件压缩,文件压缩的格式一般是 JPEG

那什么是算法呢?压结算法又是怎么定义的呢?在认识压缩算法之前我们要先了解一下文件是如何存储的

文件存储

文件是将数据存储在磁盘等存储介质的一种形式。程序文件中最基本的存储数据单位是 字节。文件的大小不管是xxxKB,xxxMB等来表示,就是因为文件是以字节 B = Byte 为单位存储的。

文件就是字节数据集合,用1字节(8位)表示的字节数据有256种,用二进制表示的话就是00000000 - 1111 1111,如果文件中存储的数据都是文字,那么该文件是文本文件。如果是图形,那么该文件是图像文件。在任何情况下,文件中字节数据都是 连续存储 的。

文件是字节数据的集合体示意图:

 二、压缩算法定义

        上面介绍了文件的集合体其实就是一堆字节数据的集合,那么我们就可以来给压缩算法下个定义。压缩算法(compaction algorithm) 指的就是数据压缩的算法,主要包括压缩和还原(解压缩)的两个步骤。

其实就是在不改变原有文件属性的前提下,降低文件字节空间和占用空间一种算法。

根据的压缩算法的定义,我们可将其分成不同的类型:

有损和无损

无损压缩:能够无失真地 从压缩后的数据重构,准确地还原原始的数据,可用于对数据的准确性要求严格的场合,如可执行文件和普通文件的压缩、磁盘的压缩,也可用于多媒体数据压缩。该方法的压缩比较小,如差分编码,RLE,Huffman编码,LZW编码,算术编码。

有损压缩:有失真,不能完全准确地 恢复原始数据,重构的数据只是原始数据的一个近似。可用于对数据准确性要求不高的场合,如多媒体数据的压缩。该方法的压缩比较大。例如预测编码、音感编码。分形压缩,小波压缩,JPEG/MPEG

对称性

如果编解算法的复杂性和所需时间差不多,则为对称的编码方法,多数压缩算法都是对称的,但也有不对称的,一般是编码难而解码容易,如 Huffman增码和分形编码。但用于密码学的编码方法则相反,是编码易,而解码非常难

帧间与帧内

在视频编码中会同时用到帧内与帧间的编码方法,帧内编码是指在一帧图像内立完成编码方法,同静态图像的编码,如JPEG;而帧间编码则需要参照前后帧才能进行编解码,并在编码过程中考虑对帧之间的时间冗余的压缩,如 MPEG

实时性

在有些多媒体应用场合,需要实时处理或传输数据(如现场的数字录音和录影、播放MP3/RM/VCD/DVD、视频/音频点播、网络现场直播、可视电话、视频会议),编解码一般要求延时≤ 50ms。这就需要简单/快速/高效的算法和高速/复杂的CPU/DSP芯片

分级处理

有些压缩算法可以同时处理不同分辨率,不同传输速率,不同质量水平的多媒体数据,如JPEG2000、MPEG-2/4


http://lihuaxi.xjx100.cn/news/51961.html

相关文章

【设计模式】-创建型模式-第2章第3讲-【建造者模式】

目录 场景需求 1、建造者模式中包含以下4个类 2、实际代码示例 2.1、具体产品(Product)类 2.2、抽象建造者(Builder ) 2.3、具体建造者(ConcreteBuilder ) 2.4、指挥者(Director&#xff…

注册中心系列二:Consul的接入与使用

目录一、Consul原理与介绍1.介绍2.实现原理2.1serf2.2Raft3.consul agent参数三、Docker搭建集群版的Consul四、springcloud的接入方式1.依赖引入2.配置五、优缺点1.优点2.缺点一、Consul原理与介绍 1.介绍 consul主要有server和client两种组件组成。 server负责核心数据的存…

C++中const关键字的用法

1 如果用const修饰一个类的成员方法&#xff0c;这个方法就不能修改这个类的成员变量&#xff0c;也不能调用这个类的非const的成员方法。如下&#xff1a; class A05 { public:void run() const {i;cout << "index:" << i << endl;}private:int …

qmake language

qmake language 变量 qmake language $() $$() $$[] $${} 区别&#xff08;属性property、变量variable、环境变量evironment variable&#xff09;_丘上人的博客-CSDN博客 qmake language 内建关键字 qmake language variable true false test function host_build_丘上人的…

JAVA计算机毕业设计毕业生就业信息管理系统Mybatis+系统+数据库+调试部署

JAVA计算机毕业设计毕业生就业信息管理系统Mybatis系统数据库调试部署 JAVA计算机毕业设计毕业生就业信息管理系统Mybatis系统数据库调试部署本源码技术栈&#xff1a; 项目架构&#xff1a;B/S架构 开发语言&#xff1a;Java语言 开发软件&#xff1a;idea eclipse 前端技…

python做题遇到的format用法

“{ }”.format()** print(“三角形的周长为&#xff1a;{:.1f}”.format(d)) print(‘{} * {} {:<2}’.format(i,j, ij), end " “) print(”{}{}{:<2}“.format (i, k, ik), end‘\t’) print("{0}{1}{2}”.format(i, j, i * j), end‘\t’) str.format(’…

数据规范化与数据离散化

文章目录一、数据规范化1、小数定标规范化2、最小—最大规范化3、零-均值规范化&#xff08;z-score规范化&#xff09;二、数据离散化一、数据规范化 数据规范化&#xff08;归一化&#xff09;处理是数据挖掘的一项基础工作。不同评价指标往往具有不同的量纲&#xff0c;数值…

Linux外壳程序编程 shell编程 引号详解

shell是命令语言、命令解释程序及程序设计语言的统称&#xff1b; shell是一个命令语言解释器&#xff0c;它拥有自己内建的shell命令&#xff1b; Shell&#xff08;Bash&#xff09;单引号、双引号和反引号用法详解; 尽量使用 $(命令) 的方式来引用命令的输出&#xff0c;…