一个想法是,在添加value之前,通过检查255与当前像素值之间的差异并检查其是否在value之内,检查添加是否会导致溢出。如果是的话,我们不会添加value,我们会直接将它们设置为255,否则我们会进行添加。现在,这个决定可以通过一个面具的创造来放松,并且-mask = (255 - grey) < value
然后,将这个mask/boolean数组馈送给^{},让它根据掩码在255和grey+value之间进行选择。
因此,最终我们将实现为-grey_new = np.where((255 - grey) < value,255,grey+value)
样本运行
让我们用一个有代表性的小例子来演示这些步骤。In [340]: grey
Out[340]:
array([[125, 212, 104, 180, 244],
[105, 26, 132, 145, 157],
[126, 230, 225, 204, 91],
[226, 181, 43, 122, 125]], dtype=uint8)
In [341]: value = 100
In [342]: grey + 100 # Bad results (e.g. look at (0,1))
Out[342]:
array([[225, 56, 204, 24, 88],
[205, 126, 232, 245, 1],
[226, 74, 69, 48, 191],
[ 70, 25, 143, 222, 225]], dtype=uint8)
In [343]: np.where((255 - grey) < 100,255,grey+value) # Expected results
Out[343]:
array([[225, 255, 204, 255, 255],
[205, 126, 232, 245, 255],
[226, 255, 255, 255, 191],
[255, 255, 143, 222, 225]], dtype=uint8)
对样本图像进行测试
使用问题中发布的示例图像给我们arr,并使用value作为50,我们将-