- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 2025年文山州砚山县中医医院第十一期招聘(18人)笔试备考题库及答案解析.docx VIP
- C186015【基础】2025年海南医学院105300公共卫生《353卫生综合之医学统计学》考研基础.pdf VIP
- 2025年湖南有色金属职业技术学院单招职业技能测试题库及一套答案.docx
- 中国乙型肝炎病毒母婴传播防治指南(2024年版)解读.pptx
- 有机磷农药中毒.ppt VIP
- 骨科手术护理培训.pptx VIP
- 2025退役分类考试题及答案.docx VIP
- 护线宣传方案课件.pptx VIP
- 2025年文山州砚山县中医医院第十一期招聘(18人)笔试备考试题及答案解析.docx VIP
- SL 557-2012水利基本建设项目竣工决算审计规程.pdf
文档评论(0)