当前位置: 首页 > article >正文

角点特征检测技术:Harris与Harris-Laplace算法研究

‍博主简介博士研究生超级学长超级学长实验室提供各种程序开发、实验复现与论文指导个人邮箱easy_optics126.com个人微信easy_optics个人企鹅754357517 目 录摘要原理1. 角点定义2. Harris角点检测算法3. Harris-Laplace算法实验过程实验1Harris角点检测手动实现实验2使用MATLAB内置函数实验3Harris-Laplace多尺度检测实验结果结果1Harris角点响应图结果2手动实现Harris角点检测结果3OpenCV Harris角点检测结果4Harris-Laplace多尺度角点检测结果5算法对比总结摘要角点是图像中重要的局部特征点广泛应用于图像匹配、目标识别、运动跟踪等领域。本实验实现了Harris角点检测和Harris-Laplace多尺度角点检测两种算法验证了角点检测的有效性和多尺度特征的稳定性。实验结果表明Harris算法能够有效检测图像中的角点特征而Harris-Laplace算法则在多尺度空间中检测角点具有更好的尺度不变性。原理1. 角点定义角点是图像中两条边缘的交点或者说是局部窗口沿各方向移动都能检测到灰度变化明显的点。角点具有以下特征局部特征明显对旋转、平移不变计算简单检测效率高2. Harris角点检测算法Harris角点检测基于图像局部自相关性。对于图像I ( x , y ) I(x,y)I(x,y)在点( x , y ) (x,y)(x,y)处平移( u , v ) (u,v)(u,v)后的灰度变化为E ( u , v ) ∑ x , y w ( x , y ) [ I ( x u , y v ) − I ( x , y ) ] 2 E(u,v) \sum_{x,y} w(x,y) [I(xu, yv) - I(x,y)]^2E(u,v)x,y∑​w(x,y)[I(xu,yv)−I(x,y)]2通过泰勒展开可以表示为E ( u , v ) ≈ [ u , v ] M [ u v ] E(u,v) \approx [u, v] M \begin{bmatrix} u \\ v \end{bmatrix}E(u,v)≈[u,v]M[uv​]其中M MM是自相关矩阵M ∑ x , y w ( x , y ) [ I x 2 I x I y I x I y I y 2 ] M \sum_{x,y} w(x,y) \begin{bmatrix} I_x^2 I_x I_y \\ I_x I_y I_y^2 \end{bmatrix}Mx,y∑​w(x,y)[Ix2​Ix​Iy​​Ix​Iy​Iy2​​]Harris角点响应函数定义为R det ⁡ ( M ) − k ⋅ trace ( M ) 2 R \det(M) - k \cdot \text{trace}(M)^2Rdet(M)−k⋅trace(M)2其中det ⁡ ( M ) λ 1 λ 2 \det(M) \lambda_1 \lambda_2det(M)λ1​λ2​是矩阵的行列式trace ( M ) λ 1 λ 2 \text{trace}(M) \lambda_1 \lambda_2trace(M)λ1​λ2​是矩阵的迹k kk是经验常数通常取0.04~0.06当R RR大于阈值时该点被认为是角点。3. Harris-Laplace算法Harris-Laplace算法是对Harris角点检测的多尺度扩展主要步骤包括构建尺度空间在不同尺度上计算Harris角点响应尺度归一化使用尺度归一化的LoG算子进行尺度选择特征点选择选择在空间和尺度上都达到极值的点尺度归一化的LoG响应为∣ L o G ( σ ) ∣ σ 2 ∣ L x x L y y ∣ |LoG(\sigma)| \sigma^2 |L_{xx} L_{yy}|∣LoG(σ)∣σ2∣Lxx​Lyy​∣实验过程实验1Harris角点检测手动实现使用MATLAB代码实现Harris角点检测function[posr,posc]Harris1(in_image,a)% 功能检测图像的Harris角点% 输入in_image-待检测的RGB图像% a-角点响应参数取值范围为0.04到0.06% 把RGB图像转换为灰度图像in_imagergb2gray(in_image);ori_imdouble(in_image);%%%%%%计算图像在x和y方向的梯度%%%%%%fx[-101];Ixfilter2(fx,ori_im);fy[-1;0;1];Iyfilter2(fy,ori_im);%%%%%%计算两个方向的梯度乘积%%%%%%Ix2Ix.^2;Iy2Iy.^2;IxyIx.*Iy;%%%%%%使用高斯函数对梯度乘积进行加权%%%%%%hfspecial(gaussian,[77],2);Ix2filter2(h,Ix2);Iy2filter2(h,Iy2);Ixyfilter2(h,Ixy);%%%%%%计算每个像素的Harris响应值%%%%%%fori1:heightforj1:width M[Ix2(i,j)Ixy(i,j);Ixy(i,j)Iy2(i,j)];R(i,j)det(M)-a*(trace(M))^2;endend实验2使用MATLAB内置函数% 生成角点度量矩阵并进行检测Ccornermetric(I,Harris);corner_peaksimregionalmax(C);corner_idxfind(corner_peakstrue);实验3Harris-Laplace多尺度检测functionpointsharrislaplace(img)% 功能提取Harris-Laplace角点% 尺度参数sigma_begin1.5;sigma_step1.2;sigma_nb13;% 第一部分提取Harris角点fori1:sigma_nb s_Isigma_array(i);s_D0.7*s_I;% 计算Harris响应k0.06;cim(Ix2.*Iy2-Ixy.^2)-k*(Ix2Iy2).^2;end% 第二部分Laplace变换% 尺度归一化LoG响应laplace_snlo(:,:,i)s_L*s_L*imfilter(img,fspecial(log,floor(6*s_L1),s_L));实验结果结果1Harris角点响应图图中展示了Harris角点响应值的热力图响应值越高的区域表示角点可能性越大。结果2手动实现Harris角点检测使用手动实现的Harris算法检测角点红色标记表示检测到的角点位置。结果3OpenCV Harris角点检测使用OpenCV内置Harris角点检测函数的结果对比。结果4Harris-Laplace多尺度角点检测Harris-Laplace算法在不同尺度上检测角点圆圈大小表示特征尺度。结果5算法对比对比了不同角点检测算法的效果包括手动Harris、OpenCV Harris和Harris-Laplace。总结本实验成功实现了Harris角点检测和Harris-Laplace多尺度角点检测算法得出以下结论Harris角点检测计算简单检测效率高对旋转、平移具有不变性对尺度变化敏感Harris-Laplace算法具有尺度不变性在多尺度空间检测特征点计算复杂度较高应用建议对于固定尺度的图像匹配Harris算法是高效的选择对于需要尺度不变性的应用如目标识别应选择Harris-Laplace算法超级学长科研实验室简介工程光学、物理光学、智能优化算法、信号处理、图像处理、机器视觉、深度学习、神经网络等领域实验搭建与实验数据分析等程序开发、光学相关实验开展、课题选题与科研/论文指导等均可私信交流。

