【Python_Opencv图像处理框架】边缘检测、轮廓检测、图像金字塔

news2024/9/21 20:46:00

写在前面

本篇文章是opencv学习的第四篇文章,主要讲解了边缘及轮廓检测的主要操作,并对两种图像金字塔简单的介绍了一下,作为初学者,我尽己所能,但仍会存在疏漏的地方,希望各位看官不吝指正😍


写在中间

一、Canny边缘检测

( 1 )简单介绍

Canny边缘检测是一种常用的图像处理算法,它能够在图像中快速准确地识别出物体的边缘。

边缘检测算法步骤:

首先使用高斯滤波器对原始图像进行滤波,用于去除图像中的噪声

然后计算图像的梯度,通过阈值处理以便识别出图像中的边缘

接着使用非极大值抑制,避免假阳性和重复检测。

最后使用双阈值算法进行边缘连接和筛选

( 2 )操作实现

cv2.Canny(img, 120, 250)

这三个参数是用于Canny边缘检测的阈值参数。其中:

  • img是需要进行边缘检测的图像。

  • 120是低阈值,用于过滤掉弱边缘。

  • 250是高阈值,用于较好地保留强边缘。

在Canny边缘检测中,像素点的灰度值如果大于高阈值,就被认为是强边缘,如果小于低阈值,就被认为是非边缘。如果在两者之间,那么只有与强边缘相连通的像素点才被认为是边缘。通过调整这两个阈值,可以控制检测到的边缘数量和质量。

( 3 )代码实现

import cv2
import matplotlib.pyplot as plt
import numpy as np

img = cv2.imread("D:\python\Program\pythonProject\photos\\bear.png", 0)

v1 = cv2.Canny(img, 100, 150)
v2 = cv2.Canny(img, 20, 70)

res = np.hstack((v1, v2))  # 拼接

cv2.imshow('result', res)
cv2.waitKey(0)
cv2.destroyAllWindows()

( 4 )效果展示

在这里插入图片描述


二、图像金字塔

(1)简单介绍

图像金字塔是一种特殊的多尺度图像结构,它可以在不同尺度下对图像进行表示,从而实现对图像局部特征的提取。

图像金字塔通常由两个部分组成,即高斯金字塔拉普拉斯金字塔

高斯金字塔:可以通过向下采样法得到较小的图片,也可以通过向上采样法得到较大的图片。

   向下采样法(缩小)

   向上采样法(增大)

拉普拉斯金字塔:则是指将两个相邻尺度的高斯金字塔图像相减得到的亮度差异图像。

   低通滤波

   降采样(缩小尺寸)

   内插(放大尺寸)

   带通滤波(图像相减)

(2)操作实现

向下采样法:img_down = cv2.pyrDown(img)

向上采样法:img_up = cv2.pyrUp(img_down)

拉普拉斯:img_laplacian = cv2.subtract(img, img_up)

拉普拉斯采样法就是先将原始图像向下采样,接着向上采样,最后将原始图像减去两次采样的结果。

( 3 )代码展示

import cv2
img = cv2.imread("D:\python\Program\pythonProject\photos\\bear.png", 0)

img_down = cv2.pyrDown(img)  # 向下采样
img_up = cv2.pyrUp(img_down)  # 向上采样
img_laplacian = img - img_up  # 拉普拉斯金字塔
cv2.imshow('Original', img)
cv2.imshow('Down', img_down)
cv2.imshow('Up', img_up)
cv2.imshow('Laplacian', img_laplacian)
cv2.waitKey(0)
cv2.destroyAllWindows()

(3)效果展示

原图:

在这里插入图片描述

向下采样:

在这里插入图片描述

向上采样:

在这里插入图片描述

拉普拉斯金字塔:

在这里插入图片描述


三、轮廓检测

( 1 )简单介绍

轮廓检测是指在图像中检测出所有轮廓,并将它们可视化。下面是 OpenCV 中轮廓检测的基本步骤:

  1. 读取图像:使用cv2.imshow()函数读取图像。

  2. 转换为灰度图像:为了检测出轮廓,需要将图像转换为灰度图像。可以使用 cv2.cvtColor() 函数将图像从 BGR 颜色空间转换为灰度颜色空间。

  3. 二值化:使用 cv2.threshold() 函数将灰度图像转换为二值图像。这一步可以将图像中的白色区域和黑色区域分开。

  4. 轮廓检测:使用 cv2.findContours() 函数检测出图像中的所有轮廓。这个函数可以返回一个轮廓列表,其中每个轮廓是一个由点组成的数组。

  5. 可视化:使用drawContours() 函数将轮廓可视化。这个函数可以将轮廓画在原始图像上,或者将轮廓绘制在其他图像上,以便进一步分析和处理。

