简单Python模糊卷积核函数生成奇怪的图像

我在编写一个自定义函数,使用卷积核对图像进行模糊处理。然而,当我显示图像时,结果却很奇怪。某种程度上,图像似乎被反转了,但我不知道为什么。这里是原始图像:

原始图像

这是结果:

输入图像描述

我已经尝试了重写代码、更换图像、改变模糊核、打印并亲自逐个检查许多卷积等方法。

import cv2import numpy as npimport matplotlib.pyplot as pltdef showImage(image):    plt.imshow(image, cmap='gray')    plt.show()def gaussianBlur(image):    tempImage = image.copy()    tempImage = np.pad(tempImage, 1, "constant")    showImage(tempImage)    max = 0    i = 0    for x in range(1, len(image)-1):        for y in range(1, len(image[0])-1):            roi = image[x-1:x+2, y-1:y+2]            kernel = np.array([                [0.0625, 0.125, 0.0625],                [0.125, 0.25, 0.125],                [0.0625, 0.125, 0.0625]            ])            if np.matmul(roi, kernel).sum() > max:                max = np.matmul(roi, kernel).sum()            tempImage[x][y] = np.matmul(roi, kernel).sum()            i += 1            print(np.matmul(roi, kernel).sum())            # if(i % 1000 == 0):            #     showImage(tempImage)    divAmount = max / 255    for x in range(1, len(image)-1):            for y in range(1, len(image[0])-1):                tempImage[x][y] = tempImage[x][y] / divAmount    return tempImage.tolist()# 加载并查看图像image = cv2.imread("image_1_small.jpg", 0)showImage(image)# 应用模糊image = gaussianBlur(image)print(image)# image = cv2.GaussianBlur(image, (5, 5), 0)showImage(image)

预期的结果应该是模糊处理后的原始图像。


回答:

这是由溢出引起的。你计算卷积的方式有误。请使用np.multiply替换np.matmul。

Related Posts

在使用k近邻算法时,有没有办法获取被使用的“邻居”?

我想找到一种方法来确定在我的knn算法中实际使用了哪些…

Theano在Google Colab上无法启用GPU支持

我在尝试使用Theano库训练一个模型。由于我的电脑内…

准确性评分似乎有误

这里是代码: from sklearn.metrics…

Keras Functional API: “错误检查输入时:期望input_1具有4个维度,但得到形状为(X, Y)的数组”

我在尝试使用Keras的fit_generator来训…

如何使用sklearn.datasets.make_classification在指定范围内生成合成数据?

我想为分类问题创建合成数据。我使用了sklearn.d…

如何处理预测时不在训练集中的标签

已关闭。 此问题与编程或软件开发无关。目前不接受回答。…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注