OpenCV-Python(35):BRIEF算法

算法介绍

        BRIEF(Binary Robust Independent Elementary Features)是一种用于计算机视觉中特征点描述子的算法。它是一种二进制描述子,通过比较图像上不同位置的像素值来生成特征点的描述子。

        BRIEF算法的基本思想是选取一组固定的像素对,并比较这些像素对之间的亮度差异。对于每一个像素对,如果第一个像素的亮度大于第二个像素的亮度,则将该像素对的比较结果设为1,否则设为0。将所有像素对的比较结果串联起来,就得到了该特征点的二进制描述子。

        BRIEF算法的优点是计算速度快、内存消耗小,适用于实时应用和资源受限的设备。然而,由于BRIEF算法只比较像素的亮度差异,而没有考虑像素的空间关系,因此对于图像的旋转、尺度变化等变换不具有鲁棒性

        实际应用中,为了提高BRIEF算法的鲁棒性,通常会结合其他方法来使用,比如使用FAST算法或Harris角点检测等方法来检测特征点,然后再使用BRIEF算法生成特征点的描述子。

背景说明

        我们知道,SIFT 算法使用的是128 维的描述符。由于它是使用的浮点数,所以需要使用512 个字节。同样SURF 算法最少使用256 个字节,因为至少是64 为维描述符。创建一个包含上千个特征的向量需要消耗大量的内存,在嵌入式等资源有限的设备上这样是不合适的,因为匹配时也会消耗更多的内存和时间。

        实际的匹配过程中,如此多的维度是没有必要的。我们可以使用PCA,LDA 等方法来进行降维。甚至可以使用LSH(局部敏感哈希)将SIFT 浮点数的描述符转换成二进制字符串。对这些字符串再使用汉明距离进行匹配。汉明距离的计算只需要 XOR 位运算以及位计数,这种计算算很适合在现代的CPU 上运行。但我们还是需要先找到描述符才能使用哈希,这不能解决最初的内存消耗问题。

        BRIEF 算法应运而生。它不去计算描述符而是直接找到一个二进制字符串。这种算法使用的是已经平滑后的图像,它会按照一种特定的方式选取一组像素点对nd (x,y),然后在这些像素点对之间进行灰度值对比。例如,第一个点对的灰度值分别为p 和q。如果p 小于q,结果就是1,否则就是0。就这样对nd个点对进行对比得到一个nd 维的二进制字符串。

        nd 可以是128,256,512。OpenCV 对这些都提供了支持,但在默认情况下是256(OpenC 是使用字节表示它们的,所以􄦈这些值分别对应与16、32、64)。当我们获得这些二进制字符串之后就可以使用汉明距离对它们匹配了。

        非常重要的一点是:BRIEF 是一种特征描述符,它不提供查找特征的方法。所以我们不得不使用其他特征检测器,比如SIFT 和SURF 等。原始文献推荐使用CenSurE 特征检测器,这种算法很快。而且BRIEF 算法对CenSurE关键点的描述效果比SURF 关键点的描述更好。

        简单来说, BRIEF 是一种对特征点描述符计算和匹配的快速方法。这种算法可以实现很高的识别率,除非出现平面内的大旋转。

OpenCV 中的BRIEF

        下面的代码使用了CenSurE 特征检测器和BRIEF 描述符。在OpenCV中CenSurE 检测器被叫做STAR 检测器。

import numpy as np
import cv2
from matplotlib import pyplot as plt

img = cv2.imread('simple.jpg',0)

# Initiate STAR detector
star = cv2.FeatureDetector_create("STAR")

# Initiate BRIEF extractor
brief = cv2.DescriptorExtractor_create("BRIEF")

# find the keypoints with STAR
kp = star.detect(img,None)

# compute the descriptors with BRIEF
kp, des = brief.compute(img, kp)

print (brief.getInt('bytes'))
print (des.shape)

        函数brief.getInt(′bytes′) 会以字节格式给出nd 的大小,默认值为32。 

如果opencv版本不同,可能会报错,可以尝试以下代码:

在Python的OpenCV中,可以使用cv2.xfeatures2d.BriefDescriptorExtractor_create()函数来创建BRIEF算法的特征点描述子生成器。