相关文章:

角点特征检测技术:Harris与Harris-Laplace算法研究

👨‍🎓 博主简介:博士研究生 🔬 超级学长:超级学长实验室(提供各种程序开发、实验复现与论文指导) 📧 个人邮箱:easy_optics126.com 💬 个人微信&#…...

STM32 GPIO模拟OneWire协议实战:手把手教你与DS2431 EEPROM通信

STM32 GPIO模拟OneWire协议实战:手把手教你与DS2431 EEPROM通信 在嵌入式系统开发中,与各种外设的通信是工程师们经常需要面对的挑战。当项目需要连接多个传感器或存储设备时,传统的I2C、SPI等总线协议虽然常见,但在某些特定场景下…...

Qwen3-TTS在教育场景落地:AI教师多语种发音训练工具搭建实战

Qwen3-TTS在教育场景落地:AI教师多语种发音训练工具搭建实战 想象一下,一位能流利切换十种语言、发音标准、情感饱满的AI教师,正在为你的学生进行一对一的发音训练。这不再是科幻电影里的场景,而是我们今天就能用Qwen3-TTS-12Hz-…...

SC16IS7XX UART扩展库:工业级双通道串口驱动详解

1. 项目概述Appnostic SC16IS7XX Arduino Library 是一款面向嵌入式硬件工程师的工业级 UART 扩展驱动库,专为 NXP 半导体推出的 SC16IS750、SC16IS751 和 SC16IS752 系列双通道/单通道异步收发器芯片设计。该系列芯片本质是高度集成的“UART-to-Bus”桥接器&#x…...

GLM-Image边缘计算:在终端设备上实现图像生成

GLM-Image边缘计算:在终端设备上实现图像生成 让AI图像生成能力从云端走向终端,释放边缘计算的无限可能 你有没有遇到过这样的情况:想要快速生成一张产品展示图,但网络不稳定导致云端服务响应缓慢;或者需要处理敏感图片…...

Python新手入门:一下看懂try-except异常处理

你是不是写 Python 时经常遇到: 1.程序跑一半突然报错 2.输入数字变成字符串、除 0、文件找不到 3.一出错整个程序直接崩掉,后面代码都不跑了今天用最简单、最新手友好的方式,带你彻底学会 try except ——Python 里专门用来抓错误、防崩溃的…...

