Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
qq_38597003
opencv_contrib
提交
33ed4c3b
O
opencv_contrib
项目概览
qq_38597003
/
opencv_contrib
与 Fork 源项目一致
Fork自
OpenCV / opencv_contrib
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
opencv_contrib
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
33ed4c3b
编写于
1月 25, 2021
作者:
A
Alexander Alekhin
浏览文件
操作
浏览文件
下载
差异文件
Merge moved code from opencv/3.4
上级
0b8aecd9
3778fa37
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
4 addition
and
4 deletion
+4
-4
modules/cudalegacy/src/calib3d.cpp
modules/cudalegacy/src/calib3d.cpp
+1
-1
modules/cudalegacy/test/test_calib3d.cpp
modules/cudalegacy/test/test_calib3d.cpp
+3
-3
未找到文件。
modules/cudalegacy/src/calib3d.cpp
浏览文件 @
33ed4c3b
...
...
@@ -283,7 +283,7 @@ void cv::cuda::solvePnPRansac(const Mat& object, const Mat& image, const Mat& ca
p_transf
.
z
=
rot
[
6
]
*
p
.
x
+
rot
[
7
]
*
p
.
y
+
rot
[
8
]
*
p
.
z
+
transl
[
2
];
p_proj
.
x
=
p_transf
.
x
/
p_transf
.
z
;
p_proj
.
y
=
p_transf
.
y
/
p_transf
.
z
;
if
(
norm
(
p_proj
-
image_normalized
.
at
<
Point2f
>
(
0
,
i
))
<
max_dist
)
if
(
norm
(
p_proj
-
image_normalized
.
at
<
Point2f
>
(
i
))
<
max_dist
)
inliers
->
push_back
(
i
);
}
}
...
...
modules/cudalegacy/test/test_calib3d.cpp
浏览文件 @
33ed4c3b
...
...
@@ -163,7 +163,7 @@ struct SolvePnPRansac : testing::TestWithParam<cv::cuda::DeviceInfo>
CUDA_TEST_P
(
SolvePnPRansac
,
Accuracy
)
{
cv
::
Mat
object
=
randomMat
(
cv
::
Size
(
5000
,
1
),
CV_32FC3
,
0
,
1
00
);
cv
::
Mat
object
=
randomMat
(
cv
::
Size
(
5000
,
1
),
CV_32FC3
,
-
2000
,
20
00
);
cv
::
Mat
camera_mat
=
randomMat
(
cv
::
Size
(
3
,
3
),
CV_32F
,
0.5
,
1
);
camera_mat
.
at
<
float
>
(
0
,
1
)
=
0.
f
;
camera_mat
.
at
<
float
>
(
1
,
0
)
=
0.
f
;
...
...
@@ -174,7 +174,7 @@ CUDA_TEST_P(SolvePnPRansac, Accuracy)
cv
::
Mat
rvec_gold
;
cv
::
Mat
tvec_gold
;
rvec_gold
=
randomMat
(
cv
::
Size
(
3
,
1
),
CV_32F
,
0
,
1
);
tvec_gold
=
randomMat
(
cv
::
Size
(
3
,
1
),
CV_32F
,
0
,
1
);
tvec_gold
=
randomMat
(
cv
::
Size
(
3
,
1
),
CV_32F
,
0
,
1
000
);
cv
::
projectPoints
(
object
,
rvec_gold
,
tvec_gold
,
camera_mat
,
cv
::
Mat
(
1
,
8
,
CV_32F
,
cv
::
Scalar
::
all
(
0
)),
image_vec
);
cv
::
Mat
rvec
,
tvec
;
...
...
@@ -184,7 +184,7 @@ CUDA_TEST_P(SolvePnPRansac, Accuracy)
rvec
,
tvec
,
false
,
200
,
2.
f
,
100
,
&
inliers
);
ASSERT_LE
(
cv
::
norm
(
rvec
-
rvec_gold
),
1e-3
);
ASSERT_LE
(
cv
::
norm
(
tvec
-
tvec_gold
),
1e-3
);
ASSERT_LE
(
cv
::
norm
(
tvec
,
tvec_gold
,
NORM_L2
|
NORM_RELATIVE
),
1e-3
);
}
INSTANTIATE_TEST_CASE_P
(
CUDA_Calib3D
,
SolvePnPRansac
,
ALL_DEVICES
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录