参考博客: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()