OpenCVSharp入门教程 特征提取①——MSER区域特征提取Maximally Stable Extremal Regions

article/2025/9/13 1:36:00

文章目录

  • 一、前文
  • 二、特征提取流程
  • 三、界面布局
  • 四、功能实现
    • 4.1 打开图片
    • 4.2 特征提取—源码
    • 4.3 特征提取—参数讲解
    • 4.4 特征提取—Detect和DetectRegions
  • 五、运行效果图
  • 六、发现并解决问题
  • 七、其他问题

一、前文

MSER = Maximally Stable Extremal Regions
最大极值稳定区
业界认为是性能最好的仿射不变区域,MSER是当使用不同的灰度阈值对图像进行二值化时得到的最稳定的区域,特点:
1.对于图像灰度的仿射变化具有不变性
2.稳定性,区域的支持集相对灰度变化稳定
3.可以检测不同精细程度的区域

二、特征提取流程

  1. 使用一系列灰度阈值对图像进行二值化处理
  2. 对于每个阈值得到的二值图像,得到相应的黑色区域与白色区域
  3. 在比较宽的灰度阈值范围内保持形状稳定的区域就是MSERs
  4. 评判标准: dA/dtA: 二值图像区域面积,t: 灰度

三、界面布局

  • 一个Label
  • 两个Button
  • 三个Picture

在这里插入图片描述

四、功能实现

