opencv——图像滤波_中值滤波

1、中值模糊

#!/usr/bin/env python3
# -*- coding: utf-8 -*-


"""
中值模糊,故名思意就是运用卷积框对应像素的中值代替中心像素点的值,
    中值滤波器常常用来处理椒盐噪声,注意它的卷积核必须为正奇数。
    其函数原型为:
        medianBlur(src, ksize[, dst]) -> dst

"""

import cv2 as cv

img = cv.imread('./mouse.jpg')

# 中值滤波
blur = cv.medianBlur(img, 5)

cv.imshow('img', img)
cv.imshow('blur', blur)

cv.waitKey(0)
cv.destroyAllWindows()

# 提高理解
small = img[10:20, 20:30:, :1]
print(small.reshape(10, 10))
print('*' * 60)
small_b = cv.medianBlur(small, 3)
# 边缘填充:复制原图中最临近的行或者列
print(small_b)

2、中值模糊_练习

#!/usr/bin/env python3
# -*- coding: utf-8 -*-


"""
中值模糊,故名思意就是运用卷积框对应像素的中值代替中心像素点的值,
    中值滤波器常常用来处理椒盐噪声,注意它的卷积核必须为正奇数。
    其函数原型为:
        medianBlur(src, ksize[, dst]) -> dst

"""

import cv2 as cv
import numpy as np

# img_path = './images/Fig4.11(a).jpg'
# img_path = './images/Fig5.08(a).jpg'
img_path = './images/Fig5.08(b).jpg'

img = cv.imread(img_path)

# 中值滤波
blur_3 = cv.medianBlur(img, 3)
blur_5 = cv.medianBlur(img, 5)
blur_9 = cv.medianBlur(img, 9)
blur_15 = cv.medianBlur(img, 15)
blur_35 = cv.medianBlur(img, 35)

cv.imwrite('./outputs/blur_src.jpg', img)
cv.imwrite('./outputs/blur_3.jpg', blur_3)
cv.imwrite('./outputs/blur_5.jpg', blur_5)
cv.imwrite('./outputs/blur_9.jpg', blur_9)
cv.imwrite('./outputs/blur_15.jpg', blur_15)
cv.imwrite('./outputs/blur_35.jpg', blur_35)

h1 = np.hstack((img, blur_3, blur_5))
h2 = np.hstack((blur_9, blur_15, blur_35))
cv.imshow('blur_test', np.vstack((h1, h2)))

cv.waitKey(0)
cv.destroyAllWindows()

# 提高理解
small = img[10:20, 20:30:, :1]
print(small.reshape(10, 10))
print('*' * 60)
small_b = cv.medianBlur(small, 3)
# 边缘填充:复制原图中最临近的行或者列
print(small_b)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值