OpenCV图像分割教程

OpenCV 图像分割教程

OpenCV 是一个非常强大的计算机视觉库,支持各种图像处理任务。图像分割是 OpenCV 支持的一个重要功能,它用于将图像划分为不同的区域,识别感兴趣的部分。我们将通过介绍 OpenCV 中的图像分割方法,包括基础功能、进阶功能和高级功能,来帮助你理解和掌握图像分割的应用。

官方文档链接:

OpenCV 官方文档


一、OpenCV 库概述

1.1 什么是 OpenCV?

OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库。它为实时图像处理任务提供了数百种高效的工具和算法,并广泛应用于领域如图像处理、视频分析、机器学习、增强现实等。

1.2 OpenCV 的架构

  • 核心模块:提供基本的数据结构和工具。
  • 图像处理模块:支持各种图像变换和滤波操作。
  • 对象检测模块:支持基于深度学习的检测算法。
  • 视频分析模块:支持运动检测、跟踪和背景分割。
  • 机器学习模块:提供各种经典的机器学习算法。

二、基础功能:阈值分割

阈值分割是最简单的一种图像分割方法,它通过将图像的像素值与某个阈值进行比较,来区分前景和背景。该方法适用于图像的亮度差异明显的情况。

2.1 基础 API 介绍

cv2.threshold() 是 OpenCV 提供的主要阈值分割函数。其语法为:

retval, dst = cv2.threshold(src, thresh, maxval, type)
  • src:输入图像(灰度图)。
  • thresh:阈值。
  • maxval:当像素值大于阈值时,分配给它的值。
  • type:阈值类型(如二值化、反二值化等)。

2.2 代码示例

import cv2
import numpy as np# 读取灰度图像
image = cv2.imread('example.jpg', 0)# 应用全局阈值
ret, thresh1 = cv2.threshold(image, 127, 255, cv2.THRESH_BINARY)# 显示原图和阈值分割后的图像
cv2.imshow('Original Image', image)
cv2.imshow('Thresholded Image', thresh1)cv2.waitKey(0)
cv2.destroyAllWindows()

解释

  • 该代码将图像读取为灰度图,然后应用全局阈值分割,所有像素值大于127的部分被设置为255(白色),小于127的部分被设置为0(黑色)。

三、进阶功能:自适应阈值与 Otsu 分割

对于具有复杂光照条件的图像,全局阈值方法可能效果不好。自适应阈值和 Otsu 方法可以帮助处理更复杂的场景。

3.1 自适应阈值

自适应阈值根据图像的局部区域计算阈值,更适用于光照不均匀的图像。

cv2.adaptiveThreshold() 的语法为:

dst = cv2.adaptiveThreshold(src, maxValue, adaptiveMethod, thresholdType, blockSize, C)
  • adaptiveMethod:使用的自适应阈值算法,常用 cv2.ADAPTIVE_THRESH_MEAN_Ccv2.ADAPTIVE_THRESH_GAUSSIAN_C
  • blockSize:计算局部阈值的邻域大小。
  • C:从平均值或加权平均值中减去的常数。

3.2 Otsu 分割

Otsu 方法可以自动计算最优阈值,用于二值化。

ret2, th2 = cv2.threshold(image, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)

3.3 代码示例

import cv2# 读取灰度图像
image = cv2.imread('example.jpg', 0)# Otsu 阈值分割
ret2, th2 = cv2.threshold(image, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)# 自适应阈值分割
th3 = cv2.adaptiveThreshold(image, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, 11, 2)# 显示分割结果
cv2.imshow('Otsu Threshold', th2)
cv2.imshow('Adaptive Threshold', th3)cv2.waitKey(0)
cv2.destroyAllWindows()

解释

  • 使用 Otsu 方法自动计算最佳阈值,二值化图像。
  • 自适应阈值则根据局部区域计算阈值,适合处理光照不均的图像。

四、高级功能:分水岭算法

分水岭算法是一种更复杂的图像分割方法,通常用于分割重叠物体。

4.1 分水岭算法的工作原理

分水岭算法将图像视为一个地形图,图像的亮度值表示高程,算法将找到各个低谷区域的边界进行分割。

4.2 使用分水岭算法的步骤:

  1. 预处理图像(如应用高斯模糊)。
  2. 使用阈值或其他方法生成二值图像。
  3. 通过距离变换生成标记图像。
  4. 应用分水岭算法进行分割。

