基于Matlab-图像匹配——模板匹配(共8页).docx
精选优质文档-倾情为你奉上 课程名称 数字图像处理 实验序号 实验8 实验名称 图像匹配模板匹配 实验地点 综B207 实验学时 2 实验类型 验证性 2017年 10 月 16 日一、实验目的及要求在机器识别物体的过程,常需把不同传感器或同一传感器在不同时间,不同成像条件下对同一景物获取的两幅或多幅图像在空间上对准,或根据已知模式到另一幅图中寻找相应的模式,这就叫做匹配。模板匹配是一种最原始、最基本的模式识别方法。利用模板匹配可以在一幅图像中找到已知的物体。这里的模板指的是一幅待匹配的图像,相当于模式识别的模式。基本要求如下: (1).进行匹配的两幅图像为JPG格式或BMP格式。 (2).能够进行对两幅数字图像的匹配。 (3)采用交互式程序对图像进行匹配。二、实验原理与内容模板匹配是指用一个较小的图像,即模板与源图像进行比较,以确定在源图像中是否存在与该模板相同或相似的区域,若该区域存在,还可确定其位置并提取该区域。 模板匹配常用的一种测度为模手术台与源图像对应区域的误差平方和。设f(x,y)为M×N的源图像,t(j,k)为J×K(JM,KN)的模板图像,则误差平方和测度定义为: DS(x,y)称为源图像中与模板对应区域的能量,它与像素位置(x,y)有关,但随像素位置(x,y)的变化,DS(x,y)变化缓慢。DST(x,y)模板与源图像对应区域的互相关,它随像素位置(x,y)的变化而变化,当模板t(j,k)和源图像中对应区域相匹配时取最大值。DT(x,y)称为模板的能量,它与图像像素位置(x,y)无关,只用一次计算便可。显然,计算误差平方和测度可以减少计算量。 基于上述分析,若设DS(x,y)也为常数,则用DST(x,y)便可进行图像匹配,当DST(x,y)取最大值时,便可认为模板与图像是匹配的。但假设DS(x,y)为常数会产生误差,严重时将无法下确匹配,因此可用归一化互相关作为误差平方和测度,其定义为:模板匹配的示意图如图图2.1所示,其中假设源图像f(x,y)和模板图像t(k,l)的原点都在左上角。对任何一个f(x,y)中的(x,y),根据上式都可以算得一个R(x,y).当x和y变化时,t(j,k)在源图像区域中移动并得出R(x,y)所有值。R(x,y)的最大值指出了与t(j,k)匹配的最佳位置,若从该位置开始在源图像中取出与模板大小相同的一个区域,便可得到匹配图像。三、实验软硬件环境1.计算机2.Matlab软件四、实验过程(实验步骤、记录、数据、分析)1. 图像模板匹配实验代码如下:a=imread('b.jpg');a1=imcrop(a);imwrite(a1,'moban.jpg','jpg'); %构建一个模板pipeitu=imread('moban.jpg');%读取模板图像yuantu2gray=rgb2gray(yuantu);%将原图灰度化pipeitu2gray=rgb2gray(pipeitu);%将模板图灰度化pipei_height,pipei_width=size(pipeitu2gray);yuantu_height,yuantu_width=size(yuantu2gray);imshow(yuantu);%显示原图像hold on;for i=1:yuantu_height-pipei_height for j=1:yuantu_width-pipei_width temp_picture=imcrop(yuantu2gray,j,i,pipei_width-1,pipei_height-1); r=corr2(temp_picture,pipeitu2gray);%取得相关系数 if r>0.95 %规定值为0.95%下面用plot函数在原图的坐标系上画出匹配区域 plot(j:j+pipei_width,i,'b'); plot(j:j+pipei_width,i+pipei_height,'b'); plot(j,i:i+pipei_height,'b'); plot(j+pipei_width,i:i+pipei_height,'b'); end endend这是在原图上截取一部分作为模板,经过比较长的运算,终于可以在原图像上匹配到的区域五、测试/调试及实验结果分析通过代码,可以看到在原图像找到了匹配区域,并且可以画上了对应的框。六、实验结论与体会结论:通过本次实验学会了如何在原图像上截取部分作为匹配模板。由于本次读入的图像大概为250k,相对有点大,所以经过了比较长的时间才将匹配区域找到。因此我觉得,提高效率的有连个,一是先把图像经过压缩再进行匹配,二是优化算法,提高代码的执行率。专心-专注-专业