opencv滤波操作

1.1 均值滤波

简单的平均卷积操作

边框补0,每次选3 * 3个元素相加求平均值

python 复制代码
# 导入OpenCV库,用于图像处理
import cv2
# 从matplotlib库中导入pyplot模块,用于绘制图像
from matplotlib import pyplot as plt

# 创建一个名为'window'的窗口,窗口大小自动调整
cv2.namedWindow('window', cv2.WINDOW_AUTOSIZE)  # cv2.WINDOW_AUTOSIZE: 窗口大小自动调整,不允许用户改变窗口大小

# 使用OpenCV的imread函数读取名为"mao.jpg"的图片,参数1表示读取彩色图像
cat = cv2.imread("mao.jpg", 1)  # cat变量存储读取的图像数据,OpenCV默认以BGR格式读取

# 在名为'window'的窗口中显示图像
cv2.imshow('window', cat)

blur = cv2.blur(cat,(3,3)) #均值滤波
cv2.imshow('blur', blur)

# 等待按键事件,0表示无限期等待
key = cv2.waitKey(0)

# 检查按下的键是否是'q',如果是则销毁所有窗口
if key & 0xFF == ord('q'):  # 0xFF是掩码,用于确保只检查最低8位
    print("准备销毁窗口")
    cv2.destroyAllWindows()

1.2 方框滤波

处理结果=cv2.boxFilter(原始图像,目标图像深度,核大小,normalize属性),目标图像深度是-1表示和原图像大小相同,效果几乎和均值滤波持平

true = 1 = 所有值相加 除以 矩阵元素的个数

false = 0 = 是k = 所有的元素相加,超过255时取255

python 复制代码
# 导入OpenCV库,用于图像处理  
import cv2  
# 从matplotlib库中导入pyplot模块,用于绘制图像  
from matplotlib import pyplot as plt  
  
# 创建一个名为'window'的窗口,窗口大小自动调整  
cv2.namedWindow('window', cv2.WINDOW_AUTOSIZE)  # cv2.WINDOW_AUTOSIZE: 窗口大小自动调整,不允许用户改变窗口大小  
  
# 使用OpenCV的imread函数读取名为"mao.jpg"的图片,参数1表示读取彩色图像  
cat = cv2.imread("mao.jpg", 1)  # cat变量存储读取的图像数据,OpenCV默认以BGR格式读取  
  
# 在名为'window'的窗口中显示图像  
cv2.imshow('window', cat)  
  
blur = cv2.blur(cat,(3,3)) #均值滤波  
cv2.imshow('blur', blur)  
  
box = cv2.boxFilter(cat,-1,(3,3),normalize=True) #方框滤波  
cv2.imshow('box', box)  
  
# 等待按键事件,0表示无限期等待  
key = cv2.waitKey(0)  
  
# 检查按下的键是否是'q',如果是则销毁所有窗口  
if key & 0xFF == ord('q'):  # 0xFF是掩码,用于确保只检查最低8位  
    print("准备销毁窗口")  
    cv2.destroyAllWindows()

1.3 高斯滤波

结果=所有对应的卷积核 * 相应的值 相加

python 复制代码
# 导入OpenCV库,用于图像处理  
import cv2  
# 从matplotlib库中导入pyplot模块,用于绘制图像  
from matplotlib import pyplot as plt  
  
# 创建一个名为'window'的窗口,窗口大小自动调整  
cv2.namedWindow('window', cv2.WINDOW_AUTOSIZE)  # cv2.WINDOW_AUTOSIZE: 窗口大小自动调整,不允许用户改变窗口大小  
  
# 使用OpenCV的imread函数读取名为"mao.jpg"的图片,参数1表示读取彩色图像  
cat = cv2.imread("mao.jpg", 1)  # cat变量存储读取的图像数据,OpenCV默认以BGR格式读取  
  
# 在名为'window'的窗口中显示图像  
cv2.imshow('window', cat)  
  
