实现 "RAPID - 视频速率物体跟踪器" [116], 并结合 [73] 中的动态控制点提取。
|
void | cv::rapid::convertCorrespondencies (InputArray cols, InputArray srcLocations, OutputArray pts2d, InputOutputArray pts3d=noArray(), InputArray mask=noArray()) |
|
void | cv::rapid::drawCorrespondencies (InputOutputArray bundle, InputArray cols, InputArray colors=noArray()) |
|
void | cv::rapid::drawSearchLines (InputOutputArray img, InputArray locations, const Scalar &color) |
|
void | cv::rapid::drawWireframe (InputOutputArray img, InputArray pts2d, InputArray tris, const Scalar &color, int type=LINE_8, bool cullBackface=false) |
|
void | cv::rapid::extractControlPoints (int num, int len, InputArray pts3d, InputArray rvec, InputArray tvec, InputArray K, const Size &imsize, InputArray tris, OutputArray ctl2d, OutputArray ctl3d) |
|
void | cv::rapid::extractLineBundle (int len, InputArray ctl2d, InputArray img, OutputArray bundle, OutputArray srcLocations) |
|
void | cv::rapid::findCorrespondencies (InputArray bundle, OutputArray cols, OutputArray response=noArray()) |
|
float | cv::rapid::rapid (InputArray img, int num, int len, InputArray pts3d, InputArray tris, InputArray K, InputOutputArray rvec, InputOutputArray tvec, double *rmsd=0) |
|
◆ convertCorrespondencies()
Python |
---|
| cv.rapid.convertCorrespondencies( | cols, srcLocations[, pts2d[, pts3d[, mask]]] | ) -> | pts2d, pts3d |
#include <opencv2/rapid.hpp>
根据对应关系和掩码收集相应的 2D 和 3D 点
- 参数
-
cols | 对应关系 - 线束空间中每条线的坐标 |
srcLocations | 源图像位置 |
pts2d | 2D 点 |
pts3d | 3D 点 |
mask | 掩码,包含要保留的元素的非零值 |
◆ drawCorrespondencies()
Python |
---|
| cv.rapid.drawCorrespondencies( | bundle, cols[, colors] | ) -> | bundle |
#include <opencv2/rapid.hpp>
在 lineBundle 上调试绘制匹配对应关系的标记
- 参数
-
bundle | lineBundle |
cols | lineBundle 中的列坐标 |
colors | 标记的颜色。默认为白色。 |
◆ drawSearchLines()
Python |
---|
| cv.rapid.drawSearchLines( | img, locations, color | ) -> | img |
◆ drawWireframe()
Python |
---|
| cv.rapid.drawWireframe( | img, pts2d, tris, color[, type[, cullBackface]] | ) -> | img |
◆ extractControlPoints()
Python |
---|
| cv.rapid.extractControlPoints( | num, len, pts3d, rvec, tvec, K, imsize, tris[, ctl2d[, ctl3d]] | ) -> | ctl2d, ctl3d |
#include <opencv2/rapid.hpp>
从网格投影轮廓中提取控制点
参见 [73] 第 2.1 节,步骤 b
- 参数
-
num | 控制点的数量 |
len | 搜索半径(用于限制 ROI) |
pts3d | 网格的 3D 点 |
rvec | 网格和相机之间的旋转 |
tvec | 网格和相机之间的平移 |
K | 相机内参 |
imsize | 视频帧的大小 |
tris | 三角形面的连接性 |
ctl2d | 控制点的 2D 位置 |
ctl3d | 网格的匹配 3D 点 |
◆ extractLineBundle()
Python |
---|
| cv.rapid.extractLineBundle( | len, ctl2d, img[, bundle[, srcLocations]] | ) -> | bundle, srcLocations |
#include <opencv2/rapid.hpp>
从图像中提取线束
- 参数
-
len | 搜索半径。线束将有 2*len + 1 列。 |
ctl2d | 搜索线将以这些点为中心,并且垂直于由它们定义的轮廓。线束将有这么多行。 |
img | 从其读取像素强度值的图像 |
bundle | 大小为 ctl2d.rows() x (2 * len + 1) 且与 img 类型相同的线束图像 |
srcLocations | bundle 在 img 中的源像素位置,为 CV_16SC2 |
◆ findCorrespondencies()
Python |
---|
| cv.rapid.findCorrespondencies( | bundle[, cols[, response]] | ) -> | cols, response |
#include <opencv2/rapid.hpp>
通过沿着搜索线(线束中的一行)搜索最大的 sobel 边缘来查找相应的图像位置
- 参数
-
bundle | 线束 |
cols | 对应关系 - 线束空间中每条线的坐标 |
response | 所选点的 sobel 响应 |
◆ rapid()
Python |
---|
| cv.rapid.rapid( | img, num, len, pts3d, tris, K, rvec, tvec | ) -> | retval, rvec, tvec, rmsd |