您现在的位置:首页 >> 图像处理 >> 内容

基于Surf+GTM的图像配准和拼接算法matlab仿真

时间:2022/12/10 19:48:31 点击:

  核心提示:A106,包括程序操作录像...

1.完整项目描述和程序获取

>面包多安全交易平台:https://mbd.pub/o/bread/Y5mXlZ9p

>如果链接失效,可以直接打开本站店铺搜索相关店铺:

点击店铺

>如果链接失效,程序调试报错或者项目合作可以加微信或者QQ联系。

2.部分仿真图预览




3.算法概述

       SIFT采用的是DoG图像,而SURF采用的是Hessian矩阵(SURF算法核心)行列式近似值图像。在数学中,Hessian矩阵是一个自变量为向量的实值函数的二阶偏导数组成的方块矩阵,即每一个像素点都可以求出一个2x2的Hessian矩阵,可计算出其行列式detH,可以利用行列式取值正负来判别该点是或不是极值点来将所有点分类。在SURF算法中,选用二阶标准高斯函数作为滤波器,通过特定核间的卷积计算二阶偏导数,从而计算出Hessian矩阵,但是由于特征点需要具备尺度无关性,所以在进行Hessian矩阵构造前,需要对其进行高斯滤波(由于高斯核服从正态分布,所以为了提高运算速度,SURF采用了盒式滤波器近似代替高斯滤波器提高运算速度),即与以方差为自变量的高斯函数的二阶导数进行卷积。通过这种方法可以为图像中每个像素计算出其H的行列式的决定值,并用这个值来判别特征点。

       与Sift特征点匹配类似,Surf也是通过计算两个特征点间的欧式距离来确定匹配度,欧氏距离越短,代表两个特征点的匹配度越好。 不同的是Surf还加入了Hessian矩阵迹的判断,如果两个特征点的矩阵迹正负号相同,代表这两个特征具有相同方向上的对比度变化,如果不同,说明这两个特征点的对比度变化方向是相反的,即使欧氏距离为0,也直接予以排除。

4.部分源码

clc;

clear;

close all;

warning off;

addpath(genpath(pwd));

  I1=imread('TestImages/testc1.png');

  I2=imread('TestImages/testc2.png');

% Get the Key Points

  Options.upright=true;

  Options.tresh=0.0001;

  Ipts1=OpenSurf(I1,Options);

  Ipts2=OpenSurf(I2,Options);

% Put the landmark descriptors in a matrix

  D1 = reshape([Ipts1.descriptor],64,[]); 

  D2 = reshape([Ipts2.descriptor],64,[]); 

% Find the best matches

  err=zeros(1,length(Ipts1));

  cor1=1:length(Ipts1); 

  cor2=zeros(1,length(Ipts1));

  for i=1:length(Ipts1),

      distance=sum((D2-repmat(D1(:,i),[1 length(Ipts2)])).^2,1);

      [err(i),cor2(i)]=min(distance);

  end

% Sort matches on vector distance

  [err, ind]=sort(err); 

  cor1=cor1(ind); 

  cor2=cor2(ind);

% Show both images

  I = zeros([size(I1,1) size(I1,2)*2 size(I1,3)]);

  I(:,1:size(I1,2),:)=I1; I(:,size(I1,2)+1:size(I1,2)+size(I2,2),:)=I2;

  figure, imshow(I/255); hold on;

A106

作者:我爱C编程 来源:我爱C编程
本站最新成功开发工程项目案例
相关评论
发表我的评论
  • 大名:
  • 内容:
本类固顶
  • 没有
  • FPGA/MATLAB商业/科研类项目合作(www.store718.com) © 2025 版权所有 All Rights Reserved.
  • Email:1480526168@qq.com 站长QQ: 1480526168