以下是一个简单的示例代码,展示了如何在Python的OpenCV中使用BRIEF算法生成特征点的描述子:

import cv2

# 读取图像
image = cv2.imread('image.jpg', cv2.IMREAD_GRAYSCALE)

# 创建BRIEF算法的特征点检测器和描述子生成器
detector = cv2.FastFeatureDetector_create()
descriptor = cv2.xfeatures2d.BriefDescriptorExtractor_create()

# 检测图像中的特征点
keypoints = detector.detect(image, None)

# 计算特征点的描述子
_, descriptors = descriptor.compute(image, keypoints)

# 打印特征点数目和描述子的维度
print('Number of keypoints:', len(keypoints))
print('Descriptor size:', descriptors.shape[1])

在这个示例中,首先使用cv2.imread()函数读取了一幅灰度图像。然后,使用cv2.FastFeatureDetector_create()函数创建了一个FAST算法的特征点检测器,并使用cv2.xfeatures2d.BriefDescriptorExtractor_create()函数创建了一个BRIEF算法的特征点描述子生成器。接下来,使用特征点检测器检测图像中的特征点,并使用描述子生成器计算特征点的描述子。最后,使用len()函数获取特征点的数目,使用shape[1]获取描述子的维度,并打印出来。

需要注意的是,需要安装OpenCV的Python模块和对应的xfeatures2d模块。可以使用以下命令来安装:

pip install opencv-python
pip install opencv-contrib-python

以上代码仅仅是一个简单的示例,实际应用中可能需要根据具体情况进行参数调整和错误处理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/323290.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

[VGG团队论文阅读]Free3D: Consistent Novel View Synthesis without 3D Representation

Vedaldi, C. Z. A. (n.d.). Free3D: Consistent Novel View Synthesis without 3D Representation. Chuanxiaz.com. https://chuanxiaz.com/free3d/static/videos/Free3D.pdf Free3D: 无需3D表示的一致新视角合成 Visual Geometry Group, University of Oxford 摘要 我们介绍…

Radzen Blazor Studio 脚手架框架解读

背景 组织管理管理准备使用Blazor这个工具实现,因为其有对应的 scaffold 脚手架,先构建数据库,然后通过向导,生成CRUD以及对应的接口,那么有必要看一下,其内部的代码结构是什么样的。 结构 接口层 有两类…

MIT 6s081 blog1.xv6内存管理

xv6内存管理部分 xv6内存布局 内核地址空间 如xv6指导书中图3.3:从0x80000000开始的地址为内核地址空间,CLINT、PLIC、uart0、virtio disk等为I/O设备(内存映射I/O),可以看到xv6虚拟地址到物理地址的映射&#xff0…

YOLOv8目标检测中数据集各部分的作用

自学答疑使用,持续更新… 在目标检测任务中,通常将整个数据集划分为训练集(training set)、验证集(validation set)和测试集(test set)。这三个数据集在训练和评估过程中具有不同的…

水经注语义化版本控制规范1.2.0版

为了更好的对产品进行版本管理,我们曾基于业界的一些权威参考资料,梳理过两版水经注产品的版本控制规范。 但随着多个平台的产品研发,以及产品在各平台的更新发布,再结合我们的实际情况,现在对版本控制规范进行一次升…

手把手教你使用Django如何连接Mysql

目录 一、引言 二、准备工作 三、配置Django连接MySQL 1、安装MySQL驱动: 2、配置数据库设置: 3、 创建数据库迁移: 四、编写Django模型和视图函数 1、编写模型: 2. 编写视图函数: 3. 编写模板: …

帆软笔记-决策表报对象使用(两表格联动)

效果描述如下: 数据库中有个聚合商表,和一个储能表,储能属于聚合商,桩表中有个字段是所属聚合商。 要求帆软有2个表格,点击某个聚合商,展示指定的储能数据。 操作: 帆软选中表格单元&#xf…

【揭秘】武汉建筑安全员ABC证报考内幕,社保问题竟成硬伤!

【揭秘】武汉建筑安全员ABC证报考内幕,社保问题竟成硬伤! 没有武汉社保可以报考建筑安全员C3证建安C证吗? 武汉市三类人员安全员ABC报考,要求建筑公司给专职安全、项目经理、技术负责人等这些人员缴纳社保才可以报考建筑安全员A…

