作者 | 小白

来源 | 小白学视觉

了解图像分割

当我们在做一个图像分类任务时,首先我们会想从图像中捕获感兴趣的区域,然后再将其输入到模型中。让我们尝试一种称为基于聚类的图像分割技术,它会帮助我们在一定程度上提高模型性能,让我们看看它是什么以及一些进行聚类分割的示例代码。

什么是图像分割?

想象一下我们要过马路,过马路之前我们会做什么?

首先,我们会看道路两旁,以确定接近的车辆等环境对象,然后我们会对接近的车辆的速度做出一些快速的估计,并决定何时以及如何过马路。所有这些都发生在很短的时间内,非常很的神奇。

  1. 我们的大脑捕捉道路两侧的图像

  2. 它检测道路上的车辆和其他物体==物体检测

  3. 它还确定了它检测到的每个对象的形状 == 图像分割

通过确定不同物体的形状,我们的大脑能够在同一张快照中检测到多个物体,这是多么神奇啊。

让我们进一步了解,假设我们有我们的图像分类模型,它能够以 95% 上的准确率对苹果和橙子进行分类。当我们输入一幅同时包含苹果和橙子的图像时,预测精度会下降。随着图像中对象数量的增加,分类模型的性能会下降,这就是目标定位发挥作用的地方。

在我们检测图像中的对象并对其进行分类之前,模型需要了解图像中的内容,这就是图像分割的帮助所在。它为图像中的对象创建一个像素级的蒙版,这有助于模型更精细地理解对象的形状及其在图像中的位置。

目标检测 VS 图像分割

分割的类型有哪些?

图像分割大致分为两大类。

  1. 语义分割

  2. 实例分割

检测到的对象 — 语义段 — 实例段

在第一张图片中,我们可以看到检测到的对象都是男性。在语义分割中,我们认为所有这些像素都属于一类,因此我们用一种颜色表示它们。另一方面,在实例分割中,这些像素属于同一类,但我们用不同的颜色表示同一类的不同实例。

根据我们使用的分割方法,分割可以分为许多类别。

  • 基于区域的分割

  • 基于边缘检测的分割

  • 基于聚类的分割

  • 基于CNN的分割等。

接下来让我们看一个基于聚类的分割示例。

什么是基聚类的分割?

聚类算法用于将彼此更相似的数据点从其他组数据点更紧密地分组。

现在我们想象一幅包含苹果和橙子的图像。苹果中的大部分像素点应该是红色/绿色,这与橙色的像素值不同。如果我们能把这些点聚在一起,我们就能正确地区分每个物体,这就是基于聚类的分割的工作原理。现在让我们看一些代码示例。

from skimage.io import imread
from skimage.color import rgb2gray
import numpy as np
import matplotlib.pyplot as plt
%matplotlib inline
from scipy import ndimage
# Scaling the image pixels values within 0-1
img = imread('./apple-orange.jpg') / 255
plt.imshow(img)
plt.title('Original')
plt.show()

由于肉眼可见,图像中有五个色段

  1. 苹果的绿色部分

  2. 橙子的橙色部分

  3. 苹果和橙子底部的灰色阴影

  4. 苹果顶部和右侧部分的亮黄色部分

  5. 白色背景

让我们看看我们是否可以使用来自 scikit-learn 的 K 均值算法对它们进行聚类

# For clustering the image using k-means, we first need to convert it into a 2-dimensional array
image_2D = img.reshape(img.shape[0]*img.shape[1], img.shape[2])
# Use KMeans clustering algorithm from sklearn.cluster to cluster pixels in image
from sklearn.cluster import KMeans
# tweak the cluster size and see what happens to the Output
kmeans = KMeans(n_clusters=5, random_state=0).fit(image_2D)
clustered = kmeans.cluster_centers_[kmeans.labels_]
# Reshape back the image from 2D to 3D image
clustered_3D = clustered.reshape(img.shape[0], img.shape[1], img.shape[2])
plt.imshow(clustered_3D)
plt.title('Clustered Image')
plt.show()

效果非常好,我们能够将五个部分组合在一起,这就是聚类分割的工作原理。目前有许多先进的技术,例如 Mask R-CNN,可以进行更细粒度的分割。

Github代码连接:

https://github.com/Mathanraj-Sharma/sample-for-medium-article/blob/master/cluster-based-segmentation-skimage/cluster-based-segmentation.ipynb

资讯

2021 PS 进入人工智能P图时代

资讯

跟人聊天 VS 跟机器聊天?

比赛

人人可用的AI大模型,玩转它

图像

深度学习视频理解之图像分类