4.3 代码示例

import cv2
import numpy as np# 读取图像
image = cv2.imread('example.jpg')
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 阈值化处理
ret, thresh = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU)# 去除噪声
kernel = np.ones((3,3), np.uint8)
opening = cv2.morphologyEx(thresh, cv2.MORPH_OPEN, kernel, iterations=2)# 确定背景
sure_bg = cv2.dilate(opening, kernel, iterations=3)# 确定前景
dist_transform = cv2.distanceTransform(opening, cv2.DIST_L2, 5)
ret, sure_fg = cv2.threshold(dist_transform, 0.7*dist_transform.max(), 255, 0)# 标记未确定区域
sure_fg = np.uint8(sure_fg)
unknown = cv2.subtract(sure_bg, sure_fg)# 标记
ret, markers = cv2.connectedComponents(sure_fg)# 加 1 ,确保背景是 1 而不是 0
markers = markers + 1# 标记未知区域为 0
markers[unknown == 255] = 0# 应用分水岭算法
markers = cv2.watershed(image, markers)
image[markers == -1] = [255, 0, 0]# 显示结果
cv2.imshow('Watershed Result', image)
cv2.waitKey(0)
cv2.destroyAllWindows()

解释

  • 通过形态学操作去除噪声,确定前景和背景。
  • 使用距离变换识别前景区域。
  • 分水岭算法处理图像,最终得到边界。

总结

我们介绍了 OpenCV 中的几种图像分割方法,从最基础的阈值分割,到进阶的自适应阈值和 Otsu 方法,再到高级的分水岭算法。根据不同的应用场景,选择合适的分割方法是关键。

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

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

相关文章

ubantu安装mysql + redis数据库并使用C/C++操作数据库

mysql 安装mysql ubuntu 安装 MySql_ubuntu安装mysql-CSDN博客 Ubuntu 安装 MySQL 密码设置_ubuntu安装mysql后设置密码-CSDN博客 service mysql restart1 C/C连接数据库 C/C 连接访问 MySQL数据库_c mysql-CSDN博客 ubuntu安装mysql的c开发环境_ubuntu 搭建mysql c开发…

测试一些概念

软件测试 软件测试流程 需求分析:在这个阶段,测试人员会审查和分析项目的需求文档,以确保他们理解需要测试的功能和特性。 制定测试计划:在这个阶段,测试人员会制定一个详细的测试计划,包括测试目标、测…

跨越技术壁垒:EasyCVR为何选择支持FMP4格式,重塑视频汇聚平台标准

随着物联网、大数据、云计算等技术的飞速发展,视频监控系统已经从传统的安防监控扩展到智慧城市、智能交通、工业制造等多个领域。视频流格式作为视频数据传输与存储的基础,其兼容性与效率直接影响到整个视频监控系统的性能。 在众多视频流格式中&#…

TCP Analysis Flags 之 TCP Port numbers reused

前言 默认情况下,Wireshark 的 TCP 解析器会跟踪每个 TCP 会话的状态,并在检测到问题或潜在问题时提供额外的信息。在第一次打开捕获文件时,会对每个 TCP 数据包进行一次分析,数据包按照它们在数据包列表中出现的顺序进行处理。可…

pytorch计算网络参数量和Flops

from torchsummary import summary summary(net, input_size(3, 256, 256), batch_size-1)输出的参数是除以一百万(/1000000)M, from fvcore.nn import FlopCountAnalysis inputs torch.randn(1, 3, 256, 256).cuda() flop_counter FlopCo…

停车场小程序如何实现分账功能?

智慧停车平台为什么迫切需要分账功能的原因,通过清结算系统提供的服务商分账功能,可以有效提高交易环节的分账效率。平台方只需要在后台配置好与各服务商、业主等多方分账规则,待交易订单形成后,清结算系统会自动化分账&#xff0…

十大口碑最好开放式蓝牙耳机是哪些?五款热销好用产品测评!

​开放式耳机现在超火,成了时尚、好看又舒服的代名词,迅速俘获了一大波粉丝,成了耳机界的新宠儿。跟那些传统的入耳式耳机比起来,开放式耳机戴着更稳,对耳朵也更友好。不过,也有人觉得这玩意儿不值&#xf…

系统找不到指定的文件怎么解决?

