叶片形状特征提取(概念/代码)

2023-10-20 21:40

本文主要是介绍叶片形状特征提取(概念/代码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 本文主要介绍叶片形状特征提取的相关概念(后续附上matlab代码)

  • 叶片的基础特征

前提:叶片经过二值化(可以使用K-means进行)、降噪、膨胀、腐蚀、叶片轮廓(轮廓跟踪算法))

面积(S):叶片二值化,计算矩阵中白色像素点数量

周长(D):按照链码的计算方式,链码中偶数步的数量为N,奇数步的数量为M

重心(X_{c},Y_{c}):计算重心到边界的最短距离作为特征,记为(c)

凸包:QuickHull算法完成 (此处不再赘述,后续有执行代码)获取凸包的轮廓后可用来计算凸包的周长D_{t}凸包的面积S_{t}

长轴(L):叶片的轮廓上距离最长的两个点

短轴(W):叶片轮廓上与长轴互相垂直且距离最长的两个点

面积最小外接矩阵(S_{min}):叶片长轴与短轴的乘积

周长最小外接矩阵(D_{min}):以等间隔的角度使物体在90度的范围内旋转,每次旋转之后用水平外界矩阵对其进行拟合,记录下周长最小的外接矩阵的参数,长rect_{l} ,宽rect_{w}


附:叶片特征提取图像

                            

                   原图                           轮廓                            重心                           凸包                           长短轴               周长最小外接矩阵


  • 相对特征

前提:已经获取叶片基础特征)

面积凹凸比(CA):叶片面积/凸包面积                       CA=S/S_{t}

周长凹凸比(CP):叶片周长/凸包周长                       CP=D/D_{t}

形状参数(F):描述叶片紧凑程度                               F=4\pi S/D^{2}

圆形度(C):衡量叶片边界的复杂度                           C=D^{2}/S

狭长度(N):叶片长轴/叶片短轴                                 N=L/W

矩形度(R):叶片面积/面积最小外接矩阵面积          R=S/S_{min}

周长长宽比(PRP):叶片周长/长轴与短轴和              PRP=D/(L+W)

横纵比(Q):周长最小外接矩阵的长/宽                      Q=rect_{l}/rect_{w}

周径比(M):叶片周长/长轴                                         M=D/L

叶状性(Z):叶片重心到边界最短距离/短轴               Z=c/W

 

以上均为写一些相关论文以及查阅文献整理出来,如有错误可及时提出进行修改!

关于以上特征提取的相关代码,在下一篇博客中将会以函数的形式呈现,方便大家调用!

 

 

 

 

 

 

 

 

 

这篇关于叶片形状特征提取(概念/代码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/249903

相关文章

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Java springBoot初步使用websocket的代码示例

《JavaspringBoot初步使用websocket的代码示例》:本文主要介绍JavaspringBoot初步使用websocket的相关资料,WebSocket是一种实现实时双向通信的协... 目录一、什么是websocket二、依赖坐标地址1.springBoot父级依赖2.springBoot依赖

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

什么是 Java 的 CyclicBarrier(代码示例)

《什么是Java的CyclicBarrier(代码示例)》CyclicBarrier是多线程协同的利器,适合需要多次同步的场景,本文通过代码示例讲解什么是Java的CyclicBarrier,感... 你的回答(口语化,面试场景)面试官:什么是 Java 的 CyclicBarrier?你:好的,我来举个例

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

HTML5 data-*自定义数据属性的示例代码

《HTML5data-*自定义数据属性的示例代码》HTML5的自定义数据属性(data-*)提供了一种标准化的方法在HTML元素上存储额外信息,可以通过JavaScript访问、修改和在CSS中使用... 目录引言基本概念使用自定义数据属性1. 在 html 中定义2. 通过 JavaScript 访问3.

Flutter监听当前页面可见与隐藏状态的代码详解

《Flutter监听当前页面可见与隐藏状态的代码详解》文章介绍了如何在Flutter中使用路由观察者来监听应用进入前台或后台状态以及页面的显示和隐藏,并通过代码示例讲解的非常详细,需要的朋友可以参考下... flutter 可以监听 app 进入前台还是后台状态,也可以监听当http://www.cppcn

Python使用PIL库将PNG图片转换为ICO图标的示例代码

《Python使用PIL库将PNG图片转换为ICO图标的示例代码》在软件开发和网站设计中,ICO图标是一种常用的图像格式,特别适用于应用程序图标、网页收藏夹图标等场景,本文将介绍如何使用Python的... 目录引言准备工作代码解析实践操作结果展示结语引言在软件开发和网站设计中,ICO图标是一种常用的图像

Java中有什么工具可以进行代码反编译详解

《Java中有什么工具可以进行代码反编译详解》:本文主要介绍Java中有什么工具可以进行代码反编译的相关资,料,包括JD-GUI、CFR、Procyon、Fernflower、Javap、Byte... 目录1.JD-GUI2.CFR3.Procyon Decompiler4.Fernflower5.Jav

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值