使用Python查找具有类似调色板的图像

jac*_*ack 5 python image colors

假设图库中有10,000个JPEG,PNG图像,如何找到具有相似调色板的所有图像到选定图像,并按降序相似度排序?

Fra*_*ger 10

为每个图像构建颜色直方图.然后,当您想要将图像与集合匹配时,只需按照直方图与所选图像的直方图的接近程度对列表进行排序.

桶的数量取决于您想要的准确度.组合成一个存储桶的数据类型将定义您如何确定搜索的优先级.

例如,如果您对色调最感兴趣,那么您可以定义图像的每个像素所在的桶:

def bucket_from_pixel(r, g, b):
    hue = hue_from_rgb(r, g, b) # [0, 360)
    return (hue * NUM_BUCKETS) / 360
Run Code Online (Sandbox Code Playgroud)

如果您还需要通用匹配器,则可以根据完整的RGB值选择存储桶.

使用PIL,您可以使用内置histogram功能.可以使用您想要的任何距离测量来计算"接近度"直方图.例如,L1距离可以是:

hist_sel = normalize(sel.histogram())
hist = normalize(o.histogram()) # These normalized histograms should be stored

dist = sum([abs(x) for x in (hist_sel - hist)])
Run Code Online (Sandbox Code Playgroud)

L2将是:

dist = sqrt(sum([x*x for x in (hist_sel - hist)]))
Run Code Online (Sandbox Code Playgroud)

Normalize只是强制直方图的总和等于某个常量值(1.0工作正常).这很重要,因此可以将大图像与小图像进行正确比较.如果你打算使用L1距离,那么你应该使用L1测量normalize.如果L2,那么L2.