( 2 )操作实现

轮廓检测:contours, hierarchy = cv2.findContours(img,mode,method)

img:要查找区域的二值图像

mode:几种常用图像模式

cv2.RETR_EXTERNAL:只检测最外层轮廓线。
cv2.RETR_LIST:检测所有轮廓线,但不建立轮廓之间的等级关系。
cv2.RETR_CCOMP:检测所有轮廓线,并建立两层轮廓间的等级关系(外层和内层)。
cv2.RETR_TREE:检测所有轮廓线,并重构轮廓之间的嵌套结构。

method:轮廓逼近方法

cv2.CHAIN_APPROX_NONE:存储所有轮廓点,意味着不存在轮廓线之间的点的冗余。

cv2.CHAIN_APPROX_SIMPLE:仅存储水平、竖直和对角线上的端点,使得轮廓线之间的点更加紧凑。

contours是一个列表,包含了所有找到的轮廓,每个轮廓是一个列表,包含了轮廓的坐标信息(即起点、终点、长度等)

hierarchy是一个字典,包含了每个轮廓的层级关系,即从父节点到子节点的层级关系

轮廓绘制:cv2.drawContours(copy, contours, -1, (0, 0, 255), 1)

参数含义:绘制图像,轮廓,轮廓索引,颜色模式(BGR),线条宽度

( 3 )代码实现

# 边缘检测
img = cv2.imread("D:\python\Program\pythonProject\photos\A5.png")

# 转灰度图
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

# 转二值图
ret, thresh = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)  # 二值化操作,像素值大于127的点用225表示,小于阈值使用0表示

# 轮廓检测
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_NONE)

# 轮廓绘制
copy = img.copy()
res = cv2.drawContours(copy, contours, -1, (0, 0, 255), 2)

cv2.imshow('Laplacian', res)
cv2.imwrite("D:\python\Program\pythonProject\photos\Figure_12.png", res)
cv2.waitKey(0)
cv2.destroyAllWindows()

( 4 )效果展示

在这里插入图片描述


写在后面

👍🏻 点赞,你的认可是我创作的动力!
⭐ 收藏,你的青睐是我努力的方向!
✏️ 评论,你的意见是我进步的财富!

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

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

相关文章

Kafka3.0.0版本——生产者数据有序与乱序

目录 一、生产经验数据有序二、生产经验数据乱序2.1、kafka1.x版本之前保证数据单分区有序的条件2.2、kafka1.x版本及以后保证数据单分区有序的条件2.3、kafka1.x版本及以后开启幂等性数据单分区有序的原因 一、生产经验数据有序 单分区内,数据有序。如下图partion…

React之购物车+动态获取参数+Hooks+Redux