4.1 打开图片

 private void openFileBtn_Click(object sender, EventArgs e){OpenFileDialog openfiledialog = new OpenFileDialog();openfiledialog.Filter = "PNG Files (*.png)|*.png|JPG Files (*.jpg)|*.jpg|GIF Files (*.gif)|*.gif";openfiledialog.RestoreDirectory = true;if (openfiledialog.ShowDialog() == DialogResult.OK){Console.WriteLine(openfiledialog.FileName);fileName = openfiledialog.FileName;//Mat src = new Mat("foo.png", LoadMode.Color);Mat src = new Mat(fileName);//Mat src = new Mat(fileName, ImreadModes.Color);var frameBitmap = BitmapConverter.ToBitmap(src);pictureBox1.Image?.Dispose();pictureBox1.Image = frameBitmap;}}

4.2 特征提取—源码

private void mserBtn_Click(object sender, EventArgs e)
{if (String.IsNullOrEmpty(fileName)){MessageBox.Show("请先打开一个图片");return;}Mat src = new Mat(fileName);Mat gray = new Mat();Mat dst = src.Clone();Cv2.CvtColor(src, gray, ColorConversionCodes.BGR2GRAY);int delta = 5;int minArea = 60;int maxArea = 14400;//int maxArea = 100000;double maxVariation = 0.25;MSER mser = MSER.Create(delta, minArea, maxArea, maxVariation);DateTime currentTime = DateTime.Now;KeyPoint[] contours = mser.Detect(gray, null); resultLabel.Text = "Detect耗时:" + (System.DateTime.Now - currentTime).TotalMilliseconds + "ms";Console.WriteLine("contours len="+ contours.Length);currentTime = DateTime.Now;Point[][] outPoint;Rect[] bboxes;InputArray input = InputArray.Create(gray);mser.DetectRegions(input, out outPoint, out bboxes);resultLabel.Text += ",  DetectRegions耗时:" + (System.DateTime.Now - currentTime).TotalMilliseconds + "ms";Console.WriteLine("bboxes len=" + bboxes.Length);gray = src.Clone();foreach (KeyPoint pts in contours){gray.Circle((int)pts.Pt.X, (int)pts.Pt.Y, (int)pts.Size, Scalar.Black);gray.Circle((int)pts.Pt.X, (int)pts.Pt.Y, (int)1, Scalar.Black, 2);Console.WriteLine("("+pts.Pt.X+" , "+pts.Pt.Y+") Size="+pts.Size+", Angle="+pts.Angle+", Response="+pts.Response + ", ClassId=" + pts.ClassId);}foreach (Point[] pts in outPoint){foreach (Point p in pts){dst.Circle(p, 1, Scalar.Black);}}foreach (Rect b in bboxes){dst.Rectangle(b, Scalar.Black, 2);}srcPictureBox.Image = BitmapConverter.ToBitmap(src); grayPictureBox.Image = BitmapConverter.ToBitmap(gray); dstPictureBox.Image = BitmapConverter.ToBitmap(dst);
}

4.3 特征提取—参数讲解

MSER在detect的时候不需要传特别的参数
只需要在Create的时候传递参数

//
// 摘要:
//     Creates MSER parameters
//
// 参数:
//   delta:
//     delta, in the code, it compares (size_{i}-size_{i-delta})/size_{i-delta}
//
//   minArea:
//     prune the area which smaller than min_area
//
//   maxArea:
//     prune the area which bigger than max_area
//
//   maxVariation:
//     prune the area have simliar size to its children
//
//   minDiversity:
//     trace back to cut off mser with diversity < min_diversity
//
//   maxEvolution:
//     for color image, the evolution steps
//
//   areaThreshold:
//     the area threshold to cause re-initialize
//
//   minMargin:
//     ignore too small margin
//
//   edgeBlurSize:
//     the aperture size for edge blur
public static MSER Create(int delta = 5, int minArea = 60, int maxArea = 14400, double maxVariation = 0.25, double minDiversity = 0.2, int maxEvolution = 200, double areaThreshold = 1.01, double minMargin = 0.003, int edgeBlurSize = 5);
  • delta,区域的灰度差
  • minArea,检测区域面积(像素数)的下限
  • maxArea,检测区域面积(像素数)的上限
  • maxVariation,区域与子区域间的偏差的上限

剩下的参数是MSCR使用,这个CColorC
若输入的是灰度图像,则使用MSER
若输入的是彩色图像,则使用MSCR

  • minDiversity,For color image, trace back to cut off mser with diversity less than min_diversity
  • maxEvolution,For color image, the evolution steps
  • areaThreshold, For color image, the area threshold to cause re-initialize
  • minMargin,For color image, ignore too small margin
  • edgeBlurSize,For color image, the aperture size for edge blur

4.4 特征提取—Detect和DetectRegions

OpenCV库中存在两个检测方法,DetectDetectRegions

Detect返回的是KeyPoint数组,包含了:

  • 中心点Point2f
  • 特征大小Size
  • 特征角度Angle
  • 特征强度Response
  • OctaveClassId

DetectRegions返回的是二维数组Point和一位数组Rect

  • 二位数组Point,有N个区域,每个区域的所有点Point
  • 一位数组Rect,有N个区域,每个区域的Rect

五、运行效果图

  • 从左到右
  • 第一张是原图
  • 第二张是Detect结果图
    • 将检测发现的结果的中间描黑,按照结果的size画个圆
  • 第三张是DetectRegions结果图
    • 将检测发现的区域全部描黑
    • 将检测发现的区域Rect框起来

在这里插入图片描述

六、发现并解决问题

这时候会发现一个问题,为啥右上角的绿色长方形没有被识别出来

思考了一下,大胆猜测是因为面积太大了。

因为,也想不到别的因素了,小正方形的绿色都识别出来了,为啥更大的长方形绿色没有被识别出来。颜色因素排除,那只有面积了。

更改了下代码

    //int maxArea = 14400;int maxArea = 100000;

运行:
在这里插入图片描述

堪称完美

七、其他问题

当然还是存在其他问题没解决

  • 最后两张,是一样的图,but一个是jpg,一个是png,但是提取的效果就完全不一样
  • 猜测可能是数据转换过程有不一样的地方
  • 仅仅是猜测后续再花时间验证,如有大佬看到并晓得原因,不吝赐教
    在这里插入图片描述
    在这里插入图片描述

觉得好,就一键三连呗(点赞+收藏+关注)


http://chatgpt.dhexx.cn/article/Af4p51dn.shtml

相关文章

【OpenCV 例程 300篇】247. 特征检测之最大稳定极值区域(MSER)

『youcans 的 OpenCV 例程300篇 - 总目录』 【youcans 的 OpenCV 例程 300篇】247. 特征检测之最大稳定极值区域&#xff08;MSER&#xff09; 1. 最大稳定极值区域&#xff08;MSER&#xff09; 最大稳定极值区域&#xff08;MSER-Maximally Stable Extremal Regions&#xf…

师傅带徒弟学JavaScript-关东升-专题视频课程

师傅带徒弟学JavaScript—430人已学习 课程介绍 本课程是学习Web前端的基础课程&#xff0c;是学习Web前端框架、JavaWeb开发、Python Web开发、PHP开发和.NET Web开发前置课程。 课程收益 掌握JavaScript 讲师介绍 关东升 更多讲师课程 一个在IT领域摸爬滚打20多年的老程…

师傅带徒弟学:Python Web之Flask框架-关东升-专题视频课程

师傅带徒弟学&#xff1a;Python Web之Flask框架—317人已学习 课程介绍 Python Web是Python语言一个重要的应用方面&#xff0c;Python Web有很多&#xff0c;其中Flask和Django框架是他们的佼佼者。 Flask是一个Python实现的Web开发微框架。 课程收益 掌握Flask框架 讲师…

关东升的iOS实战系列图书 《iOS实战:入门与提高卷(Swift版)》已经上市

&#xfeff;&#xfeff; 承蒙广大读者的厚爱我的 《iOS实战&#xff1a;入门与提高卷&#xff08;Swift版&#xff09;》京东上市了&#xff0c;欢迎广大读者提出宝贵意见。http://item.jd.com/11766718.html 欢迎关注关东升新浪微博tony_关东升。 关注智捷课堂微信公共平台&…

Sharding-JDBC(一)SpringBoot集成

目录 1.背景2.简介3.依赖与配置4.表结构&#xff08;1..3&#xff09;5.测试验证5.1 批量保存5.2 列表查询 6.源码地址 1.背景 随着业务数据量的增加&#xff0c;原来所有的数据都是在一个数据库上&#xff0c;网络IO及文件IO都集中在一个数据库上&#xff0c;因此CPU、内存、…

第一篇【Python】基础-关东升-专题视频课程

第一篇【Python】基础—833人已学习 课程介绍 本书是智捷课堂开发的立体化图书中的一本&#xff0c;所谓“立体化图书”就是图书包含&#xff1a;书籍、视频、课件和服务等内容。 其中第一篇包括8章内容&#xff0c;系统介绍了Python语言的基础知识。内容包括Python语言历史…

shardingsphere-jdbc 整合 springboot

shardingsphere官网地址 https://shardingsphere.apache.org/document/5.2.0/cn/user-manual/shardingsphere-jdbc/spring-boot-starter/rules/sharding/ 当前我们演示的是水平分表 1、基础环境配置以及依赖管理 1.1 创建数据库表结构 CREATE TABLE address_0 (id bigint(…

如果张东升是个程序员

张东升是一家互联网公司的程序员&#xff0c;一直以来都勤勤恳恳老实工作。 可最近一段时间&#xff0c;行业不景气&#xff0c;老板不但下令开启了996的工作模式&#xff0c;更要命的是频频更改需求&#xff0c;弄得大家是敢怒不敢言。 时间一久&#xff0c;很多员工开始消极…

专访关东升:松耦合分层架构设计

关东升,国内知名iOS技术作家,iOS技术顾问,高级培训讲师,移动开发专家。拥有16年软件开发经验、8年培训行业经验。精通iOS、Android和 Windows Phone 7及Html5等移动开发技术。在App Store发布多款游戏和应用软件,擅长移动平台的应用和游戏类项目开发。目前主要从事iOS应用…

Java从小白到大牛第3篇 【进阶篇】-关东升-专题视频课程

Java从小白到大牛第3篇 【进阶篇】—4371人已学习 课程介绍 本视频是智捷课堂推出的一套“Java语言学习立体教程”的视频第三部分&#xff0c;读者以及观看群是初级小白&#xff0c;通过本视频的学习能够成为Java大牛。本主要内容包括&#xff1a;异常处理、集合、泛型、文…

Python项目实战:数据可视化与股票数据分析-关东升-专题视频课程

Python项目实战&#xff1a;数据可视化与股票数据分析—333人已学习 课程介绍 本视频内容包括使用Matplotlib绘制图表、MySQL数据库、Python访问数据库和Lambda表达式。 目录&#xff1a; 23.1 使用Matplotlib绘制图表 23.1.1 安装Matplotlib 23.1.2 图表基本构成要素 23.1…

【ShardingSphere技术专题】「ShardingJDBC实战阶段」SpringBoot之整合ShardingJDBC实现分库分表(JavaConfig方式)

前提介绍 ShardingSphere介绍 ShardingSphere是一套开源的分布式数据库中间件解决方案组成的生态圈&#xff0c;它由Sharding-JDBC、Sharding-Proxy和Sharding-Sidecar&#xff08;计划中&#xff09;这3款相互独立的产品组成。 他们均提供标准化的数据分片、分布式事务和数据…

关东升给的ios学习路线图(可以借鉴)

来源&#xff1a; http://www.zhijieketang.com/classroom/3/introduction 首页 课程 免费课程 会员 关于我们 登录 注册 首页 iOS课程 iOS会员-iOS开发学习路线图 iOS会员-iOS开发学习路线图 扫二维码继续学习 (0评价) 价格&#xff1a; 1500 金币 学员(17) 课程(37) …

关东升的《从零开始学Swift》3月9日已经上架

大家一直期盼的《从零开始学Swift》于3月9日已经上架&#xff0c;它是关东升老师历时8个月的呕心沥血所编著&#xff0c;全书600多页&#xff0c;此本书基于Swift 2.x&#xff0c;通过大量案例全面介绍苹果平台的应用开发。全书共分5 部分&#xff0c;包括Swift语法篇、Cocoa T…

python从小白到大牛百度云盘_Java从小白到大牛 (关东升著) 中文pdf+mobi版[36MB]

《Java从小白到大牛》是一本Java语言学习立体教程&#xff0c;读者群是零基础小白&#xff0c;通过本书的学习能够成为Java大牛。主要内容包括&#xff1a;Java语法基础、Java编码规范、数据类型、运算符、控制语句、数组、字符串、面向对象基础、继承与多态、抽象类与接口、枚…

SpringBoot 整合 Sharding-JDBC

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、sharding-jdbc简介二、使用步骤 1.新建项目、引入依赖2.代码实战总结 前言 SpringBoot 整合 Sharding-JDBC 提示&#xff1a;以下是本篇文章正文内容&…

关东升的iOS实战系列图书 《iOS实战:传感器卷(Swift版)》已经上市

&#xfeff;&#xfeff; 承蒙广大读者的厚爱我的 《iOS实战&#xff1a;传感器卷&#xff08;Swift版&#xff09;》京东上市了&#xff0c;欢迎广大读者提出宝贵意见。http://item.jd.com/11760248.html 欢迎关注关东升新浪微博tony_关东升。 关注智捷课堂微信公共平台&…

Java从小白到大牛第1篇 Java基础-关东升-专题视频课程

Java从小白到大牛第1篇 Java基础—3042人已学习 课程介绍 本视频是智捷课堂推出的一套“Java语言学习立体教程”的视频第一部分&#xff0c;读者以及观看群是初级小白&#xff0c;通过本视频的学习能够成为Java大牛。本主要内容包括&#xff1a;Java语法基础、Java编码规范…

Sharding-JDBC 基础

Sharding-JDBC 是当当网开源的适用于微服务的分布式数据访问基础类库&#xff0c;完整的实现了分库分表&#xff0c;读写分离和分布式主键功能&#xff0c;并初步实现了柔性事务。 从 2016 年开源至今&#xff0c;在经历了整体架构的数次精炼以及稳定性打磨后&#xff0c;如今…

python从小白到大牛pdf 下载 资源共享_Kotlin从小白到大牛 (关东升著) 中文pdf高清版[12MB]...

本书是一本Kotlin语言学习立体教程&#xff0c;主要内容包括&#xff1a;Kotlin语法基础、Kotlin编码规范、数据类型、字符串、运算符、程序流程控制、函数、面向对象基础、继承与多态、抽象类与接口、高阶函数、Lambda表达式、数组、集合、函数式编程API、异常处理、线程、协程…