Python Opencv 离散余弦变化 DCT

该博客介绍了如何使用Python3和OpenCV库进行离散余弦变换(DCT)和反变换。首先读取图像并转换为浮点型,然后应用DCT,接着进行对数处理以增强视觉效果,再进行IDCT恢复原始图像。最后,通过matplotlib展示原始图像、DCT和IDCT图像。
摘要由CSDN通过智能技术生成

参考博客:Python3+OpenCV(五):离散余弦变换(DCT) - 灰信网(软件开发博客聚合)

import cv2
import numpy as np
import matplotlib.pyplot as plt

# 读取图像
img = cv2.imread("testDCT.png", 0)
# 数据类型转换 转换为浮点型
print('0\n', img)
img1 = img.astype(np.float)

# 进行离散余弦变换
img_dct = cv2.dct(img1)
print('1\n', img_dct)
# 进行log处理
img_dct_log = np.log(abs(img_dct))
print('2\n', img_dct_log)
# 进行离散余弦反变换
img_idct = cv2.idct(img_dct)
print('3\n', img_idct)
# res = img_idct.astype(np.uint8) # 浮点型转整型 小数部分截断
# print('3-1\n',res)

plt.subplot(131)
plt.imshow(img, 'gray')
plt.title('original image'), plt.xticks([]), plt.yticks([])
plt.subplot(132)
plt.imshow(img_dct_log)
plt.title('DCT'), plt.xticks([]), plt.yticks([])
plt.subplot(133)
plt.imshow(img_idct, 'gray')
plt.title('IDCT'), plt.xticks([]), plt.yticks([])
plt.show()

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乐亦亦乐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值