分享

点收藏

点点赞

点在看

基于聚类的图像分割(Python)相关推荐

  1. 基于聚类的图像分割-Python

    点击上方"小白学视觉",选择加"星标"或"置顶" 重磅干货,第一时间送达 了解图像分割 当我们在做一个图像分类任务时,首先我们会想从图像中捕 ...

  2. 基于聚类的“图像分割”(python)

    基于聚类的"图像分割" 参考网站: https://zhuanlan.zhihu.com/p/27365576 昨天萌新使用的是PIL这个库,今天发现机器学习也可以这样玩. 视频地 ...

  3. 【CV】基于聚类的图像分割-Python

    了解图像分割 当我们在做一个图像分类任务时,首先我们会想从图像中捕获感兴趣的区域,然后再将其输入到模型中.让我们尝试一种称为基于聚类的图像分割技术,它会帮助我们在一定程度上提高模型性能,让我们看看它是 ...

  4. 基于聚类的“图像分割”案例——K-means聚类算法

    图像分割:利用图像的灰度.颜色.纹理.形状等特征,把图像分成若干个互不重叠的区域,并使这些特征在同一区域内呈现相似性,在不同的区域之间存在明显的差异性.然后就可以将分割的图像中具有独特性质的区域提取出 ...

  5. 基于聚类的“图像分割”

    来源 https://www.icourse163.org/course/BIT-1001872001 图像分割: 利用图像的灰度.颜色.纹理.形状等特征,把图像分成若 干个互不重叠的区域,并使这些特 ...

  6. Python基于聚类算法实现密度聚类(DBSCAN)计算

    本文实例讲述了Python基于聚类算法实现密度聚类(DBSCAN)计算.分享给大家供大家参考,具体如下: 算法思想 基于密度的聚类算法从样本密度的角度考察样本之间的可连接性,并基于可连接样本不断扩展聚 ...

  7. matlab实现谱聚类法图像分割代码,一种基于谱聚类的图像分割方法与系统与流程...

    本发明是一种基于谱聚类的图像分割方法与系统,涉及聚类.机器学习和人工智能领域.特别涉及通过相关性将已经学习到的知识运用到图像分割中,并在此基础上构造性地改造谱聚类方法,从而达到快速精确地分割彩色图像的 ...

  8. 基于聚类的异常值检测算法依据及python实现

    假设数据集D被聚类算法划分到k个类C = {C1 , C2 , -CK},对象p 的离群因子of3(p)定义为 与所有类间距的加权平均值: 其中,|D|为样本数量, |Cj|为第j个聚类群体样本数量, ...

  9. 【图像分割】基于萤火虫优化的半监督谱聚类彩色图像分割方法(Matlab代码实现)

    目录 0 概述 1 萤火虫算法 1.1 思想来源 1.2 数学模型 1.2.1 萤火虫相对荧光亮度 1.2.2 萤火虫吸引度 1.2.3 位置更新 1.3 算法步骤 2 基于萤火虫优化的半监督谱聚类彩 ...

最新文章

  1. git diff 比较文件_使用Python创建你自己的diff工具
  2. (0088)iOS开发之单例的写法以及重新认识
  3. 6.news.php,news.php
  4. 【线上圆桌整理 - 腾讯会议】进化中的视频会议
  5. FFMPEG结构体分析
  6. 用台球杆击球,这个击球力道能传递到10米之外的球上吗?
  7. 数组中的forEach和map的区别
  8. c++学习笔记(5)
  9. Type erroe in tensorflow
  10. 多语言页面语言标签的使用更适合推广
  11. openwrt编译qca驱动不成功。gcc -isystem问题。
  12. android按钮延迟显示出来,android Toast显示延迟的优化方案
  13. PDF内容太多分不清?这个PDF加页码的方法可以帮助你
  14. linux 使用c语言如何获取网关地址
  15. 小米电视怎么样?五大标准最有发言权
  16. 笔记本的标压和低压的区别
  17. DNS --域名系统
  18. 破解加密文档以及宏口令
  19. 使用Wordpress搭建个人博客网站
  20. 工厂人员定位系统解决方案详解

热门文章

  1. 安全测试的基本原则有哪些?
  2. Confluence 6 Home 和其他重要的目录
  3. linux系统命令学习系列-文件和目录管理
  4. Android开发实践:为什么要继承onMeasure()
  5. POJ 3174 暴力枚举
  6. Laravel Lumen之Eloquent ORM使用速查-基础部分
  7. 10624 - Super Number
  8. JAVA的StringBuffer类
  9. linux svn客户端的使用
  10. poj 2063完全背包