当前位置: 首页 > news >正文

Python OpenCV图像处理与深度学习:Python OpenCV图像滤波入门

图像滤波:从基础到实践

学习目标

通过本课程,学员们将掌握图像滤波的基本概念,了解如何使用OpenCV实现图像的平滑滤波和锐化滤波,从而能够有效地改善图像质量。

相关知识点

  • Python OpenCV图像滤波

学习内容

1 Python OpenCV图像滤波

1.1 图像滤波的基本概念

图像滤波是数字图像处理中的一个基本操作,主要用于去除图像中的噪声、增强图像的某些特征或改善图像的整体质量。滤波器通过修改图像中的像素值来实现这些目标。滤波器可以是线性的,也可以是非线性的,具体取决于滤波器的数学模型。

在数字图像处理中,滤波通常通过卷积操作实现。卷积是一种数学运算,它将一个函数(滤波器或核)与另一个函数(图像)相乘并求和,以生成一个新的函数(滤波后的图像)。滤波器的大小和形状决定了滤波的效果。例如,一个3x3的滤波器会考虑每个像素及其周围的8个邻居像素,而一个5x5的滤波器则会考虑更多的邻居像素。

滤波器可以分为两大类:平滑滤波器和锐化滤波器。平滑滤波器用于减少图像中的噪声,使图像看起来更加平滑。常见的平滑滤波器包括均值滤波器和高斯滤波器。锐化滤波器则用于增强图像的边缘和细节,使图像看起来更加清晰。常见的锐化滤波器包括拉普拉斯滤波器和高斯拉普拉斯滤波器。

1.2 使用OpenCV实现平滑滤波

OpenCV是一个强大的计算机视觉库,提供了多种图像处理功能,包括滤波。在本课程中,学员们将学习如何使用OpenCV实现图像的平滑滤波。

1.2.1 均值滤波

执行以下指令获取测试图片。

wget https://model-community-picture.obs.cn-north-4.myhuaweicloud.com/ascend-zone/notebook_datasets/a9049fc42fa911f0bad1fa163edcddae/example.jpg

均值滤波是一种简单的平滑滤波器,它通过计算每个像素及其周围像素的平均值来平滑图像。均值滤波可以有效地减少图像中的噪声,但可能会使图像的边缘变得模糊。

import cv2
import numpy as np
import matplotlib.pyplot as plt# 读取图像
image = cv2.imread('example.jpg')# 应用均值滤波
blurred = cv2.blur(image, (5, 5))
# 显示原始图像和滤波后的图像
# 将 BGR 格式转换为 RGB 格式,以适配 matplotlib 的显示
image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
blurred = cv2.cvtColor(blurred, cv2.COLOR_BGR2RGB)
# 创建画布和子图(1行2列)
# 显示第一张图像
plt.subplot(1, 2, 1)  # 1行2列,第1个位置
plt.imshow(image)
plt.title('Original Image')
plt.axis('off')
# 显示第二张图像
plt.subplot(1, 2, 2)  # 1行2列,第2个位置
plt.imshow(blurred)
plt.title('Blurred Image')
plt.axis('off')
plt.tight_layout()  # 自动调整布局
plt.show()

在这里插入图片描述
在上述代码中,cv2.blur函数用于应用均值滤波。参数(5, 5)表示滤波器的大小为5x5。可以根据需要调整滤波器的大小,以获得不同的平滑效果。

1.2.2 高斯滤波

高斯滤波是一种更高级的平滑滤波器,它使用高斯函数作为滤波器的权重。高斯滤波可以更好地保留图像的边缘信息,同时减少噪声。

# 读取图像
image = cv2.imread('example.jpg')# 应用高斯滤波
gaussian_blurred = cv2.GaussianBlur(image, (5, 5), 0)# 显示原始图像和滤波后的图像
# 将 BGR 格式转换为 RGB 格式,以适配 matplotlib 的显示
image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
gaussian_blurred = cv2.cvtColor(gaussian_blurred, cv2.COLOR_BGR2RGB)
# 创建画布和子图(1行2列)
# 显示第一张图像
plt.subplot(1, 2, 1)  # 1行2列,第1个位置
plt.imshow(image)
plt.title('Original Image')
plt.axis('off')
# 显示第二张图像
plt.subplot(1, 2, 2)  # 1行2列,第2个位置
plt.imshow(gaussian_blurred)
plt.title('Gaussian Blurred Image')
plt.axis('off')
plt.tight_layout()  # 自动调整布局
plt.show()

在这里插入图片描述
在上述代码中,cv2.GaussianBlur函数用于应用高斯滤波。参数(5, 5)表示滤波器的大小为5x5,参数0表示标准差由系统自动计算。也可以手动指定标准差,以获得不同的平滑效果。

1.3 使用OpenCV实现锐化滤波

锐化滤波器用于增强图像的边缘和细节,使图像看起来更加清晰。在本课程中,学员们将学习如何使用OpenCV实现图像的锐化滤波。

1.3.1 拉普拉斯滤波

拉普拉斯滤波是一种常用的锐化滤波器,它通过检测图像中的边缘来增强图像的细节。拉普拉斯滤波器是一个二阶导数滤波器,可以有效地增强图像的边缘。

