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

简介: 什么是压缩算法及压缩算法定义

一、什么是压缩算法


我想必都有过 压缩解压缩 文件的经历,当文件太大时,我会使用文件压缩来降低文件的占用空间,比如微信上传文件的限制是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


目录
相关文章
|
6月前
|
算法 测试技术 C++
【动态规划】【状态压缩】【C++算法】1815 得到新鲜甜甜圈的最多组数
【动态规划】【状态压缩】【C++算法】1815 得到新鲜甜甜圈的最多组数
|
6月前
|
算法 JavaScript Java
【状态压缩】【动态规划】【C++算法】1125.最小的必要团队
【状态压缩】【动态规划】【C++算法】1125.最小的必要团队
|
22天前
|
存储 JSON 算法
TDengine 检测数据最佳压缩算法工具,助你一键找出最优压缩方案
在使用 TDengine 存储时序数据时,压缩数据以节省磁盘空间是至关重要的。TDengine 支持用户根据自身数据特性灵活指定压缩算法,从而实现更高效的存储。然而,如何选择最合适的压缩算法,才能最大限度地降低存储开销?为了解决这一问题,我们特别推出了一个实用工具,帮助用户快速判断并选择最适合其数据特征的压缩算法。
30 0
|
1月前
|
人工智能 算法 前端开发
无界批发零售定义及无界AI算法,打破传统壁垒,累积数据流量
“无界批发与零售”是一种结合了批发与零售的商业模式,通过后端逻辑、数据库设计和前端用户界面实现。该模式支持用户注册、登录、商品管理、订单处理、批发与零售功能,并根据用户行为计算信用等级,确保交易安全与高效。
|
5月前
|
算法
数据结构和算法学习记录——线性表之双向链表(上)-结点类型定义、初始化函数、创建新结点函数、尾插函数、打印函数、尾删函数
数据结构和算法学习记录——线性表之双向链表(上)-结点类型定义、初始化函数、创建新结点函数、尾插函数、打印函数、尾删函数
48 0
|
3月前
|
搜索推荐 算法 Java
现有一个接口DataOperation定义了排序方法sort(int[])和查找方法search(int[],int),已知类QuickSort的quickSort(int[])方法实现了快速排序算法
该博客文章通过UML类图和Java源码示例,展示了如何使用适配器模式将QuickSort类和BinarySearch类的排序和查找功能适配到DataOperation接口中,实现算法的解耦和复用。
40 1
现有一个接口DataOperation定义了排序方法sort(int[])和查找方法search(int[],int),已知类QuickSort的quickSort(int[])方法实现了快速排序算法
|
4月前
|
算法 Java
Java面试题:解释垃圾回收中的标记-清除、复制、标记-压缩算法的工作原理
Java面试题:解释垃圾回收中的标记-清除、复制、标记-压缩算法的工作原理
58 1
|
4月前
|
算法 Java 程序员
Java面试题:解释Java的垃圾回收机制,包括常见的垃圾回收算法。介绍一下Java的垃圾回收算法中的标记-压缩算法。
Java面试题:解释Java的垃圾回收机制,包括常见的垃圾回收算法。介绍一下Java的垃圾回收算法中的标记-压缩算法。
49 0
|
5月前
|
算法
数据结构和算法学习记录——平衡二叉树(基本介绍、平衡因子、平衡二叉树的定义、平衡二叉树的高度)
数据结构和算法学习记录——平衡二叉树(基本介绍、平衡因子、平衡二叉树的定义、平衡二叉树的高度)
51 0
|
5月前
|
算法
数据结构和算法学习记录——初识二叉树(定义、五种基本形态、几种特殊的二叉树、二叉树的重要性质、初识基本操作函数)
数据结构和算法学习记录——初识二叉树(定义、五种基本形态、几种特殊的二叉树、二叉树的重要性质、初识基本操作函数)
51 0