- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想用 scikit-learn 训练我的 svm 分类器进行图像分类。
而我想使用opencv-python的SIFT算法函数来提取图像特征,情况如下:
1. scikit-learn的svm分类器输入的是一个二维数组,即每一行代表一张图片,每张图片的特征量是一样的; here
2. opencv-python 的 SIFT 算法返回一个关键点列表,它是一个形状为 的 numpy 数组. here
所以我的问题是:
我如何处理 SIFT 特征以适应 SVM 分类器的输入?你能帮助我吗 ?
更新1:
感谢 pyan 的建议,我调整了我的建议如下:
1.从每张图片中获取SIFT特征向量
2.对所有向量执行k-means聚类
3.基于聚类中心创建特征字典,又名cookbook
4.根据特征字典重新表示每张图片,当然每张图片的维度量是一样的
5. 训练我的 SVM 分类器并对其进行评估
更新2:
我已将所有图像 SIFT 特征向量收集到一个数组(x * 128)中,该数组非常大,然后我需要对其进行聚类。
问题是:
如果我使用 k-means ,必须设置参数簇数,我不知道如何设置最佳值;如果我不使用 k-means,哪种算法可能适合这个?note:I want to use scikit-learn to perform clustering
我的建议是:
1.对向量执行dbscan聚类,然后我可以得到label_size和labels;
2.由于scikit-learn中的dbscan不能用于预测,我可以根据dbscan的结果训练一个新的分类器A;
3. 分类器 A 就像一本食谱,我可以标记每个图像的 SIFT 向量。之后,每个图像都可以重新表示;
4.基于上述工作,我可以训练我的最终分类器B。note:for predict a new image, its SIFT vectors must be transform by classifier A into the vector as classifier B's input
你能给我一些建议吗?
最佳答案
图像分类可以很笼统。为了定义好的特征,首先你需要明确你想要什么样的输出。例如,图像可以根据其中的场景分为自然景观、城市景观、室内景观等。不同种类的分类可能需要不同种类的特征。
计算机视觉中用于基于关键字的图像分类的常用方法是词袋(特征装袋)或字典学习。您可以进行文献搜索以熟悉该主题。在您的情况下,基本思想是将 SIFT 特征分组到不同的集群中。而不是直接喂scikit-learn
使用SIFT特征,给出特征组频率的向量作为输入。所以每个图像都将由一个一维向量表示。
来自维基百科的简短介绍 Bag-of-words model in computer vision
关于image - 如何使用 SIFT 和 SVM 实现通用图像分类器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30532088/
我想找到一种方法,允许将图像(查询)的 SIFT 描述符与包含大量不同图片描述符的 SQL 数据库中的描述符进行比较。 事实上,我的最终目的是做一个应用程序,允许将一张图片与数据库(不是在我的设备中)
我正在使用 OpenCV 实现词袋图像分类器。最初我测试了在 SURF 关键点中提取的 SURF 描述符。我听说 Dense SIFT(或 PHOW)描述符更适合我的目的,所以我也尝试了它们。 令我惊
我尝试使用 David Lowe's implementation 对几个不同的对象进行对象检测和 OpenCV implementation (只是在此代码中更改了 'SurfFeatureDete
我正在尝试为我的项目实现 SIFT,我已经掌握了关键点。我尝试使用同一图像的所有关键点获取图像的每个关键点的欧氏距离,但按比例缩小。碰巧查询图像的 1 个关键点与数据库图像中其余关键点的距离具有非常相
我想通过旋转它们来标准化筛选描述符,以便水平方向与补丁的主要梯度方向对齐。 我正在使用 vl_feat 库。 vl_feat 中是否有任何方法可以规范筛选描述? 或 使用 matlab 执行此操作的有
我想使用基于FLANN的Matcher打印检测功能关键点 算法:http://docs.opencv.org/trunk/dc/dc3/tutorial_py_matcher.html。 搜索效果很好
SIFT 是做什么的?它是否建立了 View 之间的特征对应关系?它是否接收图像的角并删除那些没有描述性的角?它会进行匹配吗? 最佳答案 SIFT 是“尺度不变特征变换”的捷径。SIFT 特征通常用于
我正在尝试实现 SIFT,目前我只是想了解它是如何工作的,然后再开始在 MATLAB 中实现它,我了解其中的大部分内容,除了如何使用泰勒展开计算亚像素精度: 以上是原始论文中的方程式。我有几个关于它如
我在 matlab 中使用 SIFT 算法来确定模板图像和一组图像之间的相似性,最后我必须根据 SCORES 确定一组图像之间的最佳匹配,这样说对吗图像的分数越高匹配越好?我知道当存在完全匹配时,分数
我是 Opencv2.3 的入门级程序员,玩弄互联网上可用的代码和各种有用的资源。有 Stack User 实现的代码 User:Froyo在他的网站上 website .当我尝试执行代码时,只要我在
我在执行我的代码时遇到以下错误:(带有 Qt Creator 的 OpenCV) OpenCV Error: Assertion failed (!outImage.empty()) in drawK
我正在使用 OpenCV-Python。 我已经使用 cv2.cornerHarris 识别角点。输出类型为 dst。 我需要计算角点的 SIFT 特征。 sift.compute() 的输入必须是
我读过一些关于 SIFT 的文献,也看过一些视频。我了解 SIFT 背后的大部分概念,但让我感到困惑的是关于 SIFT 描述符的一件事。 在筛选中: 我们找到了一个关键点 我们在关键点周围取 16 x
有 2 张图像 A 和 B。我从中提取关键点(a[i] 和 b[i])。 我想知道如何有效地确定 a[i] 和 b[j] 之间的匹配? 我想到的最明显的方法是将 A 中的每个点与 B 中的每个点进行比
我正在开发一个应用程序,我在其中使用 SIFT + RANSAC 和 Homography 来查找对象(OpenCV C++、Java)。我面临的问题是,在有很多异常值的地方,RANSAC 表现不佳。
我正在开展一个项目,我将使用单应性作为分类器中的特征。我的问题是自动计算单应性,我使用 SIFT 描述符来找到两个图像之间的点来计算单应性,但是 SIFT 给我的结果很差,因此我不能在我的工作中使用它
我想知道,如果我可以更改 SIFT 描述符维度,如果可以,我该怎么做。我知道目前尺寸是 128,我们可以做成 128*4 或 124/4 这样的尺寸吗? 更新:我试图将 SIFT_DESCR_WIDT
我在树莓派 3b 上使用 opencv 4.5.0-pre 和 python 3.7.3。我正在尝试使用 SIFT 为图像拼接找到最匹配的特征。我使用本指南从源代码构建了 opencv https:/
我目前在 工作SIFT ,我已经生成了高斯和极值图像层的差异。谁能向我解释如何使用 Hessian 矩阵来消除低对比度关键点? 最佳答案 一个好的关键点是一个角落。这首先来自 Harris 角工作和
我在 OpenCV 4.5.2 中使用 SIFT 特征检测器.通过调整 nOctaveLayers cv::SIFT::create() 中的参数, 我从 detectAndCompute() 得到这
我是一名优秀的程序员,十分优秀!