# 转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 应用拉普拉斯滤波
laplacian = cv2.Laplacian(gray_image, cv2.CV_64F)# 将结果转换回8位图像
laplacian = np.uint8(np.absolute(laplacian))
# 显示原始图像和滤波后的图像
# 将 BGR 格式转换为 RGB 格式,以适配 matplotlib 的显示
gray_image = cv2.cvtColor(gray_image, cv2.COLOR_BGR2RGB)
laplacian = cv2.cvtColor(laplacian, cv2.COLOR_BGR2RGB)
# 创建画布和子图(1行2列)
# 显示第一张图像
plt.subplot(1, 2, 1)  # 1行2列,第1个位置
plt.imshow(gray_image)
plt.title('Original Image')
plt.axis('off')
# 显示第二张图像
plt.subplot(1, 2, 2)  # 1行2列,第2个位置
plt.imshow(laplacian)
plt.title('Laplacian Image')
plt.axis('off')
plt.tight_layout()  # 自动调整布局
plt.show()

在这里插入图片描述
在上述代码中,cv2.Laplacian函数用于应用拉普拉斯滤波。参数cv2.CV_64F表示输出图像的数据类型为64位浮点数。np.uint8(np.absolute(laplacian))用于将结果转换回8位图像,以便显示。

1.3.2 高斯拉普拉斯滤波

高斯拉普拉斯滤波(LoG)是一种结合了高斯滤波和拉普拉斯滤波的锐化滤波器。首先,它使用高斯滤波器平滑图像,然后应用拉普拉斯滤波器来增强图像的边缘。这种方法可以有效地减少噪声,同时增强图像的细节。

# 应用高斯滤波
gaussian_blurred = cv2.GaussianBlur(gray_image, (5, 5), 0)# 应用拉普拉斯滤波
laplacian = cv2.Laplacian(gaussian_blurred, cv2.CV_64F)# 将结果转换回8位图像
laplacian = np.uint8(np.absolute(laplacian))
# 显示原始图像和滤波后的图像
# 将 BGR 格式转换为 RGB 格式,以适配 matplotlib 的显示
gray_image = cv2.cvtColor(gray_image, cv2.COLOR_BGR2RGB)
laplacian = cv2.cvtColor(laplacian, cv2.COLOR_BGR2RGB)
# 创建画布和子图(1行2列)
# 显示第一张图像
plt.subplot(1, 2, 1)  # 1行2列,第1个位置
plt.imshow(gray_image)
plt.title('Original Image')
plt.axis('off')
# 显示第二张图像
plt.subplot(1, 2, 2)  # 1行2列,第2个位置
plt.imshow(laplacian)
plt.title('Laplacian Image')
plt.axis('off')
plt.tight_layout()  # 自动调整布局
plt.show()

在这里插入图片描述
(为什么那么黑?锐化,平滑,增强细节的结果?…)
在上述代码中,首先使用cv2.GaussianBlur函数对图像进行高斯滤波,然后使用cv2.Laplacian函数应用拉普拉斯滤波。这样可以有效地减少噪声,同时增强图像的边缘。

http://www.dtcms.com/a/360927.html

相关文章:

  • gradle安装、配置环境变量、配置阿里源及idea 中配置gradle
  • RabbitMinQ(模拟实现消息队列项目)02
  • Axure科技感可视化原型案例:赋能设计与研发的宝藏资源
  • 二、感知机
  • 你的Redis是不是在家能用,到了学校就连不上?
  • CPTS-Vintage 票据,基于资源的约束委派 (RBCD),DPAPI密钥
  • 搭建APP应用程序如何选择服务器
  • ‌NAT穿透技术原理:P2P通信中的打洞机制解析‌
  • 【机器学习入门】4.4 聚类的应用——从西瓜分类到防控,看无监督学习如何落地
  • Windows11安装WSL教程
  • HBase实战(一)
  • golang json v1 和 v2对比差异
  • 【重学MySQL】九十六、MySQL SQL Mode高效配置全攻略
  • Beego: Go Web Framework 详细指南
  • ⚡ Linux xargs 命令参数详解
  • 【数据可视化-103】蜜雪冰城门店分布大揭秘:2025年8月数据分析及可视化
  • Ubuntu 25.10 Snapshot4 发布。
  • 小迪Web自用笔记23
  • Linux 定时任务 crontab 完全指南 —— 让服务器自动干活,解放双手
  • 【XR技术概念科普】详解6DoF:为什么它是沉浸感的关键?
  • 【开题答辩全过程】以 健身爱好者饮食管理小程序为例,包含答辩的问题和答案
  • 餐饮门店的小程序怎么做?如何开发餐饮店下单小程序?
  • Rinetd解决服务器IP端口的转发
  • Adobe Illustrator 2025最新破解教程下载安装教程,Illustrator2025最新版下载
  • Adobe Photoshop 2025 最新下载安装教程,附PS2025下载
  • 自由学习记录(91)
  • 从零开始的python学习——函数(1)
  • stdexcept介绍与使用指南
  • 13 选 list 还是 vector?C++ STL list 扩容 / 迭代器失效问题 + 模拟实现,对比后再做选择
  • 基于 HTML、CSS 和 JavaScript 的智能图像边缘检测系统