把U盘插在电脑上,当我打开U盘中的文件时,弹窗提示系统找不到指定的文件,这是什么情况?有谁遇到过吗?大家有没有解决办法? 这个问题可能大家并不陌生,可能也曾遇到过,造成问题出现的原…

现代计算机中数字的表示与浮点数、定点数

现代计算机中数字的表示与浮点数、定点数 导读:浮点数运算是一个非常有技术含量的话题,不太容易掌握。许多程序员都不清楚使用操作符比较float/double类型的话到底出现什么问题。这篇文章讲述了浮点数的来龙去脉,所有的软件开发人员都应该读…

sqli-lab靶场学习(一)——Less1-4

前言 最近一段时间想切入安全领域,因为本身有做数据库运维工作,就打算从sql注入方向切入。而sql注入除了学习日常书本上的概念外,需要有个实践的环境,刚好看到sqli-lab这个靶场,就打算先用这个来学习。 安装部署 网上…

指针初始化和定义

简要 在计算机中我们把内存单元的编号也称为地址。C语言中给地址起了新的名字叫:指针。 所以我们可以理解为:内存单元的编号 地址 指针 1.指针指向变量的初始化 初始化定义方式: 指针变量名 & 变量名; 若在定义时初始…

【Spring Boot 3】【Web】统一封装 HTTP 响应体

【Spring Boot 3】【Web】统一封装 HTTP 响应体 背景介绍开发环境开发步骤及源码工程目录结构总结背景 软件开发是一门实践性科学,对大多数人来说,学习一种新技术不是一开始就去深究其原理,而是先从做出一个可工作的DEMO入手。但在我个人学习和工作经历中,每次学习新技术总…

小阿轩yx-Kubernertes日志收集

小阿轩yx-Kubernertes日志收集 前言 在 Kubernetes 集群中如何通过不同的技术栈收集容器的日志,包括程序直接输出到控制台日志、自定义文件日志等 有哪些日志需要收集 日志收集与分析很重要,为了更加方便的处理异常 简单总结一些比较重要的需要收集…

数据分析面试题:如何分析每日平均每件商品的锁定时长问题?

目录 0 题目描述 2 数据准备 3 数据分析 3.1 需求1:计算 2014/03/22-2014/04/30 每天的购买客户数、订单量、销售件数、销售额 3.2 计算 2014 年 4 月各品类的销售额、晚上 20-24 点销售额 3.3 提取 2014 年 3-5 月销售额排名前三的客户信息(排名/客户号/客户姓名/总销…

深入理解Elasticsearch的`_source`字段与索引优化

在Elasticsearch (ES) 中,_source字段是一个关键组件,它不仅决定了数据的存储方式,还影响到查询时返回的内容。在某些场景下,我们可以通过配置_source来优化存储和性能,尤其是当我们希望减少存储空间或避免返回某些字段…

如何保障Kubernetes集群安全?

如何保障Kubernetes集群安全? 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes通过多重机制保障集群安全,主要包括: 容器隔离:容器与宿主机隔离,防止相互影响。权限控制:遵循最小权限原则,限制组件和用户权限,使用RBAC进行细粒度管理。API Server安全:通过认证…

如何让linux程序在后台执行

怎么让linux程序在后台执行: 一、在命令末尾添加 “&” 符号 例如,要运行一个名为 my_program 的程序并让它在后台执行,可以这样做: my_program &执行这个命令后,程序会在后台运行,终端会立即返回…

华为OD机试真题 - 二叉树的广度优先遍历 - 二叉树(Python/JS/C/C++ 2024 D卷 200分)

华为OD机试 2024E卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试真题(Python/JS/C/C)》。 刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,…

(六十二)第 9 章 查找(开放定址哈希表)

示例代码 hashTable.h // 开放定址哈希表的存储结构实现头文件#ifndef HASH_TABLE_H #define HASH_TABLE_H#include "errorRecord.h"#define NULL_KEY -2 #define NUM 10#define SUCCESS 1 #define UNSUCCESS 0 #define DUPLICATE -1#define EQUAL(a, b) ((a) == (b)…

Github 2024-09-07Rust开源项目日报Top10

根据Github Trendings的统计,今日(2024-09-07统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Rust项目10CUE项目1Python项目1Go项目1Polars: Rust中的DataFrame接口和OLAP查询引擎 创建周期:1354 天开发语言:Rust, Python协议类型:MIT …