pycharm写一个对一张分辨率为417*556的图片进行基于DCT的图像压缩,并能控制压缩率的代码

时间: 2024-02-20 07:59:33 浏览: 24
以下是用Python和OpenCV库实现基于DCT的图像压缩的示例代码,您可以在PyCharm中运行它: ```python import cv2 import numpy as np # 量化矩阵 Q = np.array([[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], [18, 22, 37, 56, 68, 109, 103, 77], [24, 35, 55, 64, 81, 104, 113, 92], [49, 64, 78, 87, 103, 121, 120, 101], [72, 92, 95, 98, 112, 100, 103, 99]]) # 量化矩阵缩放 def scale_quant_matrix(Q, scale): return np.round(np.maximum(np.minimum(Q * scale, 255), 1)) # DCT变换 def dct2(block): return cv2.dct(cv2.dct(block.T, norm=cv2.DCT_TYPE-II).T, norm=cv2.DCT_TYPE-II) # 逆DCT变换 def idct2(block): return cv2.idct(cv2.idct(block.T, norm=cv2.DCT_TYPE-II).T, norm=cv2.DCT_TYPE-II) # 对块进行量化 def quantize(block, Q): return np.round(np.divide(block, Q)).astype(int) # 对块进行逆量化 def dequantize(block, Q): return np.multiply(block, Q) # DCT压缩 def dct_compression(img, Q_scale): # 将图像划分为8x8块 blocks = cv2.resize(img, (np.int(np.ceil(img.shape[1]/8)*8), np.int(np.ceil(img.shape[0]/8)*8))) blocks = cv2.cvtColor(blocks, cv2.COLOR_BGR2YCR_CB)[:,:,0] # 只对亮度分量进行压缩 blocks = np.float32(blocks) blocks = np.array(np.split(blocks, blocks.shape[0]/8)) blocks = np.array([np.split(block, block.shape[1]/8, axis=1) for block in blocks]) # 对每个块进行DCT变换和量化 dct_blocks = np.zeros(blocks.shape) quant_blocks = np.zeros(blocks.shape) for i in range(blocks.shape[0]): for j in range(blocks.shape[1]): dct_blocks[i][j] = dct2(blocks[i][j]) quant_matrix = scale_quant_matrix(Q, Q_scale) # 根据缩放因子计算量化矩阵 quant_blocks[i][j] = quantize(dct_blocks[i][j], quant_matrix) # 对量化后的系数进行编码 compressed = np.array([np.array([cv2.imencode('.jpg', quant_blocks[i][j])[1] for j in range(quant_blocks.shape[1])]) for i in range(quant_blocks.shape[0])]) return compressed, quant_blocks.shape # DCT解压缩 def dct_decompression(compressed, shape, Q_scale): # 对量化后的系数进行解码 quant_blocks = np.array([np.array([cv2.imdecode(compressed[i][j], 0) for j in range(compressed.shape[1])]) for i in range(compressed.shape[0])]) # 对每个块进行逆量化和逆DCT变换 blocks = np.zeros(shape) for i in range(quant_blocks.shape[0]): for j in range(quant_blocks.shape[1]): quant_matrix = scale_quant_matrix(Q, Q_scale) # 根据缩放因子计算量化矩阵 dct_blocks = dequantize(quant_blocks[i][j], quant_matrix) blocks[i*8:(i+1)*8, j*8:(j+1)*8] = idct2(dct_blocks) blocks = np.uint8(np.maximum(np.minimum(blocks, 255), 0)) # 将图像转换为BGR格式 img = cv2.cvtColor(blocks, cv2.COLOR_GRAY2BGR) return img # 加载图像 img = cv2.imread('image.jpg') # 压缩图像 compressed, shape = dct_compression(img, 0.5) # Q_scale = 0.5,控制压缩率 # 解压缩图像 decompressed = dct_decompression(compressed, shape, 0.5) # Q_scale = 0.5 # 显示压缩前后的图像 cv2.imshow('Original Image', img) cv2.imshow('Compressed Image', decompressed) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在这个示例代码中,我们使用了OpenCV库来实现DCT变换、量化、编码、解码和逆DCT变换等操作。您可以通过调整量化矩阵的缩放因子来控制压缩率。例如,如果您将缩放因子设置为0.5,则压缩率将大约为50%。

相关推荐

最新推荐

recommend-type

pycharm+django创建一个搜索网页实例代码

主要介绍了pycharm+django创建一个搜索网页实例代码,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
recommend-type

pycharm sciview的图片另存为操作

主要介绍了pycharm sciview的图片另存为操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

pycharm 代码自动补全的实现方法(图文)

主要介绍了pycharm 代码自动补全的实现方法(图文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

pycharm下python使用yolov3/yolov3-tiny训练好的权重文件.weights进行行人检测,批量测试自定义文件夹下的图片并输出至指定文件夹

python使用yolov3/yolov3-tiny训练好的权重文件.weights进行行人检测,批量测试自定义文件夹下的图片并输出至指定文件夹 目录 python使用yolov3/yolov3-tiny训练好的权重文件.weights进行行人检测,批量测试自定义...
recommend-type

Pycharm编辑器功能之代码折叠效果的实现代码

 在一些情况下,如果某些代码显得不太重要,我们可以通过Pycharm的代码折叠功能将其折叠为一行。在接下来的部分我们将介绍代码折叠功能基本用法。  2、代码可折叠轮廓线以及折叠开关  首先,我们观察一下代码左侧...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

hive中 的Metastore

Hive中的Metastore是一个关键的组件,它用于存储和管理Hive中的元数据。这些元数据包括表名、列名、表的数据类型、分区信息、表的存储位置等信息。Hive的查询和分析都需要Metastore来管理和访问这些元数据。 Metastore可以使用不同的后端存储来存储元数据,例如MySQL、PostgreSQL、Oracle等关系型数据库,或者Hadoop分布式文件系统中的HDFS。Metastore还提供了API,使得开发人员可以通过编程方式访问元数据。 Metastore的另一个重要功能是跟踪表的版本和历史。当用户对表进行更改时,Metastore会记录这些更改,并且可以让用户回滚到
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。