用形态学方法提取骨架线报告-read.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
用形态学方法提取骨架线报告-read

用形态学方法提取骨架线实验报告 一 实验内容 1 用数学形态学的方法提取图像骨架线 二 实验原理 数学形态学介绍 数学形态学提供了一种以形态或集合论为基础对图像进行分析理解的工具。可以用来去除噪声、抽取骨架、插补、分割、多分辨率分析、匹配等。 包括四个主要的算符:扩张(膨胀),腐蚀,开○,闭● 提取骨架的算法 骨架的定义: SK(X)是X的骨架必须满足如下条件: (1) X和SK(X)的连接性一致; (2) SK(X)为单象素宽度; (3) SK(X)位于X的中轴位置。 骨架提取算法可表示为: 其中SK(X)是二维离散数据集X的骨架; “/”为两个数据集的差; N为结构元素的最大尺寸,超过这个值时,一次腐蚀运算将使X成为空集。 三 程序设计 程序还是基于MFC的单文档界面,重用以前的位图包裹类来封装对位图的操作,增加一个数学形态学类来进行通用的数学形态学操作。 程序结构如下: 类定义如下: 位图包裹类(同以前): 数学形态学类: const int STRUCTURE_ELEMENT =100; //结构元素初始 const int SE_SQUARE =STRUCTURE_ELEMENT+1; //方形结构元素 3×3 const int SE_RHOMBUS =STRUCTURE_ELEMENT+2; //菱形结构元素 3×3 const int SE_CRICLE =STRUCTURE_ELEMENT+3; //圆形结构元素 5×5 const int STRUCTURE_ELEMENT_END =STRUCTURE_ELEMENT+4; //结构元素结束 #define _COLOR_BLACK //黑色为0的情况下 #ifdef _COLOR_BLACK const BYTE COLOR_BLACK=0; const BYTE COLOR_WHITE=255; #else const BYTE COLOR_BLACK=255; const BYTE COLOR_WHITE=0; #endif class CMorphology { public: bool Thinning(BYTE* pBuf,int nWidth,int nHeight);//标准细化算法 bool Skeleton(BYTE *pBuf, int nSEType, int nWidth, int nHeight); /*骨架化 功能:对二值图像进行骨架化 输入:pBuf 输出:pBuf 参数:nSEType:结构元素类型,nWidth:图像宽度,nHeight:图像高度 */ bool Open(BYTE* pSrcBuf,BYTE* pDestBuf,int nSEType,int nWidth,int nHeight,BYTE* pSEType=NULL,int nSEWidth=0);//开运算 bool Dilate(BYTE* pSrcBuf,BYTE* pDestBuf,int nSEType,int nWidth,int nHeight,BYTE* pSEType=NULL,int nSEWidth=0); /*扩张 功能:对二值图像进行扩张操作 输入:pSrcBuf 输出:pDestBuf 参数:nSEType:结构元素类型,nWidth:图像宽度,nHeight:图像高度 */ bool Erode(BYTE* pSrcBuf,BYTE* pDestBuf,int nSEType,int nWidth,int nHeight,BYTE* pSEType=NULL,int nSEWidth=0);//腐蚀运算 CMorphology(); virtual ~CMorphology(); private: BYTE* m_pSE; //结构元素,默认核点为中心元素 int m_nSEWidth; //结构元素宽度 protected: void XOR(BYTE *pSrcBuf1, BYTE *pSrcBuf2, BYTE *pDestBuf, int nWidth, int nHeight);//差运算 void OR(BYTE *pSrcBuf1, BYTE *pSrcBuf2, BYTE *pDestBuf, int nWidth, int nHeight);//并运算 void AND(BYTE *pSrcBuf1,BYTE* pSrcBuf2,BYTE* pDestBuf, int nWidth, int nHeight);//交运算 void SetSE(const int nDefSEType,BYTE* pSEType=NULL,int nSEWid

文档评论(0)

wangsux + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档