在对图像像素值进行加减操作时,要注意数据类型,不然就容易造成数据溢出,计算出的结果并不是你想得到的值,下面给出例子。
首先定义一个矩阵保存为图片:
>>>from skimage.io import imread,imsave
>>>import numpy
>>>data = [[1,2,3],[255,3,1], [45,113,2]]
>>>imsave('test.png',data)
接着读取图片进行像素值操作:
>>>pic_data = imread('test.png')
>>>print(pic_data[0][0], pic_data[0][1],pic_data[0][0] - pic_data[0][1])
1 2 255
>>>print(pic_data[1][0] , pic_data[1][1],pic_data[1][0] + pic_data[1][1])
255 3 2
1
−
2
=
255
,
255
+
3
=
2
1-2=255,255+3=2
1−2=255,255+3=2 是怎么回事了?
我们查看一下pic_data的数据类型
>>>print(pic_data.dtype)
uint8
问题就出在这,imread读取图片,将图片数据保存在‘uint8’类型的数组中,但‘uint8’是无符号8位整数,表示数据范围为0~255,上面的1-2=-1,255+3=258计算结果超出了‘uint8’的表示范围,造成溢出。
为了更好地理解我们看看上述数据的二进制:
>>>print(bin(pic_data[0][0]), bin(pic_data[0][1]),bin(pic_data[0][0] - pic_data[0][1]))
0b1 0b10 0b11111111
>>>print(bin(pic_data[1][0]) , bin(pic_data[1][1]),bin(pic_data[1][0] + pic_data[1][1]))
0b11111111 0b11 0b10
所以在对图像像素值等进行运算操作时,一定要注意数据的类型,及时的进行类型转换。