当前位置: 首页 > news >正文

博客和个人网站建设情况营销型网站建设案例

博客和个人网站建设情况,营销型网站建设案例,怎么做家庭网站,seo公司排名教程计算机视觉废钢堆提取问题 背景介绍 在钢铁炼制中,废钢是非常重要的原料,不同等级废钢对于钢成品影响很大,因此需要对废钢进行正确分类。某废钢料场中,卸料区域布置了多个摄像头,用于拍摄卸料场中废钢堆,…

计算机视觉废钢堆提取问题

背景介绍

在钢铁炼制中,废钢是非常重要的原料,不同等级废钢对于钢成品影响很大,因此需要对废钢进行正确分类。某废钢料场中,卸料区域布置了多个摄像头,用于拍摄卸料场中废钢堆,如下几个图所示。后续处理中需要先将废钢蟭有效提取出来,减少背景的影响。效果如下所示。
图 1     未处理图像1
图 1 未处理图像1
在这里插入图片描述
图 2 处理后图像1

2. 程序设计思路及主要方法

本次实验基于OpenCV的 GrabCut图像分割算法。GrabCut是一种交互式分割方法,该方法使用图论的max-flow/min-cut算法从图像的背景中提取前景。在算法开始之前,用户首先需要提供一些提示,大致在输入图像中指定前景区域,尽可能减少交互(例如,在前景区域周围绘制一个矩形);然后使用该法对图像进行迭代分割,得到可能的最佳结果。在某些情况下,分割可能不是理想的(例如,算法可能将一些前景区域标记为背景,反之亦然)。
用于图论Grabcut算法实现。参数img为待分割输入图像,要求必须是8位3通道;mask为输入/输出掩码图像;rect分割目标的ROI限定区域范围,该窗口内的像素被处理;bgdModel为背景模型的临时储存数组;fgdModel为前景模型的临时储存数组。
利用OpenCV进行图割算法实时显示,首先需要定义分割矩形区域,利用Grabcut完成前景与背景图像分离,利用图像匹配得到分割结果,具体实验结果展示如下。

实验结果展示

在这里插入图片描述

图 4 未处理图像2
在这里插入图片描述

图 5 已处理图像2
在这里插入图片描述
图 8 未处理图像4
在这里插入图片描述
图 9 已处理图像4

代码如下:

 import numpy as np    //导入依赖库
import cv2#鼠标事件的回调函数
def on_mouse(event,x,y,flag,param):        global rectglobal leftButtonDowmglobal leftButtonUp#鼠标左键按下if event == cv2.EVENT_LBUTTONDOWN:rect[0] = xrect[2] = xrect[1] = yrect[3] = yleftButtonDowm = TrueleftButtonUp = False#移动鼠标事件if event == cv2.EVENT_MOUSEMOVE:if leftButtonDowm and  not leftButtonUp:rect[2] = xrect[3] = y        #鼠标左键松开if event == cv2.EVENT_LBUTTONUP:if leftButtonDowm and  not leftButtonUp:x_min = min(rect[0],rect[2])y_min = min(rect[1],rect[3])x_max = max(rect[0],rect[2])y_max = max(rect[1],rect[3])rect[0] = x_minrect[1] = y_minrect[2] = x_maxrect[3] = y_maxleftButtonDowm = False      leftButtonUp = True//加载图像,指定输入图像的路径
img = cv2.imread(r'E:\Users\SongpingWang\Desktop\the_angry_birds_movie.jpg')
mask = np.zeros(img.shape[:2],np.uint8)    //创建掩码蒙版//创建临时数组
bgdModel = np.zeros((1,65),np.float64)    #背景模型
fgdModel = np.zeros((1,65),np.float64)    #前景模型
rect = [0,0,0,0]                          #设定需要分割的图像范围leftButtonDowm = False                    #鼠标左键按下
leftButtonUp = True                       #鼠标左键松开cv2.namedWindow('img')                    #指定窗口名来创建窗口
cv2.setMouseCallback('img',on_mouse)      #设置鼠标事件回调函数 来获取鼠标输入
cv2.imshow('img',img)                     #显示图片while cv2.waitKey(2) == -1:#左键按下,画矩阵if leftButtonDowm and not leftButtonUp:  img_copy = img.copy()cv2.rectangle(img_copy,(rect[0],rect[1]),(rect[2],rect[3]),(0,255,0),2)  cv2.imshow('img',img_copy)#左键松开,矩形画好 elif not leftButtonDowm and leftButtonUp and rect[2] - rect[0] != 0 and rect[3] - rect[1] != 0:rect[2] = rect[2]-rect[0]rect[3] = rect[3]-rect[1]rect_copy = tuple(rect.copy())   rect = [0,0,0,0]#物体分割cv2.grabCut(img,mask,rect_copy,bgdModel,fgdModel,5,cv2.GC_INIT_WITH_RECT)mask2 = np.where((mask==2)|(mask==0),0,1).astype('uint8')img_show = img*mask2[:,:,np.newaxis]#显示图片分割后结果--显示原图cv2.imshow('grabcut',img_show)cv2.imshow('img',img)    cv2.waitKey(0)
cv2.destroyAllWindows()
http://www.dinnco.com/news/32023.html

相关文章:

  • wordpress和hexo哪个好搜索引擎优化期末考试答案
  • 汕头电商网站建设做seo需要哪些知识
  • 电脑网站怎么制作成都网站建设公司排名
  • 做网站怎么接广告赚钱关键词点击价格查询
  • 重庆cms建站模板视频号怎么推广流量
  • 网站现在怎么做排名公众号推广合作平台
  • 硬件开发工程师是干什么的青岛seo博客
  • 做个网站成本武汉网络推广外包公司
  • 站酷网app郑州seo优化服务
  • 企业加盟网站建设厦门seo优化公司
  • 专业做网站的公司有没有服务器百度搜索推广开户
  • 网站自己做还是用程序网络推广员是干嘛的
  • 珠宝首饰商城网站建设手机营销软件
  • 哪个网站可以查到竣工资料怎么做外贸获客软件
  • 网络营销有哪些具体方法宁波seo优化流程
  • 找人做网站定金不退百度一下网页版
  • 多语言企业网站源码南昌seo公司
  • zencart 团购网站搜索引擎优化效果
  • 上海外贸网站深圳外贸网站制作
  • 广东新闻联播2020网站关键词排名手机优化软件
  • 怎么做提取微信62的网站好用的种子搜索引擎
  • 贵阳网站建设培训百度小说搜索排行榜
  • 信阳做房产哪个网站好用实时热榜
  • 网站建设总结和体会seo是什么字
  • 怎么自己做网站游戏网络营销策划ppt范例
  • 赣州做网站什么价格福州百度seo排名
  • 珠海网站建设专线百度打广告多少钱一个月
  • 哪些网站做推广百度推广代理商加盟
  • 电子商务网站建设与管理的论文网络搭建教程
  • 景安网络网站建设网络推广外包代理