Lọc trong opencv / python

Nov 10 2020

Tôi đang cố gắng tìm hiểu các bộ lọc trong opencv và chạy mã này. Nhưng vấn đề là khi ı chạy mã, nó cho tôi một hình ảnh gần như tối và cảnh báo tôi bằng "c: / Users / fazil / Desktop / Yeni Metin Belgesi (3) .py: 19: RuntimeWarning: tràn trong kết quả ubyte_scalars [ j, i, a] = int ((image [j, i, a] + image [j, i-1, a] + image [j, i + 1, a] + image [j + 1, i, a ] + hình ảnh [j-1, i, a] + hình ảnh [j + 1, i + 1, a] + hình ảnh [j + 1, i-1, a] + hình ảnh [j-1, i-1, a ] + hình ảnh [j-1, i + 1, a]) / 9) ". Và nếu tôi bình luận những điều này và chạy mã với các dòng làm việc với phương thức cv2.filter2d, nó cho tôi một hình ảnh gần như trắng. Ý tôi là, họ không phải làm điều tương tự, và suy nghĩ rằng bộ lọc làm mờ hình ảnh? Đây là mã của tôi;

import cv2

image=cv2.imread(r"C:\Users\fazil\Desktop\c.png")
cv2.imshow("input",image)
cv2.cvtColor(image,cv2.CV_8U)
# kernel=np.array([
#     [1,1,1],
#     [1,1,1],
#     [1,1,1]
# ],np.float32)
# image=cv2.filter2D(image,-1,kernel)
def blur(image):
    height,width,channel=image.shape
    result=np.zeros(image.shape,image.dtype)
    for j in range(1,height-1):
        for i in range(1,width-1):
            for a in range(channel):
                result[j,i,a]=int((image[j,i,a]+image[j,i-1,a]+image[j,i+1,a]+image[j+1,i,a]+image[j-1,i,a]+image[j+1,i+1,a]+image[j+1,i-1,a]+image[j-1,i-1,a]+image[j-1,i+1,a])/9)
    return result

cv2.imshow("output",blur(image))
cv2.imwrite(r"C:\Users\fazil\Desktop\output.png",image)
cv2.waitKey()
cv2.destroyAllWindows()  ```

Trả lời

1 fmw42 Nov 11 2020 at 19:45

Hai phương pháp sau phù hợp với tôi trong Python OpenCV

Đầu vào:

import cv2
import numpy as np

image=cv2.imread("barn.jpg")
image=image.astype(np.float32)/255
#cv2.cvtColor(image,cv2.CV_8U)
kernel=np.array([
                [1,1,1],
                [1,1,1],
                [1,1,1]
                ],np.float32)
outimage1=cv2.filter2D(image,cv2.CV_32F,kernel)/9
outimage1=(255*outimage1).clip(0,255).astype(np.uint8)

def blur(image):
    height,width,channel=image.shape
    result=np.zeros(image.shape,dtype=np.float32)
    for j in range(1,height-1):
        for i in range(1,width-1):
            for a in range(channel):
                result[j,i,a]=(255*(image[j-1,i-1,a]+image[j-1,i,a]+image[j-1,i+1,a]+image[j,i-1,a]+image[j,i,a]+image[j,i+1,a]+image[j+1,i-1,a]+image[j+1,i,a]+image[j+1,i+1,a])/9)
    return result

outimage2 = blur(image)
outimage2 = outimage2.clip(0,255).astype(np.uint8)

cv2.imshow("input",image)
cv2.imshow("output1",outimage1)
cv2.imshow("output2",outimage2)
cv2.imwrite("barn_blur1.jpg",outimage1)
cv2.imwrite("barn_blur2.jpg",outimage2)
cv2.waitKey()
cv2.destroyAllWindows()

Phương pháp làm mờ 1:

Phương pháp làm mờ 2: