将ax[1].imshow(img_compress)显示的图片保存为图像文件
时间: 2024-02-15 20:05:55 浏览: 80
要将`ax[1].imshow(img_compress)`显示的图片保存为图像文件,可以使用scikit-image库中的`io.imsave()`函数,如下所示:
```python
from skimage import io
# 读取图像
img = io.imread('image.jpg')
# 对图像进行处理
# 保存压缩后的图像
io.imsave('compressed_image.jpg', img_compress)
```
其中,`io.imsave()`函数需要传入两个参数,第一个参数是保存的文件名,第二个参数是要保存的图像数据。在这个示例中,我们将压缩后的图像数据保存为了名为"compressed_image.jpg"的文件。
如果你想保存的图像是灰度图像,可以将`io.imsave()`函数的第二个参数设置为单通道的灰度图像数据,例如:
```python
from skimage import io, color
# 读取图像并转换为灰度图像
img = io.imread('image.jpg')
gray_img = color.rgb2gray(img)
# 对图像进行处理
# 保存处理后的灰度图像
io.imsave('processed_image.jpg', gray_img)
```
在这个示例中,我们使用了scikit-image库中的`color.rgb2gray()`函数将彩色图像转换为灰度图像,然后将处理后的灰度图像保存到了"processed_image.jpg"文件中。
相关问题
import matplotlib.pyplot as plt from PIL import Image # 读取图像 image = np.array(Image.open('0.jpg')) # 将图像数据归一化到 [0, 1] 范围内 image_norm = image.astype('float32') / 255.0 # 压缩图像 compressed_image = compress_image(image_norm, n_clusters=16) # 显示压缩前后的图像 fig, ax = plt.subplots(1, 2, figsize=(10, 5)) ax[0].imshow(image_norm) ax[0].set_title('Original Image') ax[1].imshow(compressed_image) ax[1].set_title('Compressed Image') plt.show()加上计算PSNR的代码
可以使用以下代码计算压缩后的图像与原始图像之间的 PSNR 值:
```
import numpy as np
import math
# 计算 PSNR
def psnr(img1, img2):
mse = np.mean((img1 - img2) ** 2)
if mse == 0:
return float('inf')
return 20 * math.log10(1.0 / math.sqrt(mse))
# 计算压缩前后图像的 PSNR
psnr_value = psnr(image_norm, compressed_image)
print("PSNR: {:.2f} dB".format(psnr_value))
```
这将在显示压缩前后的图像后,输出压缩前后图像的 PSNR 值。
import numpy as np import matplotlib.pyplot as plt import pywt from skimage import io, color # 读取灰度图像并转换为RGB图像 img_gray = io.imread('lena.png', as_gray=True) img = color.gray2rgb(img_gray) # 对图像的三个通道进行DWT变换 coeffs_r = pywt.dwt2(img[:, :, 0], 'haar') coeffs_g = pywt.dwt2(img[:, :, 1], 'haar') coeffs_b = pywt.dwt2(img[:, :, 2], 'haar') # 设置压缩比率 compress_ratio = 0.5 # 计算阈值 threshold_r = np.sort(np.abs(coeffs_r[1].ravel()))[::-1][int(compress_ratio * len(coeffs_r[1].ravel()))] threshold_g = np.sort(np.abs(coeffs_g[1].ravel()))[::-1][int(compress_ratio * len(coeffs_g[1].ravel()))] threshold_b = np.sort(np.abs(coeffs_b[1].ravel()))[::-1][int(compress_ratio * len(coeffs_b[1].ravel()))] # 对小于阈值的系数进行置零 coeffs_r = list(coeffs_r) coeffs_r[0] = np.round(coeffs_r[0]) coeffs_r[1] = np.where(np.abs(coeffs_r[1]) < threshold_r, 0, coeffs_r[1]) coeffs_r[2] = np.where(np.abs(coeffs_r[2]) < threshold_r, 0, coeffs_r[2]) coeffs_g = list(coeffs_g) coeffs_g[0] = np.round(coeffs_g[0]) coeffs_g[1] = np.where(np.abs(coeffs_g[1]) < threshold_g, 0, coeffs_g[1]) coeffs_g[2] = np.where(np.abs(coeffs_g[2]) < threshold_g, 0, coeffs_g[2]) coeffs_b = list(coeffs_b) coeffs_b[0] = np.round(coeffs_b[0]) coeffs_b[1] = np.where(np.abs(coeffs_b[1]) < threshold_b, 0, coeffs_b[1]) coeffs_b[2] = np.where(np.abs(coeffs_b[2]) < threshold_b, 0, coeffs_b[2]) # 合并三个通道的系数 coeffs = [np.stack([coeffs_r[i], coeffs_g[i], coeffs_b[i]], axis=-1) for i in range(len(coeffs_r))] # 对图像进行IDWT反变换 img_dwt = pywt.idwt2(coeffs, 'haar') # 显示原始图像和压缩后的图像 fig, axes = plt.subplots(nrows=1, ncols=2, figsize=(8, 4)) ax = axes.ravel() ax[0].imshow(img) ax[0].set_title("Original image") ax[1].imshow(img_dwt) ax[1].set_title("Compressed image (DWT)") ax[1].set_xlabel("Compression ratio: {:.2f}".format(compress_ratio)) plt.tight_layout() plt.show()
这段代码缺少了两行,分别是导入numpy和matplotlib.pyplot两个模块的语句。请在代码的开头添加以下两行语句:
```
import numpy as np
import matplotlib.pyplot as plt
```
这样就可以解决代码中的报错。
阅读全文