一 简介

目标检测即为在图像中找到自己感兴趣的部分,将其分割出来进行下一步操作,可避免背景的干扰。以下介绍几种基于opencv的单目标检测算法,算法总体思想先尽量将目标区域的像素值全置为1,背景区域全置为0,然后通过其它方法找到目标的外接矩形并分割,在此选择一张前景和背景相差较大的图片作为示例。

环境:python3.7 opencv4.4.0

二 背景前景分离

1 灰度+二值+形态学 轮廓特征和联通组件

根据图像前景和背景的差异进行二值化,例如有明显颜色差异的转换到HSV色彩空间进行分割。

1 原图

2 灰度化

3 二值化

4 形态学处理

5 提取轮廓并找出目标外接矩形

代码封装:

def get_roi_contours(image_path, morph_size, num_morph):

'''

参数详解:

image_path:所需处理图片路径

morph_size:形态学处理核的大小

num_morph:进行形态学处理的次数

'''

image = cv2.imread(image_path, cv2.IMREAD_COLOR)

#灰度转换

gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

#二值化

threhold, binary_image = cv2.threshold(gray_image, 0, 255, cv2.THRESH_BINARY_INV+cv2.THRESH_OTSU)

#形态学操作

kernel = cv2.getStructuringElement(shape=cv2.MORPH_RECT, ksize=morph_size)

morph_image = cv2.morphologyEx(binary_image, cv2.MORPH_CLOSE, kernel)

for i in range(num_morph-1):

morph_image = cv2.morphologyEx(morph_image, cv2.MORPH_CLOSE, kernel)

#查找轮廓

contours, hierarchy = cv2.findContours(morph_image, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

#选取轮廓面积最大的轮廓

area = 0

max_area_index = 0

for j in range(len(contours)):

if area < cv2.contourArea(contours[j]):

max_area_index = j

area = cv2.contourArea(contours[j])

rect = cv2.boundingRect(contours[max_area_index])

return rect

6 通过联通组件找到外接矩形

代码封装:

def get_roi_ConCom(image_path, morph_size, num_morph):

'''

参数详解:

image_path:所需处理图片路径

morph_size:形态学处理核的大小

num_morph:进行形态学处理的次数

'''

image = cv2.imread(image_path, cv2.IMREAD_COLOR)

#灰度转换

gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

#二值化

threhold, binary_image = cv2.threshold(gray_image, 0, 255, cv2.THRESH_BINARY_INV+cv2.THRESH_OTSU)

#形态学操作

kernel = cv2.getStructuringElement(shape=cv2.MORPH_RECT, ksize=morph_size)

morph_image = cv2.morphologyEx(binary_image, cv2.MORPH_CLOSE, kernel)

for i in range(num_morph-1):

morph_image = cv2.morphologyEx(morph_image, cv2.MORPH_CLOSE, kernel)

#联通组件查询

numlabels, components_img, stats, centers = cv2.connectedComponentsWithStats(morph_image, 8)

#获取除背景外的所有联通组件

stats_without_back = stats[1:]

#获取除背景外的所有联通组件的面积最大值

max_area = np.max(stats_without_back, axis=0)[-1]

#获取面积最大联通组件的index

max_area_index = stats_without_back[:, -1]==max_area

rect = stats_without_back[max_area_index]

return np.squeeze(rect)[0:4]

2 Kmeans聚类实现前景和背景的分离

1 kmeans聚类后的图像,由于簇的中心是随机初始化的,所以目标的像素值可能为0,也可能为1,若采用opencv的findContours则要求前景像素值为1。

2 利用轮廓特征找外接矩形

由于Kmeans随机初始化簇中心导致前景目标像素不确定,采用边缘提取的方法再查找轮廓。

边缘图:

代码封装:

def get_roi_Kmeans(image_path):

image = cv2.imread(image_path, cv2.IMREAD_COLOR)

image_data = image.reshape(-1, 3).astype(np.float32) #必须要转成浮点类型进行计算

#簇内平方和,标签和每个簇的中心

criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_COUNT, 10, 1)

interia, label, centers = cv2.kmeans(image_data, 2, None, criteria, 5, cv2.KMEANS_RANDOM_CENTERS)

#二值化,将标签为0的转换为255,即是目标

label[label==0] = 255

label[label==1] = 0

#转换数据类型,轮廓查找要是uint8类型数据

thresh_img = label.reshape(image.shape[0:2]).astype(np.uint8)

x_grad = cv2.Sobel(thresh_img, cv2.CV_32F, 1, 0)

y_grad = cv2.Sobel(thresh_img, cv2.CV_32F, 0, 1)

x_grad = cv2.convertScaleAbs(x_grad) #ax + b 线性变换

y_grad = cv2.convertScaleAbs(y_grad)

dst = cv2.add(x_grad, y_grad, dtype=cv2.CV_16S) #将两种sobel的加起来就可以得到整个边缘

dst = cv2.convertScaleAbs(dst)

plt.imshow(dst, cmap='gray')

#轮廓查找目标必须为1

