我试图在角星中实现MNIST图像的DCT。对于同样的问题,我有几个问题:
这是我的密码:
import keras
from keras import backend as K
from keras.models import Sequential
from keras.layers import Dense, Dropout, Activation, Flatten, Add
from keras.layers import Convolution2D, MaxPooling2D
from keras.utils import np_utils
from keras.layers.core import Lambda
from keras.datasets import mnist
from PIL import Image
import numpy as np
import matplotlib.pyplot as plt
%matplotlib inline
(X_train, y_train), (X_test, y_test) = mnist.load_data()
X_train = X_train.astype('float32')
X_test = X_test.astype('float32')
X_train /= 255
X_test /= 255
model = Sequential()
model.add(Lambda(lambda x: K.tf.spectral.dct(K.transpose(K.tf.spectral.dct(K.transpose(x), type=2, norm='ortho')), type=2, norm='ortho') ,input_shape=(28, 28,1), output_shape=(28,28,1)))
model.add(Lambda(lambda x: K.tf.spectral.dct(K.transpose(K.tf.spectral.dct(K.transpose(x), type=2, norm='ortho')), type=2, norm='ortho'),input_shape=(28, 28,1), output_shape=(28,28,1)))
X_train = X_train.reshape(X_train.shape[0], 28, 28, 1)
viz_dct = model.predict(X_train[:len(X_train)//2])
def get_reconstructed_image(coeff):
coeff = coeff*255
img = Image.fromarray(coeff)
return img
print(viz_dct.shape)
viz_dct = viz_dct.reshape(viz_dct.shape[0],viz_dct.shape[1],viz_dct.shape[2])
plt.imshow(get_reconstructed_image(viz_dct[5]))以下是上述程序的输出图像:
原始图像:

在第一次dct之后:

在第二次dct之后:

发布于 2018-05-24 21:44:31
通常情况下,图像值是8位DCT输出的8位是16位。拍摄一幅图像,并在上面做一个DCT,然后显示它,很可能会导致你有超出范围的像素值。
https://stackoverflow.com/questions/50383888
复制相似问题