- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
用形态学方法提取骨架线实验报告
朱俊 0220080198
一 实验内容
1 用数学形态学的方法提取图像骨架线
二 实验原理
数学形态学介绍
数学形态学提供了一种以形态或集合论为基础对图像进行分析理解的工具。可以用来去除噪声、抽取骨架、插补、分割、多分辨率分析、匹配等。
包括四个主要的算符:扩张(膨胀) eq \o\ac(○,+),腐蚀 eq \o\ac(○,-),开○,闭●
提取骨架的算法
骨架的定义:
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* pS
文档评论(0)