1、redux-logger中间件 1️⃣:安装redux-logger依赖包 yarn add redux-logger 2️⃣:在store的配置文件index中配置 import {legacy_createStore as applyMiddleware,applyMiddleware} from reduximport counterReducer from ./counterReducerimport {c…

【论文写作】-我的第一篇论文形成记(投稿过程、课题来源、python与数学学习、实验设计、论文思路建立与写作、回复审稿人)

我的第一篇论文形成记 投稿过程背景记录课题来源-本科毕业设计python及数学学习实验设计调参阶段实验阶段 论文思路建立论文写作回复审稿人总结 投稿过程 2022年12月28日 投AIChE 2023年01月05日 AlChE编辑认为方向不太符合期刊定位,建议投其他期刊 2023年01月06日…

SpringCloud_服务调用OpenFeign和断路器Resilience4J

文章目录 一、负载均衡概论1、服务器负载均衡2、客户端负载均衡3、客户端负载均衡策略(SpringCloudRibbon)4、客户端负载均衡策略(SpringCloudLoadBalancer) 二、SpringCloudOpenFeign服务调用1、OpenFeign服务调用的使用2、OpenFeign服务调用的日志增强3、OpenFeign服务调用超…

Vector - CAPL - 检查DUT发出与dbc定义一致

目录 ChkCreate_UndefinedMessageReceived 代码示例 有回调函数 无回调函数 Trace报文 报告显示 ChkCreate_UndefinedMessage

一维离散小波变换原理和代码实现

基本原理: 离散小波变换:对连续小波变换的尺度因子和时移动因子采用不同的离散条件进行离散,得到Discrete Wavelet Transform(DWT)。降低计算量的同时,保持连续小波变换的光滑性、紧支性、对称性。 离散小波函数: ψ…

脚本函数基础

shell脚本编程系列 函数是一个脚本代码块,可以为其命名并在脚本中的任何位置重用它。每当需要在脚本中使用该代码块时,直接写函数名即可。称作调用函数。 创建函数 方式1: function name {commands }name定义了该函数的唯一名称&#xff0…

私有部署、重构企业软件,第四范式发布大模型“式说”

大模型领域再添重要一员! 4月26日,第四范式首次向公众展示其大模型产品「式说3.0」,并首次提出AIGS战略(AI-Generated Software):以生成式AI重构企业软件。式说将定位为基于多模态大模型的新型开发平台&…

ImageJ 用户手册——第五部分(菜单命令Process)

这里写目录标题 ImageJ 用户手册——第五部分29. Process29.1 Smooth29.2 Sharpen29.3 Find Edges29.4 Find Maxima29.5 Enhance Contrast29.6 Noise29.6.1 Add Noise29.6.2 Add Specified Noise29.6.3 Salt and Pepper29.6.4 Despeckle29.6.5 Remove Outliers29.6.6 Remove Na…

Shell编程条件语句 if case (愿此行终抵群星)

一、Shell条件语句 Shell环境根据命令执行后的返回状态值($?)来判断是否执行成功,当返回值为0(真 true)时表示成功,返回值为非0值(假 false)时表示失败或异常。 test 命令 更多操作可使用 man test 查看 1.条件表达式…

深度学习论文分享(二)Data-driven Feature Tracking for Event Cameras

深度学习论文分享(二)Data-driven Feature Tracking for Event Cameras(CVPR2023) 前言Abstract1. Introduction2. Related Work3. Method3.1. Feature Network3.2. Frame Attention Module3.3. Supervision 4. Experiments5. Con…

焕新时刻,移动云品牌升级燃动十一城

4月25日,在2023移动云大会上,移动云品牌形象全方位焕新,启用新品牌LOGO和品牌标语,在政府领导、院士专家、行业大咖等3000多位参会嘉宾见证下,吹响品牌进阶新号角。 24日晚,移动云品牌焕新亮灯仪式率先在苏…

C语言入门篇——指针篇

目录 1、指针 1.1内存地址 1.2基地址 1.3指针变量 2、指针类型 2.1指针-整数 2.2指针的解引用 3、特殊指针 3.1野指针 3.2空指针 4、指针运算 4.1指针-指针 4.2指针的关系运算 5、指针和数组 6、二级指针 7、指针数组 1、指针 1.1内存地址 内存是电脑上特别重…

剑指offer 26树的子结构

文章目录 题目详情分析判断A中有出现和B相同的结构和节点值递归主体,解决问题 完整代码总结 题目详情 树的子结构 输入两棵二叉树A和B,判断B是不是A的子结构。(约定空树不是任意一个树的子结构) B是A的子结构, 即 A中有出现和B相同的结构和节…

合并两个有序链表

文章目录 1.题目描述2.解题思路方法1:方法2: 1.题目描述 题目链接:力扣21,合并两个有序链表 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 2.解题思路 方法1:…

【python】多进程和多线程

【Python】多线程 概念 同一时间内能够执行多个任务 执行方式 并发:多个任务交替去运行 并发:多喝CPU中,多个任务是在多个CPU上运行的 一般来说:并发和并行是同时存在的,是操作系统自动调用的 实现方式 多进程实…

系统集成项目管理工程师 笔记(第九章:项目成本管理)

文章目录 9.1.1 成本与成本管理概念 329项目成本管理的过程 9.1.2 相关术语 331成本的类型(6种)应急储备与管理储备 9.2.3 项目成本管理计划制订的 输出 3349.3.1 项目成本估算的主要相关因素 335项目估算还需要考虑但 容易被忽视的 主要因素 9.3.2 项目…

随机森林(Random Forest)简单介绍

文章目录 随机森林(Random Forest)简单介绍1. 介绍2. 工作原理2.1 随机森林的基本原理2.1.1 随机采样2.1.2. 随机选特征2.1.3. 多数表决 2.2 随机森林的建模过程2.2.1. 建立多颗决策树2.2.2. 特征随机选择2.2.3. 样本随机选择2.2.4. 决策树训练与生成2.2…

发现【Stable-Diffusion WEBUI】的神奇插件:离线自动翻译中文提示词

文章目录 (零)前言(一)提示词翻译(Prompt Translator)(1.1)尚需改进 (零)前言 本篇主要提到了WEBUI的提示词翻译插件,之前我说不喜欢联网的插件&a…

【单目标优化算法】沙猫群优化算法(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…