我想要一些有关在python中执行简单图像分析的建议。我需要为图像的“亮度”计算一个值。我知道PIL是执行此类操作的goto库。有一个内置的直方图功能。
我需要的是“感知亮度”值,我可以决定是否需要对图像进行进一步的调整。那么在这种情况下可以使用哪些基本技术呢?我应该只使用RGB值,还是直方图会给我足够接近的东西?
一种可能的解决方案是将两者结合起来,并使用直方图生成平均R,G和B值,然后应用“感知亮度”公式。
使用问题中提到的技术,我提出了几个不同的版本。
每个方法都返回一个close值,但与其他方法不完全相同。另外,除了最后一种方法外,所有方法都以相同的速度运行,这取决于图像大小,速度要慢得多。
将图像转换为灰度,返回平均像素亮度。
def brightness( im_file ):
im = Image.open(im_file).convert(‘L’) stat = ImageStat.Stat(im) return stat.mean[0]
将图像转换为灰度,返回RMS像素亮度。
im = Image.open(im_file).convert(‘L’) stat = ImageStat.Stat(im) return stat.rms[0]
平均像素,然后转换为“感知的亮度”。
im = Image.open(im_file) stat = ImageStat.Stat(im) r,g,b = stat.mean return math.sqrt(0.241(r2) + 0.691(g2) + 0.068*(b2))
像素的RMS,然后转换为“感知的亮度”。
im = Image.open(im_file) stat = ImageStat.Stat(im) r,g,b = stat.rms return math.sqrt(0.241(r2) + 0.691(g2) + 0.068*(b2))
计算像素的“感知亮度”,然后返回平均值。
im = Image.open(im_file) stat = ImageStat.Stat(im) gs = (math.sqrt(0.241(r2) + 0.691(g2) + 0.068*(b2)) for r,g,b in im.getdata()) return sum(gs)/stat.count[0]
更新测试结果 我对200张图像进行了仿真。我发现方法#2,#4给出几乎相同的结果。方法#3,#5也几乎相同。方法#1紧跟在方法#3,#5之后(有一些例外)。