计算机视觉中的双边滤波:经典案例与Python代码解析

🌟 计算机视觉中的双边滤波:经典案例与Python代码解析 🚀

Hey小伙伴们!今天我们要聊的是计算机视觉中的一个重要技术——双边滤波。双边滤波是一种非线性滤波方法,主要用于图像去噪和平滑,同时保留图像的边缘和细节。通过双边滤波,我们可以显著改善图像的质量。让我们一起来看看如何使用Python实现双边滤波吧!🎉


📝 理论篇:双边滤波的基本原理

双边滤波是一种结合了空间距离和像素强度差异的滤波方法。它通过以下两个权重来计算新的像素值:

  1. 空间权重:根据像素之间的空间距离计算权重。
  2. 强度权重:根据像素之间的强度差异计算权重。

双边滤波的公式如下:

f ( i , j ) = ∑ ( x , y ) ∈ N ( i , j ) I ( x , y ) ⋅ w s ( i , j , x , y ) ⋅ w r ( I ( i , j ) , I ( x , y ) ) ∑ ( x , y ) ∈ N ( i , j ) w s ( i , j , x , y ) ⋅ w r ( I ( i , j ) , I ( x , y ) ) f(i, j) = \frac{\sum_{(x, y) \in N(i, j)} I(x, y) \cdot w_s(i, j, x, y) \cdot w_r(I(i, j), I(x, y))}{\sum_{(x, y) \in N(i, j)} w_s(i, j, x, y) \cdot w_r(I(i, j), I(x, y))} f(i,j)=(x,y)N(i,j)ws(i,j,x,y)wr(I(i,j),I(x,y))(x,y)N(i,j)I(x,y)ws(i,j,x,y)wr(I(i,j),I(x,y))

其中:

  • f(i, j) 是新像素值。
  • I(i, j) 是原图像中的像素值。
  • N(i, j) 是邻域窗口。
  • w_s(i, j, x, y) 是空间权重。
  • w_r(I(i, j), I(x, y)) 是强度权重。

1. 空间权重

w s ( i , j , x , y ) = exp ⁡ ( − ( i − x ) 2 + ( j − y ) 2 2 σ d 2 ) w_s(i, j, x, y) = \exp\left(-\frac{(i - x)^2 + (j - y)^2}{2\sigma_d^2}\right) ws(i,j,x,y)=exp(2σd2(ix)2+(jy)2)

2. 强度权重

w r ( I ( i , j ) , I ( x , y ) ) = exp ⁡ ( − ( I ( i , j ) − I ( x , y ) ) 2 2 σ r 2 ) w_r(I(i, j), I(x, y)) = \exp\left(-\frac{(I(i, j) - I(x, y))^2}{2\sigma_r^2}\right) wr(I(i,j),I(x,y))=exp(2σr2(I(i,j)I(x,y))2)


📑 实战篇:使用Python实现双边滤波

接下来,我们通过一个具体的Python示例来实现双边滤波。我们将使用OpenCV库来处理图像,并使用NumPy进行矩阵运算。

1. 安装必要的库

首先,确保你已经安装了OpenCV和NumPy:

pip install opencv-python numpy
2. 读取和显示图像

我们先读取一张图像并显示它:

import cv2
import numpy as np

# 读取图像
image = cv2.imread('path_to_your_image.jpg')

# 显示原始图像
cv2.imshow('Original Image', image)
cv2.waitKey(0)
cv2.destroyAllWindows()
3. 双边滤波

使用OpenCV的 bilateralFilter 函数进行双边滤波:

def bilateral_filter(image, d, sigma_color, sigma_space):
    # 使用OpenCV的bilateralFilter函数进行双边滤波
    filtered_image = cv2.bilateralFilter(image, d, sigma_color, sigma_space)
    return filtered_image

# 应用双边滤波
filtered_image = bilateral_filter(image, d=9, sigma_color=75, sigma_space=75)

