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

网站制作自助seo专业培训费用

网站制作自助,seo专业培训费用,口碑好网站建设价格,阳江做网站的公司OpenCV 中提供了多种常用的特征提取算法,广泛应用于图像匹配、拼接、SLAM、物体识别等任务。以下是 OpenCV 中几个主流特征提取算法的 用法总结与代码示例,涵盖 C 和 Python 两个版本。常用特征提取算法列表算法特点是否需额外模块SIFT(尺度不…

OpenCV 中提供了多种常用的特征提取算法,广泛应用于图像匹配、拼接、SLAM、物体识别等任务。以下是 OpenCV 中几个主流特征提取算法的 用法总结与代码示例,涵盖 C++ 和 Python 两个版本。


常用特征提取算法列表

算法特点是否需额外模块
SIFT(尺度不变特征)稳定性强、可旋转缩放xfeatures2d 模块
SURF(加速稳健特征)快速但专利保护xfeatures2d 模块
ORB(Oriented FAST + BRIEF)免费、高速OpenCV 主模块
AKAZE适用于非线性尺度空间OpenCV 主模块
BRISK二进制描述子、适用于实时应用OpenCV 主模块

示例一:ORB 特征提取与匹配

Python 版:

import cv2# 加载图像
img1 = cv2.imread("image1.jpg", cv2.IMREAD_GRAYSCALE)
img2 = cv2.imread("image2.jpg", cv2.IMREAD_GRAYSCALE)# 创建 ORB 检测器
orb = cv2.ORB_create()# 检测关键点和计算描述子
kp1, des1 = orb.detectAndCompute(img1, None)
kp2, des2 = orb.detectAndCompute(img2, None)# 创建匹配器
bf = cv2.BFMatcher(cv2.NORM_HAMMING, crossCheck=True)
matches = bf.match(des1, des2)# 排序并绘制前 20 个匹配点
matches = sorted(matches, key=lambda x: x.distance)
matched_img = cv2.drawMatches(img1, kp1, img2, kp2, matches[:20], None, flags=2)cv2.imshow("ORB Matches", matched_img)
cv2.waitKey(0)
cv2.destroyAllWindows()

C++ 版:

#include <opencv2/opencv.hpp>
#include <opencv2/features2d.hpp>int main()
{cv::Mat img1 = cv::imread("image1.jpg", cv::IMREAD_GRAYSCALE);cv::Mat img2 = cv::imread("image2.jpg", cv::IMREAD_GRAYSCALE);cv::Ptr<cv::ORB> orb = cv::ORB::create();std::vector<cv::KeyPoint> kp1, kp2;cv::Mat des1, des2;orb->detectAndCompute(img1, cv::noArray(), kp1, des1);orb->detectAndCompute(img2, cv::noArray(), kp2, des2);cv::BFMatcher matcher(cv::NORM_HAMMING, true);std::vector<cv::DMatch> matches;matcher.match(des1, des2, matches);std::sort(matches.begin(), matches.end(),[](const cv::DMatch& m1, const cv::DMatch& m2) {return m1.distance < m2.distance;});cv::Mat img_matches;cv::drawMatches(img1, kp1, img2, kp2, matches, img_matches);cv::imshow("ORB Matches", img_matches);cv::waitKey(0);return 0;
}

示例二:SIFT 特征提取(需额外模块)

Python 版:

import cv2sift = cv2.SIFT_create()
img = cv2.imread("image.jpg", cv2.IMREAD_GRAYSCALE)
kp, des = sift.detectAndCompute(img, None)img_kp = cv2.drawKeypoints(img, kp, None, flags=cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)
cv2.imshow("SIFT Features", img_kp)
cv2.waitKey(0)

注意:SIFT 在 OpenCV 4.x 中已开放为免费使用,需 pip install opencv-contrib-python


C++ 版:

#include <opencv2/opencv.hpp>
#include <opencv2/xfeatures2d.hpp>int main()
{cv::Mat img = cv::imread("image.jpg", cv::IMREAD_GRAYSCALE);cv::Ptr<cv::SIFT> sift = cv::SIFT::create();std::vector<cv::KeyPoint> keypoints;cv::Mat descriptors;sift->detectAndCompute(img, cv::noArray(), keypoints, descriptors);cv::Mat output;cv::drawKeypoints(img, keypoints, output, cv::Scalar::all(-1), cv::DrawMatchesFlags::DRAW_RICH_KEYPOINTS);cv::imshow("SIFT", output);cv::waitKey(0);return 0;
}

示例三:AKAZE 特征提取

Python 版:

import cv2akaze = cv2.AKAZE_create()
img = cv2.imread("image.jpg", cv2.IMREAD_GRAYSCALE)
kp, des = akaze.detectAndCompute(img, None)img_kp = cv2.drawKeypoints(img, kp, None, color=(0,255,0))
cv2.imshow("AKAZE", img_kp)
cv2.waitKey(0)

C++ 版:

#include <opencv2/opencv.hpp>int main()
{cv::Mat img = cv::imread("image.jpg", cv::IMREAD_GRAYSCALE);cv::Ptr<cv::AKAZE> akaze = cv::AKAZE::create();std::vector<cv::KeyPoint> keypoints;cv::Mat descriptors;akaze->detectAndCompute(img, cv::noArray(), keypoints, descriptors);cv::Mat output;cv::drawKeypoints(img, keypoints, output);cv::imshow("AKAZE", output);cv::waitKey(0);return 0;
}

示例四:SURF 特征提取

小提示

SURF 属于专利算法(由 Hessian Matrix 加速构建特征),因此默认在 opencv-python不可用,需要使用 opencv-contrib 版本:

  • Python: pip install opencv-contrib-python
  • C++: 编译 OpenCV 时需启用 opencv_contrib,并启用 xfeatures2d 模块。

Python 示例

import cv2
import numpy as np# 读取图像
img = cv2.imread("image.jpg", cv2.IMREAD_GRAYSCALE)# 创建 SURF 对象(阈值越高,检测特征点越少)
surf = cv2.xfeatures2d.SURF_create(hessianThreshold=400)# 检测并计算特征点和描述子
keypoints, descriptors = surf.detectAndCompute(img, None)# 绘制关键点
img_kp = cv2.drawKeypoints(img, keypoints, None, (0,255,0), flags=cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)cv2.imshow("SURF Features", img_kp)
cv2.waitKey(0)
cv2.destroyAllWindows()

C++ 示例

#include <opencv2/opencv.hpp>
#include <opencv2/xfeatures2d.hpp>int main()
{cv::Mat img = cv::imread("image.jpg", cv::IMREAD_GRAYSCALE);if (img.empty()) {std::cerr << "Cannot load image!" << std::endl;return -1;}// 创建 SURF 检测器cv::Ptr<cv::xfeatures2d::SURF> surf = cv::xfeatures2d::SURF::create(400); // Hessian thresholdstd::vector<cv::KeyPoint> keypoints;cv::Mat descriptors;surf->detectAndCompute(img, cv::noArray(), keypoints, descriptors);cv::Mat output;cv::drawKeypoints(img, keypoints, output, cv::Scalar::all(-1), cv::DrawMatchesFlags::DRAW_RICH_KEYPOINTS);cv::imshow("SURF", output);cv::waitKey(0);return 0;
}

特征提取算法比较总结

算法是否开源描述子类型匹配类型特点
SIFT浮点(128维)L2(欧氏距离)稳定性好,适合图像拼接
SURF❌(专利)浮点L2快速但已过时
ORB二值(256位)Hamming(汉明)快速,适合实时系统
AKAZE二值或浮点Hamming/L2稳定性与速度兼顾
BRISK二值Hamming实时性强

小结

  • 推荐优先使用 ORBAKAZE(开源 + 高速);
  • 高精度图像处理可考虑 SIFT
  • 所有算法都可配合 BFMatcherFLANN 进行匹配;
  • 选择依据:速度要求匹配精度是否支持缩放旋转

http://www.dtcms.com/wzjs/181678.html

相关文章:

  • 贵港北京网站建设最火的推广软件
  • wordpress加动效漳州seo建站
  • 网站诚信认证怎么做免费推广平台哪些比较好
  • iframe网站后台模板免费域名注册官网
  • 上海网站建设网站制作开网店3个月来亏了10万
  • 网站开发哪家强苏州关键词排名提升
  • 安顺市建设局网站今日nba数据帝
  • java做后端的网站的搜索引擎优化
  • 网站用什么做关键词西安百度关键词包年
  • 邵阳做网站公司如何给公司做网络推广
  • 做网站一般按什么报价宁波网站建设公司哪家好
  • 网站源码采集steam交易链接怎么看
  • 网站设计规范站长工具查询域名
  • 商城网站前期seo应该怎么做重庆百度小额贷款有限公司
  • 南京电商网站建设公司排名国内新闻摘抄
  • 河源网站建设网络营销岗位描述的内容
  • 做网站制作大概多少钱青岛网站建设公司排名
  • 重庆网站建设培训机构指数函数
  • 网站建设有哪些需要注意的关键细节优秀品牌策划方案
  • wap网站报价我也要投放广告
  • 做网站 360的好不好北京网站托管
  • 峰峰企业做网站推广网络营销出来可以干什么工作
  • 来个靠谱网站2021什么是seo优化?
  • 无锡网站优化排名推广免费seo提交工具
  • 牙科网站模板外贸网站建设公司哪家好
  • 做业务在那几个网站上找客户端网站百度收录秒收方法
  • 为澳门赌场做网站维护域名怎么注册
  • 礼品网站建设深圳关键词排名seo
  • 网站建设与动态网页设计aso优化推广公司
  • 泰安网络公司行情重庆网站seo多少钱