基于Python实现椭圆拟合

椭圆拟合 实验目的和要求 尝试使用 cv,fitEllipse()函数,对图像进行椭圆拟合 实验内容和原理 椭圆拟合 该函数使用的是最小二乘法拟合

本文包含相关资料包-----> 点击直达获取<-------

椭圆拟合

实验目的和要求

尝试使用 cv.fitEllipse()函数,对图像进行椭圆拟合

实验内容和原理

椭圆拟合

该函数使用的是最小二乘法拟合,要求输入的点至少有 6 个。

函数中对应的参数如下:

对输入图像的预处理

输入一张 RGB 图片,先转换为灰度图,本来打算先转换为二值图像再进行边缘检测的,但是发现二值化容易使阴影成为新的边缘,并丢失原有边缘信息,于是直接对灰度图进行了边缘检测。在边缘检测前还进行了降噪

边缘检测

用 Sobel Kernel 进行滤波,来计算 x 和 y 方向的导数。

对于每个像素,检测它是否为局部最大值,如果不是就设置为 0

输入的两个参数为 min 和 max,用来限定寻找的边缘范围(大于 max 的肯定是边缘,小于 min 的肯定不是,在 min 和 max 之间的则通过判断连通性等方式来判断。

实验步骤与分析

读入图片

读入后先去掉高频的信息(降噪)。然后保存一个 RGB 图像信息,存储一个 gray 灰度图信息。边缘信息 edge 直接从 gray 中提取,min 取到 100,max 取到 200。

```python FILENAME = "dota2items4.bmp" img = cv.imread(FILENAME) img = cv.GaussianBlur(img, (5, 5), 0) rgb = cv.cvtColor(img, cv.COLOR_BGR2RGB) gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)

_, thresh = cv.threshold(gray, 130, 255, cv.THRESH_BINARY + cv.THRESH_OTSU)

edge = cv.Canny(gray, 100, 200) ```

使用 fitEllipse()函数

Ells 数组储存椭圆信息,recs 储存可以旋转的最小矩阵,recs2 储存正矩形信息。Cols 用于储存随机生成的颜色信息,方便区分不同椭圆和矩阵之间的对应关系

```c++ img = rgb edge_ = cv.cvtColor(edge, cv.COLOR_GRAY2RGB) ells = [] recs = [] recs2 = [] cols = [] contours, nothing = cv.findContours(edge, cv.RETR_TREE, cv.CHAIN_APPROX_SIMPLE) for index, contour in enumerate(contours): if contour.shape[0] > 50: ells.append(cv.fitEllipse(contour)) recs2.append(cv.boundingRect(contour)) recs.append(cv.minAreaRect(contour))

random.seed(10) for i in range(len(ells)): cols.append([random.randint(0, 256) for j in range(3)])

```

绘制椭圆与矩形

同时在 RGB 图像和边缘图像中绘制,这是椭圆

c++ for index, ell in enumerate(ells): cv.ellipse(img, ell, cols[index], 2) cv.ellipse(edge_, ell, cols[index], 2)

这是可旋转的矩形

```c++ for index, rec in enumerate(recs): box = cv.boxPoints(rec) # cv2.boxPoints(rect) for OpenCV 3.x box = np.int0(box) cv.drawContours(img,[box],0,cols[index],1) cv.drawContours(edge_,[box],0,cols[index],1)

```

绘制正矩形

```c++ for index, rec2 in enumerate(recs2): x,y,w,h = rec2 cv.rectangle(img,(x,y),(x+w,y+h),cols[index],1) cv.rectangle(edge_,(x,y),(x+w,y+h),cols[index],1)

```

实验结果

输入图像

图里左上角的 Hyper stone 具有很多同心圆信息,右上的 Clarity 有不规则曲线和直线信息,右下的 Tango 有圆形信息且整体外形近似椭圆,正下方的 Force Staff 有近似的圆形信息和直线。

输出:

  • RGB

图像因为进行过高斯滤波而稍微模糊

  • GrayScale

  • Thresh

可以看出,二值化后的图像失去了很多细节信息,同时引入了阴影的边缘信息,这是我们不太想要的

  • Edge

根据灰度图生成了图像的边缘信息

Ellipse on Edge

大部分边缘信息拟合良好,但是图中红色箭头标出的浅蓝色椭圆很奇怪,通过分析,它对应的 contour 是左边浅蓝色矩形内部的信息,并不知道为什么会发生这样的事,也许是 bug?(这个现象同样在 Lena 图片中出现,根据搜索到的信息,可能是最小二乘法造成的问题)

下图为 Lena 照片下半部分,看得出左边深蓝色矩阵和右边的椭圆对应,但并没有任何重合。

Ellipse on RGB

看得出,那个浅蓝色椭圆与整个图片格格不入

心得体会

本来想直接用那种波点图像就算了,看见同学做了对奇怪的游戏 CG 的拟合,于是考虑到继续使用 Lena 姐姐的照片,但是羽毛帽的细节信息太多,导致效果并不十分好。于是找了 DOTA2 的物品图标(虽然效果很好,但是分辨率实在太低,于是找了二次创作的高清图像,效果还不错,各种情况下的效果都能看见)

比如这里非常标准的椭圆

这里对形状近似的物体的拟合

这个粉色应该是在拟合瓶子的左下边缘。

通过调大拟合时使用的点的数量阈值以及画的线的粗细,可以删除一些不靠谱的结果,防止出现一大团乱七八糟的线 的效果(如下)

(对应的其实是)

参考文献

  • 股票在线虚拟交易系统的设计与实现(电子科技大学·苏璇)
  • 基于J2EE的虚拟物流企业信息系统设计(中国农业大学·王福华)
  • 分布式智能网络爬虫的设计与实现(中国科学院大学(工程管理与信息技术学院)·何国正)
  • 基于网络爬虫的计量数据分析系统开发(吉林大学·邹思宇)
  • 校园虚拟地图系统的研究与应用(中国地质大学(北京)·魏传振)
  • 基于Q-learning的系统集成与过程优化(青岛科技大学·魏晓彤)
  • 战时运输任务演练系统设计与实现(大连理工大学·杨福君)
  • 基于J2EE的远程网络教育系统研究与实现(电子科技大学·陈南荪)
  • 校园虚拟地图系统的研究与应用(中国地质大学(北京)·魏传振)
  • 基于SSH架构的个人空间交友网站的设计与实现(北京邮电大学·隋昕航)
  • 基于增量反馈和自适应机制的主题爬虫系统的设计与实现(南京理工大学·王斐)
  • 基于Python的虚拟仪器设计与开发(中央民族大学·郑可富)
  • 轻量级分布式虚假信息爬虫的设计与实现(辽宁大学·韩昱)
  • 销售网站的设计与实现(吉林大学·尹迪)
  • 基于JSF的Web-GIS研究与应用(武汉理工大学·周鼎)

本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:源码码头 ,原文地址:https://bishedaima.com/yuanma/36131.html

相关推荐

  • 基于Springboot+RabbitMQ+redis实现的超市订单管理系统

    基于Springboot+RabbitMQ+redis实现的超市订单管理系统 1 系统需求分析 超市订单管理系统是一个专为连锁店,超市等商业场所提供订单管理平台的系统
    2024年05月14日
    5 1 2
  • 基于mybatis的时间日程管理系统

    基于 MyBatis 的时间日程管理系统 1 绪论 1,1 背景 随着时代的进步,网络技术层出不穷信息量急剧膨胀,整个人类社会已成为信息化的社会
    2024年05月14日
    2 1 1
  • 新手python简单的飞机游戏

    game 一个新手做的python简单的飞机游戏 参考文献 基于Java EE的个人博客管理系统的设计和实现(内蒙古大学·闫伟光) 深度可定制的工具化爬虫系统的设计与实现(北京邮电大学·李笑语) 航空订票服务器爬虫检测技术研究(杭州电子科技大学·陈万烤) 主题爬虫关键技术研究(哈尔滨工程大学·黄正德) 机票票价预测系统设计与实现(大连理工大学·陈岩松) 深度可定制的工具化爬虫系统的设计与实现(北京邮电大学·李笑语) 基于SSH架构的个人空间交友网站的设计与实现(北京邮电大学·隋昕航) 基于B/S架构的酷跑社区系统的设计与实现(内蒙古大学·张晓乐) 基于SSH架构的个人空间交友网站的设计与实现(北京邮电大学·隋昕航) 机票票价预测系统设计与实现(大连理工大学·陈岩松) 山东航空货运业务管理系统的设计与实现(山东大学·高辉) 飞行情报资料管理信息系统设计与实现(中国地质大学(北京)·张晓琴) 山东航空货运业务管理系统的设计与实现(山东大学·高辉) 豆玩手机游戏平台的设计与实现(吉林大学·李天明) 面向高职信息技术教育的严肃游戏设计与实施(大连理工大学·王晓姝)
    2024年05月14日
    1 1 1
  • 基于JSP实现的校园师生交流系统

    基于JSP实现的校园师生交流系统 第1章 课设任务 1,1 课程题目 师生交流系统的设计与开发 1,2 课设目的 复习,巩固JavaWeb的基础知识
    2024年05月14日
    17 1 3
  • 基于Python实现手写数字识别

    基于 TensorFlow 框架的手写数字识别系统 摘要 时下人工智能蔚然成风,作为新型生产要素,在各个领域都极大地推动了经济发展,预示着社会经济将取得巨大增长和和人类潜能将得到深度开发
    2024年05月14日
    4 1 2
  • 基于springboot和ftp实现的网盘文件系统

    基于springboot和ftp实现的网盘文件系统 1,项目简介 因为开发中很多时候都需要上传和下载文件,所以想开发出一个模块,用于文件的上传和下载,自然而然也就想到了网盘
    2024年05月14日
    4 1 1
  • 基于Spring与Spark开发电影推荐网站

    电影推荐系统 演示效果 演示视频 环境搭建 ES ``` docker run -p 9200:9200 -p 9300:9300 --name='es' -d -v /home/k8s-develop/movie/elasticsearch
    2024年05月14日
    4 1 1
  • 基于Python的智能监控平台

    基于Python的智能监控平台 1,环境配置 网站使用了 Flask 框架,安装 Flask : pip install Flask Flask 连接 mysql 数据库需要库 flask_sqlalchemy 和库 pymysql
    2024年05月14日
    2 1 1
  • JavaWeb电商项目

    基于 javaweb 技术的在线电子商城系统 摘 要 随着人们生活水平的提高,对物质要求也越来越高,人们网购的消费也逐年增长,所以电子商务发展十分迅速
    2024年05月14日
    3 1 2
  • 大数据中的文本挖掘之Python

    大数据中的文本挖掘 Introduction 本次作业的任务是故事生成,即给定一个故事标题,要求输出 5 个句子的短故事,我们力图复现一下论文(Seq2Seq
    2024年05月14日
    1 1 1

发表回复

登录后才能评论