【发布时间】:2019-12-05 00:47:24
【问题描述】:
我目前正在尝试使用 OpenCV 确定输出图像与使用 Python 绘制的莫奈画作之间的色差。
根据我的研究,我发现 Delta E 是确定色差的最佳选择。我尝试使用提取两个图像的 BGR 通道,然后取用于计算每个颜色通道差异的平均“蓝色”“绿色”和“红色”颜色。
output_chans = cv2.split(image)
monet_chans = cv2.split(best_painting)
colors = ("Blue", "Green", "Red")
for (output_chan, monet_chan, color) in zip(output_chans, monet_chans, colors):
output_mean = np.mean(output_chan)
monet_mean = np.mean(monet_chan)
color1_rgb = None
color2_rgb = None
if color == "Blue":
color1_rgb = sRGBColor(0.0, 0.0, output_mean)
color2_rgb = sRGBColor(0.0, 0.0, monet_mean)
elif color == "Green":
color1_rgb = sRGBColor(0.0, output_mean, 0.0);
color2_rgb = sRGBColor(0.0, monet_mean, 0.0);
elif color == "Red":
color1_rgb = sRGBColor(output_mean, 0.0, 0.0);
color2_rgb = sRGBColor(monet_mean, 0.0, 0.0);
# Convert from RGB to Lab Color Space
color1_lab = convert_color(color1_rgb, LabColor);
# Convert from RGB to Lab Color Space
color2_lab = convert_color(color2_rgb, LabColor);
# Find the color difference
delta_e = delta_e_cie2000(color1_lab, color2_lab);
print("Delta E of the Mean of %s Channel: %f" % (color, delta_e))
我收到每个颜色通道的色差输出,但是我的教授建议我可能做错了 Delta E,因为我应该只获得整个图像的色差值而不是一个值每三个颜色通道的值。在这种情况下,是否有另一种方法或正确的方法来计算我们两个图像的 Delta E?
这是我们测试图片示例的链接:https://imgur.com/a/KToggFS
以及绘画样本的链接:https://imgur.com/a/vi1SFax
【问题讨论】:
标签: python opencv image-processing histogram