# 显示滤波后的图像
cv2.imshow('Bilateral Filtered Image', filtered_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
4. 完整代码

将上述步骤整合在一起,完整的代码如下:

import cv2
import numpy as np

# 读取图像
image = cv2.imread('path_to_your_image.jpg')

# 显示原始图像
cv2.imshow('Original Image', image)
cv2.waitKey(0)
cv2.destroyAllWindows()

# 双边滤波
def bilateral_filter(image, d, sigma_color, sigma_space):
    # 使用OpenCV的bilateralFilter函数进行双边滤波
    filtered_image = cv2.bilateralFilter(image, d, sigma_color, sigma_space)
    return filtered_image

# 应用双边滤波
filtered_image = bilateral_filter(image, d=9, sigma_color=75, sigma_space=75)

# 显示滤波后的图像
cv2.imshow('Bilateral Filtered Image', filtered_image)
cv2.waitKey(0)
cv2.destroyAllWindows()

🌟 成功案例

当你运行这段代码时,你会看到原始图像和双边滤波后的图像。双边滤波有效地去除了图像中的噪声,同时保留了图像的边缘和细节。


运行效果

在这里插入图片描述
在这里插入图片描述

🌟 小贴士
  • 参数选择

    • d:滤波器的空间直径。值越大,滤波效果越强。
    • sigma_color:颜色空间的标准差。值越大,颜色差异的影响越小。
    • sigma_space:空间域的标准差。值越大,空间距离的影响越小。
  • 多尺度处理:结合不同参数的双边滤波器,可以在多尺度上进行图像处理,提高效果。


🚀 结语

通过今天的实战演练,大家已经掌握了如何使用Python和OpenCV实现双边滤波。双边滤波是计算机视觉中非常基础但重要的技术,可以应用于图像去噪、增强和分析等多个领域。如果你有任何问题或想法,欢迎留言交流。我们下次再见!👋


标签:#计算机视觉 #Python编程 #双边滤波 #图像处理 #OpenCV #NumPy

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/917788.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu 22.04 上快速搭建 Samba 文件共享服务器

Samba 简介 Samba 是一个开源软件,它扮演着不同操作系统间沟通的桥梁。通过实现 SMB(Server Message Block)协议,Samba 让文件和打印服务在 Windows、Linux 和 macOS 之间自由流动。 以下是 Samba 的特点: 跨平台兼…

在MATLAB中实现自适应滤波算法

自适应滤波算法是一种根据信号特性自动调整滤波参数的数字信号处理方法,其可以有效处理噪声干扰和信号畸变问题。在许多实时数据处理系统中,自适应滤波算法得到了广泛应用。在MATLAB中,可以使用多种方法实现自适应滤波算法。本文将介绍自适应…

AWTK-WIDGET-WEB-VIEW 发布

awtk-widget-web-view 是通过 webview 提供的接口,实现的 AWTK 自定义控件,使得 AWTK 可以方便的显示 web 页面。 项目网址: https://gitee.com/zlgopen/awtk-widget-web-view webview 提供了一个跨平台的 webview 接口,是一个非…

使用Web Workers提升JavaScript的并行处理能力

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 使用Web Workers提升JavaScript的并行处理能力 使用Web Workers提升JavaScript的并行处理能力 使用Web Workers提升JavaScript的…

shell编程--传参与数学运算

探讨一下如何向shell脚本传递参数。 脚本传参 首先用vim创建一个脚本。 vim 脚本.sh 可以理解为其他编程语言的标准输出,例如C语言的输出%d,表标准输出数字。 用echo 执行文件名称是:$0 echo 第一个参数是:$1 echo 传递参数作为字符串显…

头歌-本关任务:使用GmSSL命令行,生成SM2私钥并对文件进行签名验证(第二关)。

第一关在网上找到了,但第二关没找到,在这里做一下补充:) 如果想认真学的话可以看看文档 国密SM2椭圆曲线密码标准http://gmssl.org/docs/sm2.html 内容为 GuetPython 的明文文件msg.txt 私钥sm2.pem 公钥sm2Pub.pem 使用sm2utl对msg.txt进行签名&…

elementui el-table中给表头 el-table-column 加一个鼠标移入提示说明

前言 在使用el-table 表格中有些表格的表头需要加入一些提示&#xff0c;鼠标移入则出现提示&#xff0c;非常实用&#xff0c;我是通过el-table中的el-tooltip实现的&#xff0c;以下的效果预览 代码实现 <el-table ref"multipleTable" :data"data"…

在kile 5中一个新工程的创建

这两天博主学习到了在kile5中创建一个工程&#xff0c;当然博主不会忘了小伙伴们的&#xff0c;这就和你们分享。 本次创建以STM32F103C8为例 创建过程&#xff1a; 1首先创建文件 名字随意&#xff0c;但也不要太随意&#xff0c;因为是外国软件&#xff0c;所以多少对中文…

PortSwigger WEB缓存欺骗

一、Web缓存概述 Web 缓存是位于源服务器和用户之间的系统。当客户端请求静态资源时&#xff0c;请求首先被定向到缓存。如果缓存不包含资源的副本&#xff08;称为缓存未命中&#xff09;&#xff0c;则请求将转发到源服务器&#xff0c;该服务器将处理并响应请求。然后&#…

nginx源码安装配置ssl域名

