我需要使用 Sewar 的 SSIM 作为损失函数来比较我的模型的图像。
当我尝试编译我的模型时出现错误。我导入函数并编译模型,如下所示:
from sewar.full_ref import ssim
...
model.compile('ssim', optimizer=my_optimizer, metrics=[ssim])
Run Code Online (Sandbox Code Playgroud)
我明白了:
File "/media/merry/merry32/train.py", line 19, in train
model.compile(loss='ssim', optimizer=opt, metrics=[ssim])
File "/home/merry/anaconda3/envs/merry_env/lib/python3.7/site-packages/keras/engine/training.py", line 451, in compile
handle_metrics(output_metrics)
File "/home/merry/anaconda3/envs/merry_env/lib/python3.7/site-packages/keras/engine/training.py", line 420, in handle_metrics
mask=masks[i])
File "/home/merry/anaconda3/envs/merry_env/lib/python3.7/site-packages/keras/engine/training_utils.py", line 404, in weighted
score_array = fn(y_true, y_pred)
File "/home/merry/anaconda3/envs/merry_env/lib/python3.7/site-packages/sewar/full_ref.py", line 143, in ssim
MAX = np.iinfo(GT.dtype).max
File "/home/merry/anaconda3/envs/merry_env/lib/python3.7/site-packages/numpy/core/getlimits.py", line 506, in __init__
raise ValueError("Invalid integer data type %r." % (self.kind,))
ValueError: Invalid integer data type 'O'.
Run Code Online (Sandbox Code Playgroud)
我也可以这样写:
model.compile(ssim(), optimizer=my_optimizer, metrics=[ssim()])
Run Code Online (Sandbox Code Playgroud)
但是后来我收到了这个错误(显然):
TypeError: ssim() missing 2 required positional arguments: 'GT' and 'P'
Run Code Online (Sandbox Code Playgroud)
我只是想对 mean_sqeared_error 做同样的事情,但使用 SSIM,就像这样(无需向其传递参数即可完美运行):
model.compile('mean_squared_error', optimizer=my_optimizer, metrics=['mse'])
Run Code Online (Sandbox Code Playgroud)
关于如何使用此函数进行编译的任何想法?
小智 8
Keras 有 SSIM 的实现。你可以这样使用它:
def SSIMLoss(y_true, y_pred):
return 1 - tf.reduce_mean(tf.image.ssim(y_true, y_pred, 1.0))
self.model.compile(optimizer=sgd, loss=SSIMLoss)
Run Code Online (Sandbox Code Playgroud)
tf.image.ssim
计算两个图像之间的 SSIM 索引。from keras.models import Sequential
from keras.layers import Dense, Conv2D, Flatten
import numpy as np
import tensorflow as tf
# Loss functtion
def ssim_loss(y_true, y_pred):
return tf.reduce_mean(tf.image.ssim(y_true, y_pred, 2.0))
# Model: Input Image size: 32X32X1 output Image size: 28X28X1
# check model.summary
model = Sequential()
model.add(Conv2D(32, kernel_size=(3, 3),
activation='relu',
input_shape=(32,32,1)))
model.add(Conv2D(1, kernel_size=(3, 3),
activation='relu'))
model.compile(optimizer='adam', loss=ssim_loss, metrics=[ssim_loss, 'accuracy'])
# Train
model.fit(np.random.randn(10,32,32,1), np.random.randn(10,28,28,1))
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6917 次 |
最近记录: |