blur = cv2.blur(cat,(3,3)) #均值滤波  
cv2.imshow('blur', blur)  
  
box = cv2.boxFilter(cat,-1,(3,3),normalize=True) #方框滤波  
cv2.imshow('box', box)  
  
aussian = cv2.GaussianBlur(cat,(3,3),1) #高斯滤波  
cv2.imshow('aussian', aussian)  
  
# 等待按键事件,0表示无限期等待  
key = cv2.waitKey(0)  
  
# 检查按下的键是否是'q',如果是则销毁所有窗口  
if key & 0xFF == ord('q'):  # 0xFF是掩码,用于确保只检查最低8位  
    print("准备销毁窗口")  
    cv2.destroyAllWindows()

1.4 中值滤波

中值滤波是取中间元素作为值,不如3X3的范围有9个元素,每次取第五个元素

python 复制代码
# 导入OpenCV库,用于图像处理  
import cv2  
# 从matplotlib库中导入pyplot模块,用于绘制图像  
from matplotlib import pyplot as plt  
  
# 创建一个名为'window'的窗口,窗口大小自动调整  
cv2.namedWindow('window', cv2.WINDOW_AUTOSIZE)  # cv2.WINDOW_AUTOSIZE: 窗口大小自动调整,不允许用户改变窗口大小  
  
# 使用OpenCV的imread函数读取名为"mao.jpg"的图片,参数1表示读取彩色图像  
cat = cv2.imread("mao.jpg", 1)  # cat变量存储读取的图像数据,OpenCV默认以BGR格式读取  
  
# 在名为'window'的窗口中显示图像  
cv2.imshow('window', cat)  
  
blur = cv2.blur(cat,(3,3)) #均值滤波  
cv2.imshow('blur', blur)  
  
box = cv2.boxFilter(cat,-1,(3,3),normalize=True) #方框滤波  
cv2.imshow('box', box)  
  
aussian = cv2.GaussianBlur(cat,(3,3),1) #高斯滤波  
cv2.imshow('aussian', aussian)  
  
median = cv2.medianBlur(cat,5) #中值滤波  
cv2.imshow('median', aussian)  
  
# 等待按键事件,0表示无限期等待  
key = cv2.waitKey(0)  
  
# 检查按下的键是否是'q',如果是则销毁所有窗口  
if key & 0xFF == ord('q'):  # 0xFF是掩码,用于确保只检查最低8位  
    print("准备销毁窗口")  
    cv2.destroyAllWindows()
相关推荐
m0_706653237 分钟前
深入理解Gumbel-Softmax技巧及其应用
人工智能
七夜zippoe12 分钟前
OpenClaw 接入 WhatsApp:消息推送实战
大数据·人工智能·microsoft·whatsapp·openclaw
眠りたいです16 分钟前
使用LangChain进行AI应用构建-RAG及相关核心组件认识(二)
人工智能·langchain·rag
WeeJot嵌入式16 分钟前
NVIDIA GTC 2026实战:Rubin平台AI五层架构部署指南
人工智能·架构
我材不敲代码27 分钟前
OpenCV实战:全自动答题卡识别与评分系统
人工智能·opencv·计算机视觉
SmartBrain33 分钟前
AI深度解析:智能体产品核心理念与技术架构
人工智能·架构·aigc
RFID科技的魅力39 分钟前
从开箱到实战:CP300R触屏RFID打印机全场景使用测评
大数据·人工智能·物联网·rfid
子兮曰42 分钟前
llama.cpp Windows 免编译部署实测:Releases 下载、模型检索与参数详解
人工智能·架构·开源
Cosolar1 小时前
吃透这5种Agent模式,搞定智能体开发
人工智能·面试·全栈
开开心心_Every1 小时前
限时免费加密、隐藏、锁定文件文件夹好工具
运维·服务器·人工智能·edge·pdf·逻辑回归·深度优先