SEO_2024年最有效的SEO实战技巧与方法全解析

2024年最有效的SEO实战技巧与方法全解析在当今竞争激烈的互联网环境中,如何有效提升网站的搜索引擎优化(SEO)已成为每个网站运营者的首要任务。2024年,SEO的技术和策略也在不断演变。本文将详细探讨2024年最有效的SEO实战技巧与方…...

脑机离婚案:妻子要求分割我的记忆云盘——软件测试视角下的数字资产分割挑战

未来离婚案的科技困局在2050年,脑机接口(BMI)技术已普及,人类记忆可上传至“记忆云盘”,成为个人数字资产的核心部分。作为软件测试工程师,我在NeuroTech公司负责BMI系统的安全测试。当妻子提起离婚诉讼&am…...

ILI9341 TFT驱动开发:8080并口嵌入式图形库实战

1. 项目概述AitendoTFT 是一款专为 Aitendo 公司推出的 2.6 英寸 TFT LCD 扩展板设计的嵌入式图形驱动库,原生支持 Arduino UNO(ATmega328P)与 STMicroelectronics STM32 Nucleo 系列开发板(如 NUCLEO-F401RE、NUCLEO-F411RE&…...

Arduino R4 WiFi 12×8点阵数字显示库:零依赖轻量级实现

1. 项目概述Pantalla12x8 是一个专为 Arduino R4 WiFi 平台设计的轻量级图形显示库,面向物理尺寸为 128 像素的单色点阵显示屏。该库不依赖任何外部显示驱动芯片(如 MAX7219、HT16K33)或复杂图形框架,而是直接以位图数据形式驱动硬…...

【第三十七周】论文阅读03

文章目录摘要Abstract一、《LLaVA-Scissor: Token Compression with Semantic Connected Components for Video LLMs》1. 摘要2. 介绍3. 相关工作4. Llava-删除5. 实验5.1 压缩类型5.2 令牌压缩中的递减规律二、FastVLM: Efficient Vision Encoding for Vision Language Models…...

SEO_快速诊断并解决网站SEO问题的五个步骤(384 )

SEO:快速诊断并解决网站SEO问题的五个步骤在当今的互联网时代,网站的SEO优化已经成为提升网站流量、吸引更多潜在客户的关键。面对复杂多变的搜索引擎算法,很多网站主都会遇到各种各样的SEO问题。本文将为大家详细介绍五个步骤,帮助你快速诊断…...

Qwen2.5-VL-7B-Instruct开源可部署优势:完全离线运行,无外网依赖保障安全

Qwen2.5-VL-7B-Instruct开源可部署优势:完全离线运行,无外网依赖保障安全 1. 项目概述 Qwen2.5-VL-7B-Instruct是一款强大的多模态视觉-语言模型,能够同时处理图像和文本输入,生成高质量的文本输出。这个开源模型最突出的特点是…...

保姆级教程:用MATLAB 2022b和STM32G431RB搞定无感FOC,从电机参数识别到代码生成

从零构建无感FOC系统:MATLAB与STM32G431RB的深度实践指南 引言:为什么选择无感FOC技术? 在电机控制领域,磁场定向控制(FOC)因其高效率、低噪音和精准控制特性,已成为工业界和学术界的黄金标准。而无需位置传感器的无感…...

【OpenClaw从入门到精通】第37篇:教育“龙虾”进化论——从答疑助教到全流程智能教学系统(2026实测版)

摘要:2026年,教育AI已从被动答疑的L1级进化至主动教学的L4级,清华开源的OpenMAIC平台更是打破传统慕课局限,实现互动式AI课堂。本文基于天津工业大学、西北农林科技大学等高校的真实应用案例,结合腾讯云、天翼云的实操指南,详解OpenClaw在教育场景的四层进化路径。核心内…...

树形DP

前言 顾名思义树上的DP 树是一种数据结构 DP (动态规划) 是一种算法 接下来我将用洛谷上的 P2052 来向你讲解 P2052 P2052 [NOI2011] 道路修建 - 洛谷 题意:给一棵树,计算n-1条边,每条边两边节点相减的绝对值乘边权。 思路:用DFS…...

在 Debian 13 (Trixie) 上安装远程桌面 Xrdp 并配置 Xfce4

在 Debian 13 (Trixie) 上安装 Xrdp 并配置 Xfce4 桌面,可以让你通过 Windows 自带的远程桌面工具流畅访问 Linux 桌面。相比 VNC,RDP 协议在体验上更接近原生系统,而且无需在客户端安装额外软件。 下面是一个完整的操作流程,按顺序执行即可。 第一步:更新系统 在开始安…...

SmolVLA助力网络安全:智能分析日志与威胁情报

SmolVLA助力网络安全:智能分析日志与威胁情报 最近和几个做安全运维的朋友聊天,他们都在抱怨同一个问题:每天面对海量的系统日志、告警信息和五花八门的威胁情报报告,眼睛都快看花了,关键信息还总是被淹没在噪音里。一…...

合宙Air780EG开发板实战指南—06 基于LuatOS的串口UART高效数据收发与调试技巧

1. 串口通信基础与硬件准备 串口通信是嵌入式开发中最基础也最重要的功能之一。合宙Air780EG开发板内置了多个UART接口,其中MAIN_UART通常作为主通信接口。在实际项目中,我经常用它连接传感器、显示屏或其他外设。对于刚接触串口开发的朋友,可…...

SEO_掌握关键词研究的正确方法,驱动SEO流量增长

SEO流量增长的关键:掌握关键词研究的正确方法在当前竞争激烈的互联网市场中,掌握关键词研究的正确方法是推动SEO流量增长的核心。掌握关键词研究不仅能帮助你更好地了解用户需求,还能让你在搜索引擎中获得更高的排名。本文将从问题分析、原因…...

Java类间变量共享与进度更新的实现策略

本文旨在探讨如何在Java中安全有效地共享和更新不同操作类别之间的变量值,特别是在需要实时监控操作进度的场景中。我们将通过三种核心策略-观察者模式(推动模型)、轮询模式(拉模式)和基于多线程的共享状态管理——详细说明如何实现类间通信和…...

网络协议分析(CTF 入门博客)

一、什么是网络协议分析网络协议分析,就是对网络传输过程中捕获的流量数据包(通常是 .pcap 或 .pcapng 文件)进行查看、筛选、追踪和解码,从中找到关键信息。在 CTF 中,这类题目通常会给一个抓包文件,我们的…...

DM8数据库容灾避坑手册:从备份恢复到应急方案的全套操作实录(含PSEG_RECV参数详解)

DM8数据库容灾实战指南:关键文件恢复与PSEG_RECV参数深度解析 在数据库运维领域,容灾能力直接决定了业务系统的可靠性天花板。达梦DM8作为国产数据库的领军产品,其恢复机制设计既遵循经典数据库理论,又融入了独特的工程实现。本文…...

《Python程序设计与算法基础教程》P41部分练习题解答

以下解法参照书本P34中例2.25完成。P41-2.12-2题目:编写程序,输入直角三角形的两条直角边,利用勾股定理计算斜边的长度(结果保留两位小数)。编写代码:import math #导入math模块,用于开平方运算…...

基于 Spring AI Alibaba 搭建 Text-To-SQL 智能系统(简单实现)

上一篇我们完成了项目初始化、数据库搭建以及DDL生成工具类的开发,成功获取到了数据库中所有表的建表语句。本篇我们继续实现核心功能:将用户的自然语言需求转换为可执行的SQL语句并自动返回查询结果。 本文实现目标 ✅ 设计专业级Text2SQL提示词&…...

如何下载各平台上购买的网课?网课学习神器!学无止下载器让你的学习效率翻倍

🎓 网课学习神器!学无止下载器让你的学习效率翻倍 前言:你是否也遇到过这些烦恼?明明花钱买的网课,网络不好时却卡顿不断;想离线复习,却发现无法下载;珍贵课程怕到期,想永…...

EMI电路设计仿真

AriZh详细讲解了利兹线的设计参数,包括感量、电流值、开关频率等关键指标,​​强调设计状态为success的重要性,error则需回溯检查​​。他提到gap(气息)、最大工作磁密(367)等变压器相关参数&am…...

WPF Decorator:高效视觉修饰指南

理解 WPF 中的 Decorator Decorator 是 WPF 中一个抽象基类,属于 System.Windows.Controls 命名空间。它的核心作用是为子元素提供附加的视觉或布局修饰功能,例如边框、滚动条或缩放效果。Decorator 的子类通常通过单一的 Child 属性管理一个子元素&…...

Web自动化测试(01)- iFrame窗口切换

iFrame窗口切换 iframe是一种特殊的窗口,内嵌在页面之中,在前端静态HTML表示为一个标签,但是它又和新窗口一样,其中的元素无法被直接定位,需要进行切换 1. 切换至子窗口 1.1 通过ID、name切换(推荐&…...

JAVA-Mybaits

1. Mybaits简介 1.1 mybaits是什么 mybaits 是一个半 ORM (对象关系映射)框架,它内部封装了 JDBC,开发时只需要关注 SQL语句本身,不需要花费精力去处理加载驱动、创建连接、创建 statement等繁杂的过程。程序员直接编…...