我正在尝试使用 cv2.normalize 函数对具有零均值和单位方差的灰度图像数组进行归一化,如下所示
out_image = np.zeros((32,32),dtype=np.float32)
out_array = np.zeros((len(X),32,32), dtype=np.uint8)
for imageindex in range(0,len(X)):
img = X[imageindex].squeeze()
if proctype == 'MeanSubtraction':
out_image = img.astype(np.float32) - np.mean(img.astype(np.float32))
elif proctype == 'Normalization':
out_image = cv2.normalize(img.astype(np.float32), out_image, alpha=-0.5, beta=0.5,\
norm_type=cv2.NORM_MINMAX, dtype=cv2.CV_32F)
elif proctype == 'HistEqualization':
out_image = cv2.equalizeHist(img)
elif proctype == 'CLAHE':
clahe = cv2.createCLAHE(tileGridSize=(6,6),clipLimit = 20.0)
out_image = clahe.apply(img)
out_array[imageindex] = out_image.astype(np.uint8)
return out_array
但是,如果我使用 0 和 1(或 0 和 255)作为标准化函数的参数 alpha 和 beta,它就可以工作。但如果我使用 -0.5 和 +0.5,它会返回一个空图像(全为零)
为什么会发生这种情况?
最佳答案
out_array
的类型为np.uint8
,因此无法准确表示浮点值。因此,当您使用 将包含
,所有这些值都被截断为零。考虑这个例子:[-0.5, 0.5]
范围内的浮点值的 out_image
转换为 np.uint8
时>out_image.astype(np.uint8)
# generate random numbers in the range [-0.5, 0.5]
x_float32 = (np.random.random((32, 32)) - 0.5).astype(np.float32)
print x_float32.min(), x_float32.max() # prints -0.49861032, 0.4998906
x_uint8 = x_float32.astype(np.uint8)
print x_uint8.min(), x_uint8.max() # prints 0, 0
如果要在out_array
中存储浮点值,首先需要将其dtype
更改为np.float32
。或者,您可以将 [-0.5, 0.5]
范围内的值重新规范化为 [0, 255]
范围内的无符号整数。
关于Python openCV 使用零均值和单位方差进行归一化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42346194/