计算机视觉中的双边滤波:经典案例与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

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

模板——实现泛型编程的有力武器

模板——实现泛型编程的有力武器 我们为什么需要模板?模板 前言:关于模板,相信大家都有所而闻,以下是我对C模板的个人看法,希望能够帮助到你们呀! 我们为什么需要模板? 请到大家看这一段代码&a…

Hugging_Face下载

能进huggingface的就能翻过去 不行的话可以去参考这个:mojie.app 1.直接原网下载 2.git(小白勿入) 如果是Linux,可以搜一个叫HFD(HuggingFace_Download) Windows的git安装参考如下:Git安装 建议先看看这个文档, 如果…

C++之内存管理

​ 🌹个人主页🌹:喜欢草莓熊的bear 🌹专栏🌹:C入门 目录 前言 一、C/C内存分配 二、 malloc、calloc、realloc、free 三、C内存管理方式 3.1 new/delete 操作内置类型 3.2 new和detele操作自定义类型…

QT适配最新版Android SDK

从AndroidStudio的SDK管理下载最新版SDK 从https://www.androiddevtools.cn/下载国内安卓SKDTools 这里下载SKDTools后不需要使用SDK Manager.exe下载SDK(SDK Manager.exe下载的SDK都是旧版,没法支持新版本),直接使用从AndroidS…

Ubuntu 环境下通过 Apt-get 安装软件

操作场景 为提升用户在云服务器上的软件安装效率,减少下载和安装软件的成本,腾讯云提供了 Apt-get 下载源。在 Ubuntu 环境下,用户可通过 Apt-get 快速安装软件。对于 Apt-get 下载源,不需要添加软件源,可以直接安装软…

反转链表、链表内指定区间反转

反转链表 给定一个单链表的头结点pHead(该头节点是有值的,比如在下图,它的val是1),长度为n,反转该链表后,返回新链表的表头。 如当输入链表{1,2,3}时,经反转后,原链表变…

SpringCloud篇(服务网关 - GateWay)

目录 一、简介 二、为什么需要网关 二、gateway快速入门 1. 创建gateway服务,引入依赖 2. 编写启动类 3. 编写基础配置和路由规则 4. 重启测试 5. 网关路由的流程图 6. 总结 三、断言工厂 四、过滤器工厂 1. 路由过滤器的种类 2. 请求头过滤器 3. 默认…

MATLAB实现历史模拟法计算VaR(Value at Risk)

MATLAB实现历史模拟法计算VaR(Value at Risk) 历史模拟法(Historical Simulation Method)是一种用于计算风险值(Value at Risk, VaR)的非参数方法。它基于过去的资产价格或收益数据来估计未来的潜在损失。 MATLAB代码如下: 完整…

数据结构——红黑树

目录 一.红黑树 二.红黑树的实现 1.红黑树节点的定义 2.红黑树的插入 3.红黑树的遍历 4.检测红黑树 5.红黑树的查找 6.红黑树的性能 三.整体代码 1.RBTree.h 2.RBTree.cpp 一.红黑树 1.红黑树的概念 红黑树,是一种二叉搜索树,但在每个结点上…

OMV7 树莓派 tf卡安装

​ 升级7之后,问题多多,不是docker不行了,就是代理不好使 今天又重装了一遍,用官方的链接,重新再折腾一遍…… 使用raspberry pi imager安装最新版lite OS。 注意是无桌面 Lite版 配置好树莓派初始化设置&#xff0…

Java集合ConcurrentHashMap——针对实习面试

目录 Java集合ConcurrentHashMapConcurrentHashMap的特性是什么?HashMap和ConcurrentHashMap的区别?说说ConcurrentHashMap的底层实现 Java集合ConcurrentHashMap ConcurrentHashMap的特性是什么? 线程安全性 多线程并发读写安全&#xff1a…

攻防世界-mfw

进入题目以后可以点击三个网页&#xff0c;这三个网页其中有一个提示我们git、php、Bootstrap。可以联想到是git泄露 在url后面的参数改为.git 存在git漏洞&#xff0c;这时候就可以利用python的githacker库下载泄漏的文件 查看index.php的源代码 <?phpif (isset($_GET[pa…

MySQL面试之底层架构与库表设计

华子目录 mysql的底层架构客户端连接服务端连接的本质&#xff0c;连接用完会立马丢弃吗解析器和优化器的作用sql执行前会发生什么客户端的连接池和服务端的连接池数据库的三范式 mysql的底层架构 客户端连接服务端 连接的本质&#xff0c;连接用完会立马丢弃吗 解析器和优化器…

代理(下):结构化工具对话、Self-Ask with Search以及Plan and execute代理

在上一讲中&#xff0c;我们深入LangChain程序内部机制&#xff0c;探索了AgentExecutor究竟是如何思考&#xff08;Thought&#xff09;、执行&#xff08;Execute/Act&#xff09;和观察&#xff08;Observe&#xff09;的&#xff0c;这些步骤之间的紧密联系就是代理在推理&…

RPC-路由策略

为什么选择路由策略&#xff1f; 每次上线应用的时候都不止一台服务器会运行实例&#xff0c;那上线就涉及到变更&#xff0c;只要变更就可能导致原本正常运行的程序出现异常&#xff0c;尤其是发生重大变动的时候&#xff0c;导致应用不稳定的因素就变得很多。 灰度发布应用…

ctf日常

8&#xff0c; [NISACTF 2022]easyssrf 跨目录读取 NSSCTF{c42d6e04-f7cb-4ac4-925b-efd9b90c76ff} 9&#xff0c; [SWPUCTF 2021 新生赛]hardrce <?php header("Content-Type:text/html;charsetutf-8"); error_reporting(0); highlight_file(__FILE__); if(is…

Linux笔记---调试工具GDB(gdb)

1. gdb的概念 GDB&#xff0c;全称GNU Debugger&#xff0c;是一个功能强大的开源调试工具&#xff0c;广泛用于Unix和类Unix系统&#xff0c;以及Microsoft Windows和macOS平台。GDB允许开发者在程序执行过程中查看内部运行情况&#xff0c;帮助定位和修复程序中的错误。 gd…

服务架构的演进:从单体到微服务的探索之旅

服务架构的演进&#xff1a;从单体到微服务的探索之旅 一 . 服务架构演变1.1 单体架构1.2 分布式架构1.3 微服务1.4 小结 二 . 微服务技术对比2.1 微服务系统架构图2.2 微服务技术对比2.3 企业需求 三 . Spring Cloud 随着企业业务的不断拓展和复杂度的提升&#xff0c;对软件系…

【论文笔记】LLaMA-VID: An Image is Worth 2 Tokens in Large Language Models

&#x1f34e;个人主页&#xff1a;小嗷犬的个人主页 &#x1f34a;个人网站&#xff1a;小嗷犬的技术小站 &#x1f96d;个人信条&#xff1a;为天地立心&#xff0c;为生民立命&#xff0c;为往圣继绝学&#xff0c;为万世开太平。 基本信息 标题: LLaMA-VID: An Image is W…

leetcode_二叉树最大深度

对二叉树的理解 对递归调用的理解 对内存分配的理解 基础数据结构&#xff08;C版本&#xff09; - 飞书云文档 每次函数的调用 都会进行一次新的栈内存分配 所以lmax和rmax的值不会混在一起 /*** Definition for a binary tree node.* struct TreeNode {* int val;* …