通信电缆的UL认证安全标准UL 444详情介绍

在介绍相关标准之前先介绍一下UL认证和UL测试报告的区别 UL认证是自愿性的认证,需要检测产品和审核工厂,每个季度审核一次,费用高、时间久,而且审厂非常的严格。 UL测试报告是根据产品选用相应的UL标准进行测试合格后&#xff0…

Unity对应SDK和NDK版本的对照表

官网:Unity - Manual: Android environment setup 本人安装的是2022版本长期支持版本2022.3.15f1c1 安装Java的JDK环境就不在这里展开了,就记录下对Android SDK的设置,要与Unity的版本对应,否则会出现很多莫名奇妙的问题。 打开…

【HarmonyOS4.0】第十一篇-ArkUI布局容器组件(三)

五、格栅布局容器 GridContainer纵向排布栅格布局容器,仅在栅格布局场景中使用。该组件不再维护,推荐使用新组件GridCol、GridRow。 5.1.栅格容器GridRow 栅格容器组件,仅可以和栅格子组件(GridCol)在栅格布局场景中使用。 5.1.1.接口 G…

污水泵站为何会导致污染事件发生及如何预防?

污水泵站是废水处理系统中至关重要的组成部分,但它们的故障可能导致严重的污染事件。本文将深入探讨污水泵站导致污染的原因,并介绍先进的预防性技术,如PreMaint,来有效应对这些问题。 一、污水泵站的污染事件发生原因 1. 不适当…

2023转转技术年货发布啦

在这个信息爆炸的时代,技术的进步变得前所未有的快速和多样化,技术已然成为驱动社会进步的重要动力之一。作为技术从业者或者对技术感兴趣的读者,我们需要不断学习和掌握最新的技术趋势和解决方案,以应对不断变化的挑战。技术年货…

赴美生子月子机构要怎么选?

首先,了解月子机构的背景和信誉度非常重要。查看机构是否合法注册,是否有任何不良记录或投诉。通过与机构的交流和与其他妈妈.的口碑推.荐,了解机构的信誉和口碑。 要选择正规的赴美生子机构。这个很重要哦!正规的机构要有合法的执照&#x…

机器学习在什么场景下最常用-九五小庞

机器学习在多个场景中都有广泛的应用,下面是一些常见的应用场景: 自然语言处理(NLP):如语音识别、自动翻译、情感分析、垃圾邮件过滤等。数据挖掘和分析:如市场分析、用户画像、推荐系统、欺诈检测等。智能…

高级分布式系统-第15讲 分布式机器学习--分布式机器学习算法

分布式机器学习算法 按照通信步调,大致可以分为同步算法和异步算法两大类。 同步算法下,通信过程中有一个显式的全局同步状态,称之为同步屏障。当工作节点运行到同步屏障 ,就会进入等待状态,直到其工作节点均运行到同…

4.2 MATRIX MULTIPLICATION

矩阵-矩阵乘法,或简称矩阵乘法,在 i X j(i 行 by j 列)矩阵 M 和 j x k 矩阵 N 之间产生 i X k 矩阵P。矩阵乘法是基本线性代数子程序(BLAS)标准的重要组成部分(见第3章中的“线性代数函数”边栏…

原生IP代理如何帮助跨境电商店铺做谷歌广告投放业务的?

随着全球化的发展,越来越多的电商店铺开始拓展跨境业务,而谷歌广告作为全球最大的广告平台之一,为跨境电商店铺带来了巨大的收益和商机。 然而,由于谷歌广告的地域限制和审查机制,店铺很难直接进行投放业务&#xff0…

Photovoltaic cell storage element IC---AEM13920

0 Preface/Foreword 0.1 Functional Block Diagram(功能框图) 1 register introduction

【极光系列】SpringBoot集成Mybatis

【极光系列】SpringBoot集成Mybatis 一.gitee地址 浅夏的猫 shawsongyue 直接下载可用 https://gitee.com/shawsongyue/aurora.git 二.mysql安装教程 详细参考我的另外一遍博客: https://blog.csdn.net/weixin_40736233/article/details/135582926?spm1001.201…