第五章:图像分割

图像分割

图像分割是将数字图像划分为多个区域的过程,这些区域具有一定的相似性或共同属性(如:颜色、亮度、纹理等)。图像分割的目标是简化或改变图像的表示形式,使得图像更容易分析和理解。

5.1. 阈值分割

定义:阈值分割是一种基于图像灰度值的分割方法,将图像中的像素分为目标物体和背景两类。通过选取一个阈值T,将图像中的像素根据灰度值与T的关系划分为不同的类别。

数学公式:g(x, y) = 1, 如果 f(x, y) > T; g(x, y) = 0, 如果 f(x, y) <= T,其中f(x, y)表示原始图像的灰度值,g(x, y)表示二值化后的图像。

用途:阈值分割用于提取图像中的目标物体,适用于目标和背景之间对比度较高的情况。

代码实现(Python):全局阈值分割

import cv2

# 读取图像
image = cv2.imread('path/to/your/image.jpg', cv2.IMREAD_GRAYSCALE)

# 阈值分割
 _, thresholded_image = cv2.threshold(image, 128, 255, cv2.THRESH_BINARY)

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

5.2. 边缘检测

定义:边缘检测是一种基于图像局部梯度的分割方法,用于检测图像中的边缘信息。常见的边缘检测算子有Sobel、Canny等。

5.2.1. Sobel算子

数学公式:Sobel算子通过计算图像的梯度来检测边缘。横向梯度Gx和纵向梯度Gy分别为:

Gx = | f(x+1, y-1) + 2f(x+1, y) + f(x+1, y+1) - f(x-1, y-1) - 2f(x-1, y) - f(x-1, y+1) |

Gy = | f(x-1, y+1) + 2f(x, y+1) + f(x+1, y+1) - f(x-1, y-1) - 2f(x, y-1) - f(x+1, y-1) |

边缘强度为:G = sqrt(Gx^2 + Gy^2)

用途:Sobel算子用于检测图像中的边缘信息,可以作为图像分割的预处理步骤。

代码实现(Python):使用Sobel算子检测边缘

import cv2
import numpy as np

# 读取图像
image = cv2.imread('path/to/your/image.jpg', cv2.IMREAD_GRAYSCALE)

# Sobel算子检测边缘
sobel_x = cv2.Sobel(image, cv2.CV_64F, 1, 0, ksize=3)
sobel_y = cv2.Sobel(image, cv2.CV_64F, 0, 1, ksize=3)
sobel_edge = np.sqrt(np.square(sobel_x) + np.square(sobel_y))

# 显示图像
cv2.imshow('Original Image', image)
cv2.imshow('Sobel Edge', sobel_edge.astype(np.uint8))
cv2.waitKey(0)
cv2.destroyAllWindows()

5.2.2. Canny算子

定义:Canny算子是一种多级边缘检测方法,包括高斯滤波、计算梯度幅值和方向、非极大值抑制和双阈值连接等步骤。

用途:Canny算子用于检测图像中的边缘信息,性能较Sobel算子更优。

代码实现(Python):使用Canny算子检测边缘

import cv2

# 读取图像
image = cv2.imread('path/to/your/image.jpg', cv2.IMREAD_GRAYSCALE)

# Canny算子检测边缘
canny_edge = cv2.Canny(image, 100, 200)

# 显示图像
cv2.imshow('Original Image', image)
cv2.imshow('Canny Edge', canny_edge)
cv2.waitKey(0)
cv2.destroyAllWindows()

5.3. 区域分割

定义:区域分割是一种基于像素聚类的分割方法,根据像素间的相似性将图像划分为多个区域。常见的区域分割方法有区域生长和分水岭算法。

5.3.1. 区域生长

定义:区域生长是一种自底向上的分割方法,从一个种子像素开始,逐步将相邻的相似像素合并到同一区域。

用途:区域生长用于将图像划分为具有相似属性的区域,适用于目标与背景的差异较小或边缘信息不明显的情况。


5.3.2. 分水岭算法

定义:分水岭算法是一种基于图像拓扑结构的分割方法,将图像看作地形,每个像素值代表地形高度。局部极小值作为初始种子,从种子开始生长,形成分水岭。

用途:分水岭算法用于将图像划分为具有相似属性的区域,适用于目标与背景的差异较小或边缘信息不明显的情况。

代码实现(Python):使用OpenCV实现分水岭算法

```python
import cv2
import numpy as np

# 读取图像
image = cv2.imread('path/to/your/image.jpg')
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 阈值分割
 _, binary_image = cv2.threshold(gray_image, 0, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU)

# 消除噪声
kernel = np.ones((3, 3), np.uint8)
opening = cv2.morphologyEx(binary_image, cv2.MORPH_OPEN, kernel, iterations=2)

# 确定背景区域
sure_bg = cv2.dilate(opening, kernel, iterations=3)

# 确定前景区域
dist_transform = cv2.distanceTransform(opening, cv2.DIST_L2, 5)
 _, 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)

# 标记标签
 _, markers = cv2.connectedComponents(sure_fg)
markers = markers + 1
markers[unknown == 255] = 0

# 应用分水岭算法
cv2.watershed(image, markers)
image[markers == -1] = [0, 0, 255]

# 显示图像
cv2.imshow('Original Image', cv2.imread('path/to/your/image.jpg'))
cv2.imshow('Segmented Image', image)
cv2.waitKey(0)
cv2.destroyAllWindows()

扩展:

图像分割方法还包括聚类算法(如:K-means)、图割(如:GrabCut)、超像素分割(如:SLIC)等。深度学习方法(如:全

卷积网络FCN、U-Net等)在图像分割领域也取得了显著的成果。这些方法在一定程度上可以解决传统方法在复杂场景中的局限性。以下是一些扩展方法的简要介绍。

5.4. K-means聚类

定义:K-means聚类是一种无监督学习方法,通过迭代优化将图像像素划分为K个聚类中心。

用途:K-means聚类可用于将图像划分为具有相似属性的区域。

5.5. GrabCut

定义:GrabCut是一种基于图割的分割方法,通过最小化能量函数找到图像中目标物体与背景之间的最优分割边界。

用途:GrabCut适用于将目标物体从复杂背景中分割出来。

5.6. SLIC超像素分割

定义:SLIC(Simple Linear Iterative Clustering)是一种基于局部聚类的超像素分割方法,将图像划分为具有相似颜色和空间位置的超像素。

用途:SLIC超像素分割可用于将图像划分为具有相似属性的区域,作为高级视觉任务的预处理步骤。

5.7. 深度学习方法

随着深度学习的发展,许多基于卷积神经网络(CNN)的图像分割方法取得了显著的成果。例如,全卷积网络(FCN)将传统的全连接层替换为卷积层,实现像素级别的分类;U-Net结构通过使用跳跃连接融合高层次特征和低层次特征,提高分割性能。这些方法可以在复杂场景中实现精确的图像分割。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

深度学习客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值