nginx源码安装 下载 wget http://nginx.org/download/nginx-1.24.0.tar.gz 解压 tar -zxvf nginx-1.24.0.tar.gz 下载openssl apt install openssl 安装nginx cd nginx-1.24.0 sudo apt-get install libpcre3 libpcre3-dev ./configure --prefix=/home/nginx24 --with-http_ss…

如何用WordPress和Shopify提升SEO表现?

选择合适的建站程序对于SEO优化非常重要。目前&#xff0c;WordPress和Shopify是两种备受推崇的建站平台&#xff0c;各有优势。 WordPress最大的优点是灵活性。它支持大量SEO插件&#xff0c;帮助你调整元标签、生成站点地图、优化内容结构等。这些功能让你能够轻松地提升网站…

RHCE的学习(20)

变量5种赋值方式 shell中变量赋值5种方式&#xff0c;其中采用name10的方法称A 直接赋值 nameB read命令 read v1C 使用命令行参数 &#xff08;$1 $2 $3 ..&#xff09; name$1D 使用命令的输入 username$(whoami)E 从文件读取 #cut -d : -f1 /etc/passwd > /user.listfor…

llama factory lora 微调 qwen2.5 7B Instruct模型

项目背景 甲方提供一台三卡4080显卡 需要进行qwen2.5 7b Instruct模型进行微调。以下为整体设计。 要使用 LLaMA-Factory 对 Qwen2.5 7B Instruct模型 进行 LoRA&#xff08;Low-Rank Adapters&#xff09;微调&#xff0c;流程与之前提到的 Qwen2 7B Instruct 模型类似。LoRA …

Python酷库之旅-第三方库Pandas(221)

目录 一、用法精讲 1036、pandas.DatetimeIndex.to_pydatetime方法 1036-1、语法 1036-2、参数 1036-3、功能 1036-4、返回值 1036-5、说明 1036-6、用法 1036-6-1、数据准备 1036-6-2、代码示例 1036-6-3、结果输出 1037、pandas.DatetimeIndex.to_series方法 10…

108. UE5 GAS RPG 实现地图名称更新和加载关卡

在这一篇里&#xff0c;我们将实现对存档的删除功能&#xff0c;在删除时会有弹框确认。接着实现获取玩家的等级和地图名称和存档位置&#xff0c;我们可以通过存档进入游戏&#xff0c;玩家在游戏中可以在存档点存储存档。 实现删除存档 删除存档需要一个弹框确认&#xff0…

后台管理系统(开箱即用)

很久没有更新博客了&#xff0c;给大家带上一波福利吧,大佬勿扰 现在市面上流行的后台管理模板很多,若依,芋道等,可是这些框架对我们来说可能会有点重,所以我自己从0到1写了一个后台管理模板,你们使用时候可扩展性也会更高 项目主要功能: 成员管理&#xff0c;部门管理&#…

【ubuntu】Geogebra

Geogebra 几何作图工具 是一款跨平台的几何作图工具软件&#xff0c; 目前已经覆盖了&#xff0c; windows&#xff0c;android&#xff0c; mac, linux 等操作系统。 Ubuntu 现状 Ubuntu 自带应用市场 Ubuntu 自带应用市场目前只有 Geogebra 4.0 版本&#xff0c; 不能画立…

MySQL--数据库基础

1. 数据库简介 1.1什么是数据库&#xff1f; 简单来说就是组织和保存数据的应用程序。 数据库是20世纪60年代末发展起来的⼀项重要技术&#xff0c;已经成为计算机科学与技术的⼀个重要分⽀。数据库技术主要是⽤来解决数据处理的⾮数值计算问题&#xff0c;数据处理的主要内容…

《生成式 AI》课程 第3講 CODE TASK 任务2:角色扮演的机器人

课程 《生成式 AI》课程 第3講&#xff1a;訓練不了人工智慧嗎&#xff1f;你可以訓練你自己-CSDN博客 我们希望你设计一个机器人服务&#xff0c;你可以用LM玩角色扮演游戏。 与LM进行多轮对话 提示:告诉聊天机器人扮演任意角色。 后续输入:与聊天机器人交互。 Part 2: Role…

SpringCloud篇(配置中心 - Nacos)

目录 一、Nacos 配置中心 1. 统一配置管理 1.1. 在nacos中添加配置文件 1.2. 从微服务拉取配置 1.2.1. 引入nacos-config依赖 1.2.2. 添加bootstrap.yaml 1.2.3. 读取nacos配置 1.2.4. 页面访问 2. 配置热更新&#xff1a;两种 2.1. 方式一 2.2. 方式二 3. 配置共享…