Python OpenCV按照像素点图片切割
图像分割是从图像处理到图像分析的关键步骤,在目标检测、特征提取、图像识别等领域具有广泛应用。OpenCV是一个强大的计算机视觉库,提供了多种图像分割方法。本文将详细介绍如何使用Python和OpenCV进行基于像素点的图像分割,包括阈值分割、自适应阈值分割、Otsu's二值化、分水岭算法、GrabCut算法、SLIC超像素分割和基于深度学习的分割方法。
一、图像分割的理论概述
阈值分割
阈值分割是最基础的图像分割方法之一,通过设定一个阈值将像素分为两组:前景和背景。该方法假设图像中的目标和背景的灰度值差异较大,存在一个合适的阈值,使得灰度值高于该阈值的像素被划分为目标,灰度值低于该阈值的像素被划分为背景。
自适应阈值分割
自适应阈值分割能够根据图像的不同区域自动调整阈值,适用于光照不均的场景。该方法将图像划分为多个小区域(子块),每个子块分别计算阈值进行分割。
Otsu's二值化
Otsu's二值化是一种自动寻找最佳阈值的方法,特别适合于单峰分布的图像。它遍历所有可能的阈值,计算类间方差,当类间方差最大时的阈值即为最佳阈值。
分水岭算法
分水岭算法常用于分割紧密相连的对象,通过模拟水流汇聚过程找到图像中的边界。该方法首先计算图像的距离变换,然后通过形态学操作找到局部最大值,最后应用分水岭算法得到分割结果。
GrabCut算法
GrabCut是一种半自动的图像分割方法,需要用户给出初步的前景和背景区域。该方法通过迭代优化算法不断调整前景和背景的掩膜,最终得到分割结果。
SLIC超像素分割
SLIC(Simple Linear Iterative Clustering)是一种快速的超像素分割方法,能将图像划分为多个小的、连贯的区域。该方法基于聚类算法,将图像像素聚类成多个超像素块。
基于深度学习的分割方法
基于深度学习的分割方法可以实现更高级的图像分割任务,如语义分割和实例分割。这些方法通常使用卷积神经网络(CNN)进行训练,能够自动学习图像特征并进行像素级别的分类。
二、代码示例
以下是使用Python和OpenCV进行图像分割的详细代码示例。
import cv2
import numpy as np
import matplotlib.pyplot as plt
from skimage.segmentation import slic
import tensorflow as tf
# 读取图像并转换为灰度
img = cv2.imread('image.jpg', 0)
# 1. 阈值分割
ret, thresh = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)
plt.imshow(thresh, cmap='gray')
plt.title('Thresholding')
plt.show()
# 2. 自适应阈值分割
adaptive_thresh = cv2.adaptiveThreshold(img, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2)
plt.imshow(adaptive_thresh, cmap='gray')
plt.title('Adaptive Thresholding')
plt.show()
# 3. Otsu's二值化
ret, otsu = cv2.threshold(img, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)
plt.imshow(otsu, cmap='gray')
plt.title('Otsu\'s Binarization')
plt.show()
# 4. 分水岭算法
D = cv2.distanceTransform(img, cv2.DIST_L2, 5)
localMax = cv2.dilate(D, None, iterations=2)
markers = cv2.watershed(cv2.cvtColor(img, cv2.COLOR_GRAY2BGR), localMax)
markers = cv2.cvtColor(markers, cv2.COLOR_BGR2RGB)
plt.imshow(markers)
plt.title('Watershed Segmentation')
plt.show()
# 5. GrabCut算法
mask = np.zeros(img.shape[:2], np.uint8)
bgdModel = np.zeros((1, 65), np.float64)
fgdModel = np.zeros((1, 65), np.float64)
rect = (50, 50, 450, 290)
cv2.grabCut(img, mask, rect, bgdModel, fgdModel, 5, cv2.GC_INIT_WITH_RECT)
mask2 = np.where((mask == 2) | (mask == 0), 0, 1).astype('uint8')
img = img * mask2[:, :, np.newaxis]
plt.imshow(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))
plt.title('GrabCut')
plt.show()
# 6. SLIC超像素分割
segments_slic = slic(img, n_segments=200, compactness=10, sigma=1)
plt.imshow(segments_slic)
plt.title('SLIC Superpixels')
plt.show()
# 7. 基于深度学习的分割方法(示例代码简化,实际应用需安装并配置相关深度学习框架)
# model = tf.keras.models.load_model('your_model.h5')
# predictions = model.predict(img[np.newaxis, :, :, np.newaxis]) # 注意输入形状可能需要调整
# plt.imshow(predictions[0, :, :, 0], cmap='gray') # 假设输出是单通道图像
# plt.title('Deep Learning Segmentation')
# plt.show()
三、注意事项和后续处理
自动阈值选择
在处理光照变化较大的场景时,尝试使用Otsu's二值化或自适应阈值分割,以获得更好的分割效果。
噪声处理
在应用阈值分割前,使用高斯模糊或中值滤波去除图像噪声,提高分割精度。
标记初始化
分水岭算法的效果很大程度上取决于初始标记的设置。尝试使用形态学运算或边缘检测结果作为初始标记,可以显著提高分割质量。
后处理
分割后的结果可能包含一些小的噪声区域,可以通过开闭运算进行清理。
精细调整
GrabCut的结果可以通过手动调整前景和背景的掩膜来进一步优化,尤其在对象边界不清晰的情况下。
迭代次数
增加迭代次数可以提高分割精度,但也会增加计算时间,需要根据具体需求权衡。
参数选择
SLIC超像素分割中的
n_segments
和compactness
参数直接影响超像素的数量和大小。较小的n_segments
值会生成更大的超像素,而较高的compactness
值会使超像素更接近圆形。后续处理
超像素分割可以作为后续图像处理任务的基础,如颜色直方图计算或特征提取。
数据增强和迁移学习
在训练深度学习模型时,使用数据增强技术(如旋转、翻转、缩放)可以增加模型的泛化能力。利用预训练的模型进行迁移学习,可以大大减少训练时间和所需的标注数据量。
四、总结
本文详细介绍了使用Python和OpenCV进行基于像素点的图像分割的方法,包括阈值分割、自适应阈值分割、Otsu's二值化、分水岭算法、GrabCut算法、SLIC超像素分割和基于深度学习的分割方法。不同的分割方法有其适用场景,选择最适合当前问题的技术是关键。在处理实时视频流或大规模数据集时,效率和速度变得尤为重要,需要对算法进行适当的优化。
Python OpenCV按照像素点图片切割的更多相关文章
- Python+Opencv实现把图片转为视频
1. 安装Opencv包 在Python命令行输入如下命令(如果你使用的Anaconda,直接进入Anaconda Prompt键入命令即可.如果你不知道Anaconda是什么,可以参考王树义老师的文 ...
- Python OpenCV ——Matplotlib显示图片
Color image loaded by OpenCV is in BGR mode.But Matplotlib displays in RGB mode.So color images will ...
- python opencv制作隐藏图片
前言 隐藏图片就是在白色背景和黑色背景显示出不同的图片,之前qq可以显示,现在好像也不行了,原因就是原来的qq,在发出来默认是白色背景,而点开后是黑色背景.但是这个原理还是挺有意思的,所以简单的研究了 ...
- Python opencv计算批量图片的BGR各自的均值
#coding:utf-8 #第一种方式 很慢很慢 自己写的如何计算均值 ''' import cv2 import os def access_pixels(frame): print(frame. ...
- python opencv show图片,debug技巧
debug的时候可以直接把图片画出来debug. imshow函数就是python opencv的展示图片的函数,第一个是你要起的图片名,第二个是图片本身.waitKey函数是用来展示图片多久的,默认 ...
- RPi 2B python opencv camera demo example
/************************************************************************************** * RPi 2B pyt ...
- python智能图片识别系统(图片切割、图片识别、区别标识)
@ 目录 技术介绍 运行效果 关键代码 写在最后 技术介绍 你好! python flask图片识别系统使用到的技术有:图片背景切割.图片格式转换(pdf转png).图片模板匹配.图片区别标识. 运行 ...
- 基于opencv图片切割
基于opencv图片切割为n个3*3区块 工作原因,切割图片,任务急,暂留调通的源码,留以后用. package com.rosetta.image.test; import org.opencv.c ...
- Python实现图片切割
import os from PIL import Image def splitimage(src, rownum, colnum, dstpath): img = Image.open(src) ...
- Python + opencv 实现图片文字的分割
实现步骤: 1.通过水平投影对图形进行水平分割,获取每一行的图像: 2.通过垂直投影对分割的每一行图像进行垂直分割,最终确定每一个字符的坐标位置,分割出每一个字符: 先简单介绍一下投影法:分别在水平和 ...
随机推荐
- Figma 学习笔记 – Keyboard Shortcut and Tips 小技巧
参考: 10 tips to work 10x faster in Figma 15 tips to design 15X faster in Figma | Figma Tutorial 2021 ...
- Figma 学习笔记 – Variants
参考 Create and use variants 定义与用途 Variants 是 Component 的扩展使用方式. 它就像 HTML 元素的属性一样, 通过修改属性, 元素就会变成相应的样式 ...
- JavaScript Bom和Dom的一般性详解
一.JavaScript的组成 JavaScript的实现包括以下3个部分: ECMAScript(核心) 描述了JS的语法和基本对象. 文档对象模型 (DOM) 处理网页内容的方法和接口 浏览器对象 ...
- 一个 tomcat 下如何部署多个项目?附详细步骤
一个tomcat下如何部署多个项目?Linux跟windows系统下的步骤都差不多,以下linux系统下部署为例.windows系统下部署同理. 一.不修改端口,部署多个项目 清楚tomcat目录结构 ...
- PyCharm 的一些基本设置&&常用插件&&快捷键
PyCharm一些基本设置 1.主题色彩 2.添加设置:Ctrl+鼠标滚轮上下调节字体大小 3. 中文语言包 4.翻译插件 5.快捷键
- 为了更好的 Flutter | 2021 第二季度开发者调研
自 Flutter 2 发布以后,诸多振奋人心的开发特性 也随之解锁,从 加速应用开发 到 流畅地开发多平台应用 都已经有了长足的进步.我们也从社区收集到了不少大家关心的问题,并进行了 解答.毫无疑问 ...
- 统一携带 token
tokne 可以使用 vuex 和 本地存储处理 : 一些接口需要携带token为了避免代码的重复性,可以在请求拦截器统一加入token ,每次请求都会携带token参数,不需要token参数的接口也 ...
- Android复习(五)设备兼容—>屏幕适配
1. 适配使用的布局 目前版本Google还是希望开发者通过 ConstraintLayout 布局完成适配 2. 对于特定屏幕 创建备用布局,即在res/layout/目录下创建对应尺寸的布局文件 ...
- Transformer的Pytorch实现【1】
使用Pytorch手把手搭建一个Transformer网络结构并完成一个小型翻译任务. 首先,对Transformer结构进行拆解,Transformer由编码器和解码器(Encoder-Decode ...
- 《使用Gin框架构建分布式应用》阅读笔记:p77-p87
<用Gin框架构建分布式应用>学习第5天,p77-p87总结,总计11页. 一.技术总结 1.Go知识点 (1)context 2.on-premises software p80, A ...