sift程序详解PPT.ppt
《sift程序详解PPT.ppt》由会员分享,可在线阅读,更多相关《sift程序详解PPT.ppt(28页珍藏版)》请在咨信网上搜索。
单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,#,SIFT,特征提取过程中,的核心函数,1,PART ONE.,物理架构,opencv_contrib-3.1.0,(,版本号,)/modules/xfeature2d/opencv_xfeature2d project/src/sift.cpp,cv namespace,xfeature2d namespace,Feature2D,父类,/,基类,SIFT,类,feature2d,的子类,父类,/,基类,SIFT_Impl,类,SIFT,的子类,2,2024/11/22 周五,PART TWO.,运行架构,主函数,int main(),/,创建,SIFT_Impl,类指针,Ptr f2d=xfeatures2d:SIFT:create();,Mat img_1=imread(1.jpg);,/读入图片,vector keypoints_1;,/用于存放检测到的关键点的容器,f2d-detect(img_1,keypoints_1);,/,检测出关键点,Mat descriptors_1;,f2d-compute(img_1,keypoints_1,descriptors_1);,/计算描述子,waitKey(0);,/等待任意按键按下,3,2024/11/22 周五,Feature2D,:detect(InputArray image,CV_OUT std:vector&keypoints,InputArray mask=noArray(),SIFT_Impl:detectAndCompute(image,mask,keypoints,noArray(),false);,SIFT_Impl:,detectAndCompute(image,noArray(),keypoints,descriptors,true);,Feature2D:compute(InputArray image,std:vector&keypoints,OutputArray descriptors),调用了 检测关键点函数,调用了 计算描述子函数,4,2024/11/22 周五,createInitialImage(),图像初始化函数,buildGaussianPyramid()构建高斯金字塔函数,buildDoGPyramid()构建,DOG,金字塔函数,SIFT_Impl:detectAndCompute(image,mask,keypoints,noArray(),false);,findScaleSpaceExtrema()检测尺度空间极值函数,adjustLocalExtrema(,),调整极值函数,calcOrientationHist,(),计算关键点主方向函数,函数功能:检测图片中的关键点,参数,image,:输入图片,参数,mask,:无掩模,参数,keypoints,:关键点容器,参数,noArray(),:无描述子,参数,false:,不使用给定的关键点,PART TREE.,检测关键点部分,5,2024/11/22 周五,图像尺度空间的构建,1.1,图像初始化函数,函数功能:,将输入图像转化为灰度图,并设置图像初始尺度,c+:,static Mat createInitialImage(const Mat&img,bool double ImageSize,float sigma),入口参数:,参数,const Mat&img:输入图像,参数,bool double ImageSize:是否将初始图像扩大两倍,若值为,1,,则图像扩大为原来两倍,参数,float sigma:设定图像的初始尺度,返回值:无,说明:,一个图像的尺度空间,L(x,y,),,定义为原始图像,I(x,y),与一个可变尺度的,2,维高斯函数,G(x,y,),卷积产生:,其中:,lowe,把初始图像的尺度,I(x,y),设置为,0.5,即:,I(x,y)=I(x,y,0.5),,那么由,L(x,y,1),得到,L(x,y,2),,即由尺度为,1,的图像生成尺度为,2,的图像的公式为:,6,图像尺度空间的构建,1.2,构建图像金字塔函数:,函数功能:,将输入图像作为金字塔初始图像,通过不断进行高斯模糊和降采样后的,图片存放在,Mat,类容器中,c+:,void SIFT_Impl:buildGaussianPyramid(const Mat&base,std:vector&pyr,int nOctaves)const,入口参数:,参数,const Mat&base:输入图像,参数,std:vector&pyr:用于存储金字塔图像的容器,参数,int nOctaves:金字塔的组数,返回值:无,7,图像尺度空间的构建,1.3,构建图像,DOG,金字塔函数:,函数功能:,将构建好的高斯金字塔相邻层相减后构成,DOG,金字塔存放在,Mat,类容器中,void SIFT_Impl:buildDoGPyramid(const std:vector&gpyr,std:vector&dogpyr)const,入口参数:,参数:vector&gpyr:存放高斯金字塔图片的容器,参数:vector&dogpyr:存放,DOG,金字塔图片的容器,返回值:无,8,关键点定位,关键点定位并确定主方向函数,函数功能:,(,1,)在,DOG,空间检测极值点,(,2,)精确定位关键点位置和尺度并进行插值处理,(,3,)去除边缘不稳定的点,(,4,)为关键点分配主方向,void SIFT_Impl:findScaleSpaceExtrema(const std:vector&gauss_pyr,const std:vector&dog_pyr,std:vector&keypoints)const,入口参数:,参数const std:vector&gauss_pyr:高斯金字塔容器,参数,const std:vector&dog_pyr:,DOG,金字塔容器,参数std:vector&keypoints:存放关键点容器,返回值:无,9,调整局部极值函数,函数功能:,精确定位关键点位置和尺度并进行插值处理,去除边缘不稳定的点,static bool adjustLocalExtrema(const std:vector&dog_pyr,KeyPoint&kpt,int octv,int&layer,int&r,int&c,int nOctaveLayers,float contrastThreshold,float edgeThreshold,float sigma),入口参数:,参数const std:vector&dog_pyr:,DOG,尺度空间金字塔,参数KeyPoint&kpt:定义了一个,KeyPoint,类对象用来存放筛选通过的关键点,参数int octv:该像素点所在的组数,参数,int&layer:该像素点所在的层数,参数int&r:该像素点所在的行,参数int&c:,该像素点所在的列,参数int nOctaveLayers:金字塔每组的层数,S,参数float contrastThreshold:对比度阈值,0.04,参数float edgeThreshold:边缘响应阈值,参数float sigma:此处的,sigma,为初始尺度,sigma0,返回值:,若极值调整成功返回,1,,调整失败返回,0,10,2024/11/22 周五,说明:,其中令 得:,令 解得 :,接下来判断偏移量在每个维度的偏差是否大于,0.5,,若不大于直接保留,若大于进行迭代插值处理。在设置的迭代次数内修正成功则保留,否则舍弃。,设,f,(,i,,,j,)是,y,轴为,i,、,x,轴为,j,的图像像素值,则在,(,i,,,j,)点处的一阶、二阶及二阶混合偏导为:,再对 进行筛选去除对比度低的点,在,opencv,中,使用下面的公式来判断其是否为不稳定的极值:,11,2024/11/22 周五,去除边缘响应较强的点,具体在程序中的计算同上:,12,2024/11/22 周五,计算关键点主方向函数,函数功能:,为特征点分配主方向,static float calcOrientationHist(const Mat&img,Point pt,int radius,float sigma,float*hist,int n),入口参数:,参数const Mat&img:当前特征点所在的图像,参数Point pt:关键点位置,参数int radius:指统计在以关键点为中心,以,radius=3*1.5sigma,为半径的区域为作为该关键点的邻域,以统计直方图的形式来确定主方向,参数float sigma:这里的,sigma,是指相对于当前组第一层图像的尺度来说的,参数float*hist:定义了,hist,指针用于存放直方图,参数int n:直方图的条数,返回值:,直方图的主峰值,说明:直方图平滑处理;,opencv,使用的平滑公式为:,由于直方图代表的只是一个角度范围,想要得到更精确的方向角度值,需要对离散的梯度方向直方图进行插值拟合处理,拟合公式为:,13,SIFT_Impl:,detectAndCompute,(image,noArray(),keypoints,descriptors,true),函数功能:计算图片中的关键点描述子,参数,image,:输入图片,参数noArray():无掩模,参数,keypoints,:关键点容器,参数descriptors:描述子,参数,true:,使用给定的关键点,unpackOctave(),calcDescriptors(),计算关键点描述子函数,calcSIFTDescriptor,PART FOUR.,关键点描述子,createInitialImage(),图像初始化函数,buildGaussianPyramid()构建高斯金字塔函数,buildDoGPyramid()构建,DOG,金字塔函数,14,2024/11/22 周五,unpackOctave(const KeyPoint&kpt,int&octave,int&layer,float&scale),计算,sift,特征描述子,入口参数:,参数,const KeyPoint&kpt,:关键点,参数,int&octave,:关键点所在层,参数,int&layer,:关键点所在组,参数,float&scale,:,关键点所在尺度的比例因子,返回值:无,函数功能:去除关键点所在高斯金字塔的层数,组数,以及尺度比例因子,以方便后面计算描述子,15,2024/11/22 周五,计算,sift,特征描述子,3.2,计算,sift,特征描述子,函数功能:计算特征点描述符,calcDescriptors,函数,static void calcDescriptors(const std:vector&gpyr,const std:vector&keypoints,Mat&descriptors,int nOctaveLayers,int firstOctave),入口参数:,参数const std:vector&gpyr:,存放高斯金字塔图片的容器,参数const std:vector&keypoints:存放关键点的容器,参数Mat&descriptors:,描述子矩阵,参数int nOctaveLayers,:,高斯金字塔层数,参数int firstOctave,:如果原图像扩大两倍,则为-1,如果没有,则为0,返回值:无,说明,:,计算,sift,特征描述子要用高斯金字塔,,dog,金字塔只用来求取极值点,int d=SIFT_DESCR_WIDTH=4,,,n=SIFT_DESCR_HIST_BINS=8,float size=kpt.size,*,scale,计算特征点的特征矢量,calcSIFTDescriptor,(img,ptf,angle,size*0.5f,d,n,descriptors.ptr(int)i),16,2024/11/22 周五,函数功能:计算,sift,特征描述子,static void calcSIFTDescriptor(const Mat&img,Point2f ptf,float ori,float scl,int d,int n,float*dst),3.3,计算,sift,特征点的描述矢量:,入口参数:,参数const Mat&img:输入图像,参数,Point2f ptf:输入检测到的特征点,,float,型,参数,float ori:特征点的幅角,角度,,float,型,参数,float scl:输入特征点的尺度,参数,int d:特征点周围邻域的宽度,参数,int n:设定直方图的条目数,之前统计主方向时设,n=36,,现在计算特征矢量,n=8,参数,float*dst:输出特征点的描述矢量,,float,型,返回值:无,17,2024/11/22 周五,关键点描述子,1.,首先要明确,我们前面的步骤分别得到了关键点的位置(层,组,所在图像的横纵坐标),尺度,主方向的信息,我们的特征描述子是回到了高斯金字塔上去做的。所以我们定位关键点在高斯金塔的那一张图片上。,2.,然后确定用描述周围多大的区域去描述这个关键点,首先我们把这块区域分成,d*d,个小区域,,sift,中,d=4,,如图中蓝色区域所示,每一格的宽度为,3,,这里的,是指相对于当前组第一层图片来说的。,注意:,opencv,中计算的区域是最外面的橘色的矩形区域,面积为,(2Rradius+1)*(2Rradius+1),其中:,18,3.,根据公式,来计算橘色矩形内每个像素点的幅值和幅角。,4.,接下来将橘色矩形内的每个像素的幅角按照旋转关键点主方向的角度,使得关键点主方向为,0,(或统一为多少度),5.,建立三维直方图,如图所示,,三维直方图是由,(opencv,中,)(d+2)*(d+2)(n+2),个长宽高均为,1,的单位立方体组成的三维直方图,高对应邻域像素幅角的大小,把,360,度分成,8,等分,立方体的底就是特征点的邻域区域。该区域被分为,4,*,4,个子区域(,opencv,中划分了,(d+2)*(d+2),个区域),邻域内的像素根据坐标位置,把他们归属到这,16,个子区域的一个,再根据邻域像素的幅角的大小,把他们归属到这,8,等分,(opencv,中为,n+2),中的一份,这样每个像素点都能对应到其中的一个立方体里,三维直方图建立起来了。,(,这里分别把每个像素的横纵坐标和幅角都进行了归一化处理,),。,19,横纵坐标,+d/2,横,纵,坐,标,减,0.5,6.,三线性插值的计算,-,坐标平移,20,2024/11/22 周五,6.,三线性插值的计算,x,y,正方体的中点,同时是立方体的顶点,显然,正方体的中心应该代表着该正方体,但落入正方体的邻域像素不可能都在中心,因此,根据它对中心点位置的贡献大小进行加权处理,即在正方体内,根据像素点相对于正方体的距离,对梯度幅值做加权处理。,在实际应用中,我们需要经过坐标平移,把中心点平移到正方体的顶点上,这样只要计算出正方体内的点对正方体的,8,个顶点的贡献大小即可。,根据三线性插值法,对某点的贡献值是以该顶点和正方体内的点为对角线的两个顶点,所构成的立方体的体积。,21,6.,三线性插值的计算,-,程序实现,根据三线性插值法,对某点的贡献是以该顶点和正方体内的点为对角线的两个顶点,所构成的立方体的体积:,22,6.,描述子归一化处理,经过上述处理后我们得出,128,维描述子,在,opencv,中,一共对描述子进行了两次,归一化处理。,第一次使用一下公式对,描述子进行归一化处理,并对大于,0.2,的描述子,进行截断处理:,假设经过第一次归一化处理后描述子用 表示,第二次归一化操作是:,其中分母要大于,FLT_EPSILON,#define FLT_EPSILON 1.192092896e-07F,23,24,2024/11/22 周五,25,2024/11/22 周五,26,2024/11/22 周五,27,2024/11/22 周五,28,2024/11/22 周五,- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- sift 程序 详解 PPT
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文