3

我正在使用 TensorFlow 解决图像超分辨率问题(2D 和 3D),并使用 SSIM 作为eval_metrics.

我正在使用image.ssim来自 TF 和measure.comapre_ssim来自skimage. 它们都给出了相同的 2D 结果,但 3D 体积的结果总是存在差异。

我查看了TF-implementationskimage-implementation的源代码。在两种实现中如何考虑和处理输入图像似乎存在一些根本差异。

复制问题的代码:

import numpy as np
import tensorflow as tf

from skimage import measure

# For 2-D case
np.random.seed(12345)
a = np.random.random([32, 32, 64])
b = np.random.random([32, 32, 64])

a_ = tf.convert_to_tensor(a)
b_ = tf.convert_to_tensor(b)

ssim_2d_tf = tf.image.ssim(a_, b_, 1.0)
ssim_2d_sk = measure.compare_ssim(a, b, multichannel=True, gaussian_weights=True, data_range=1.0, use_sample_covariance=False)

print (tf.Session().run(ssim_2d_tf), ssim_2d_sk)

# For 3-D case
np.random.seed(12345)
a = np.random.random([32, 32, 32, 64])
b = np.random.random([32, 32, 32, 64])

a_ = tf.convert_to_tensor(a)
b_ = tf.convert_to_tensor(b)

ssim_3d_tf = tf.image.ssim(a_, b_, 1.0)
ssim_3d_sk = measure.compare_ssim(a, b, multichannel=True, gaussian_weights=True, data_range=1.0, use_sample_covariance=False)

s_3d_tf = tf.Session().run(ssim_3d_tf)
print (np.mean(s_3d_tf), ssim_3d_sk)

在 3D 的情况下,我必须取输出的平均值,因为 Tensorflow 在最后三个维度上计算 SSIM,因此会产生32 个 SSIM值。这表明 TF 会考虑 NHWC 格式的 SSIM 图像。这对 SSIM 超过 3D 体积有好处吗?

skimage但是,似乎正在使用一维高斯滤波器。很明显,即使这也没有考虑 3D 体积的深度。

有人可以对这些有所了解并帮助我决定进一步使用哪一个以及为什么?

4

1 回答 1

5

粗略看一下代码,TensorFlow 似乎总是为批次中的每个图像和每个通道计算一个 2D SSIM。它对跨通道的 SSIM 值进行平均,并为批次中的每个图像返回一个值。对于 TF,4D 阵列是具有多个通道的 2D 图像的集合。

相反,SciKit-Image 在所有维度上计算 SSIM,除了最后一个 ifmultichannel设置。因此,在 4D 阵列的情况下,它会为每个通道计算一个 3D SSIM 并在各个通道之间取平均值。

这与您发现 3D 阵列的类似结果但 4D 阵列的结果不同的结果一致。


然而,skimage 似乎正在使用一维高斯滤波器。

我不确定你从哪里得到这个,SciKit-Image在n D 图像的情况下使用n D 高斯。然而,高斯是一个可分离的滤波器,这意味着它可以通过n个一维滤波器的应用有效地实现。

于 2018-12-26T16:27:49.517 回答