contours, hierarchy = cv2.findContours(dst, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

#获取外接矩形

rect = cv2.boundingRect(contours[0])

return rect

三 总结

单目标检测较为简单,只要合理利用目标和背景的差异便可将其分离出来。当然单目标检测的方法还有很多,比如有目标模板的时候可以采用模板匹配或者均值漂移,有足够的数据集时也可采用机器学习和深度学习方法。

到此这篇关于Python Opencv实现单目标检测的示例代码的文章就介绍到这了,更多相关Opencv 单目标检测内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/wahjk/article/details/108434047

python简单目标检测代码_Python Opencv实现单目标检测的示例代码相关推荐

  1. python调用程序压缩文件_Python实现文件压缩和解压的示例代码

    大家可能都熟悉.zip格式的文件.它可以把多个文件,压缩成一个文件.这在网络上传输时很有用,而且节省硬盘空间. 接下来,我们使用Python实现压缩和解压. 读取ZIP文件信息 要读取ZIP文件的内容 ...

  2. python修改自己的代码_python修改微信和支付宝步数的示例代码

    项目意义 如果你想在支付宝蚂蚁森林收集很多能量种树,为环境绿化出一份力量,又或者是想每天称霸微信运动排行榜装逼,却不想出门走路,那么该python脚本可以帮你实现. 实现方法 手机安装第三方软件乐心健 ...

  3. python人像动漫化_python实现人像动漫化的示例代码

    利用百度api实现人像动漫化 百度API地址:https://ai.baidu.com/tech/imageprocess/selfie_anime 技术文档:https://ai.baidu.com ...

  4. python通过cookie绕过验证码_Python Selenium Cookie 绕过验证码实现登录示例代码

    之前介绍过通过cookie 绕过验证码实现登录的方法.这里并不多余,会增加分析和另外一种方法实现登录. 1.思路介绍 1.1.直接看代码,内有详细注释说明 # FileName : Wm_Cookie ...

  5. python两数相乘代码_Python 实现大整数乘法算法的示例代码

    我们平时接触的长乘法,按位相乘,是一种时间复杂度为 O(n ^ 2) 的算法.今天,我们来介绍一种时间复杂度为 O (n ^ log 3) 的大整数乘法(log 表示以 2 为底的对数). 介绍原理 ...

  6. python遥感影像分类代码_Python 实现遥感影像波段组合的示例代码

    最近要做个遥感相关的小系统,需要波段组合功能,网上找了可以使用ArcGIS安装时自带的arcpy包,但是Python3.7不能使用现有ArcGIS10.2版本,也不想再装其他版本,所以只能自己想了个办 ...

  7. python实现自动登录软件_Python selenium实现微博自动登录的示例代码

    (一)编程环境 操作系统:Win 10 编程语言:Python 3.6 (二)安装selenium 这里使用selenium实现. 如果没有安装过python的selenium库,则安装命令如下 pi ...

  8. python随机生成四位验证码的代码_Python random随机生成6位验证码示例代码

    随机生成6位验证码代码 # -*- coding: utf-8 -*- import random def generate_verification_code(): ''' randomly gen ...

  9. python数据统计代码_Python 数据的累加与统计的示例代码

    问题 你需要处理一个很大的数据集并需要计算数据总和或其他统计量. 解决方案 对于任何涉及到统计.时间序列以及其他相关技术的数据分析问题,都可以考虑使用 Pandas库 . 为了让你先体验下,下面是一个 ...

最新文章

  1. 5G人才报告 | 买5G手机不用卖肾,有这个就行(全文)
  2. LCUI.css 0.1.2 发布, 基于 LCUI 开发的 UI 组件库
  3. 2010年下半年网络工程师考试上午试卷与参考答案(3)
  4. python培训学校-如何找到靠谱的Python培训学校?
  5. android 异步刷新 方法,android应用中实现异步更新UI的方法有哪些
  6. jQuery Ajax 实例 全解析
  7. java猜字母讲解_java_猜字母游戏
  8. linux创建备用管理员,sql server 创建备用管理员和只读用户
  9. jquery智能提示
  10. 使控件大小随窗口变化
  11. 泰安虚拟服务器怎么样,泰安S5353:搭建您最满意的服务器
  12. php 二位数组排序
  13. UVA-10859 - Placing Lampposts(树形DP)
  14. 多个条码标签如何在一张纸上打印
  15. 简单银行管理系统C#版本
  16. linux下用C/C++和socket实现的驾校约车助手
  17. 怎么在云服务器上建网站_怎么在云服务器建网站?阿里云服务器搭建网站教程...
  18. hdu 畅通工程再续
  19. 使用kubeadm搭建k8s高可用集群
  20. ES5, ES2015 和 TypeScript 的区别

热门文章

  1. 1.14 字符串查找(3种方法)indexOf(), lastlndexOf(), charAt()
  2. 三种插入排序算法:直接插入排序、折半插入排序、希尔插入排序
  3. 列表解析和生成器表达式
  4. linux之账号管理
  5. 对象属性操作函数:hasattr(),getattr(),setattr()
  6. 多线程别怕,有锁就安全;(解决线程安全问题)
  7. django orm级联_django+jquery 实现级联选择菜单
  8. html里注释的写法正确的是,网页怎么注释语句 HTML的注释正确写法是?
  9. 【PAT】A1060 Are They Equal *
  10. 能挣钱的,开源 SpringBoot 商城系统,功能超全,超漂亮,真TMD香!