如何在处理图像时对Scipy的convolve2d进行归一化?

7

我正在使用scipy的convolve2d函数:

for i in range(0, 12):
            R.append(scipy.signal.convolve2d(self.img,  h[i], mode = 'same'))

卷积后所有的值都是以10000的幅度,但考虑到我正在处理图像,我需要它们在0-255范围内。如何进行归一化?


这可能会给你一些提示:https://dev59.com/0GUq5IYBdhLWcg3wHs6Y 找到最大值并进行缩放。请提供图像和内核数据以获取更多信息。 - tfv
这是一个16x16的内核,所有值都在0-255之间。 - user4414636
1个回答

2
假设您想在单个图像内进行归一化,您可以简单地使用 im_out = im_out / im_out.max() * 255
您还可以对内核或原始图像进行归一化。
下面是示例。
import scipy.signal
import numpy as np
import matplotlib.pyplot as plt
from skimage import color
from skimage import io


im = plt.imread('dice.jpg')
gray_img = color.rgb2gray(im)

print im.max()

# make some kind of kernel, there are many ways to do this...
t = 1 - np.abs(np.linspace(-1, 1, 16))
kernel = t.reshape(16, 1) * t.reshape(1, 16)
kernel /= kernel.sum()   # kernel should sum to 1!  :) 

im_out =scipy.signal.convolve2d(gray_img,  kernel, mode = 'same')

im_out = im_out / im_out.max() * 255

print im_out.max()

plt.subplot(2,1,1)
plt.imshow(im)
plt.subplot(2,1,2)
plt.imshow(im_out)
plt.show()

enter image description here


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接