Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv_contrib
Commits
ab2e8324
Commit
ab2e8324
authored
Jan 10, 2019
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'upstream/3.4' into merge-3.4
parents
1c9e2374
bca1ff20
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
44 additions
and
40 deletions
+44
-40
charucoboard.jpg
...aruco/tutorials/charuco_detection/images/charucoboard.jpg
+0
-0
CMakeLists.txt
modules/ovis/CMakeLists.txt
+4
-0
ovis.cpp
modules/ovis/src/ovis.cpp
+1
-1
trajectory_reconstruction.cpp
modules/sfm/samples/trajectory_reconstruction.cpp
+0
-0
projection.cpp
modules/sfm/src/projection.cpp
+37
-37
sfm_trajectory_estimation.markdown
..._trajectory_estimation/sfm_trajectory_estimation.markdown
+1
-1
CMakeLists.txt
modules/text/CMakeLists.txt
+1
-1
No files found.
modules/aruco/tutorials/charuco_detection/images/board.jpg
→
modules/aruco/tutorials/charuco_detection/images/
charuco
board.jpg
View file @
ab2e8324
File moved
modules/ovis/CMakeLists.txt
View file @
ab2e8324
...
@@ -16,6 +16,10 @@ elseif(OGRE_VERSION VERSION_GREATER 1.10) # we need C++11 for OGRE 1.11
...
@@ -16,6 +16,10 @@ elseif(OGRE_VERSION VERSION_GREATER 1.10) # we need C++11 for OGRE 1.11
endif
()
endif
()
endif
()
endif
()
if
(
OGRE_VERSION VERSION_LESS 1.10.10
)
message
(
WARNING
"opencv_ovis: Ogre >= 1.10.10 recommended for interactive windows"
)
endif
()
include_directories
(
${
OGRE_INCLUDE_DIRS
}
)
include_directories
(
${
OGRE_INCLUDE_DIRS
}
)
link_directories
(
${
OGRE_LIBRARY_DIRS
}
)
link_directories
(
${
OGRE_LIBRARY_DIRS
}
)
...
...
modules/ovis/src/ovis.cpp
View file @
ab2e8324
...
@@ -181,7 +181,7 @@ struct Application : public OgreBites::ApplicationContext, public OgreBites::Inp
...
@@ -181,7 +181,7 @@ struct Application : public OgreBites::ApplicationContext, public OgreBites::Inp
int
flags
;
int
flags
;
Application
(
const
Ogre
::
String
&
_title
,
const
Size
&
sz
,
int
_flags
)
Application
(
const
Ogre
::
String
&
_title
,
const
Size
&
sz
,
int
_flags
)
:
OgreBites
::
ApplicationContext
(
"ovis"
,
false
),
sceneMgr
(
NULL
),
title
(
_title
),
w
(
sz
.
width
),
:
OgreBites
::
ApplicationContext
(
"ovis"
),
sceneMgr
(
NULL
),
title
(
_title
),
w
(
sz
.
width
),
h
(
sz
.
height
),
key_pressed
(
-
1
),
flags
(
_flags
)
h
(
sz
.
height
),
key_pressed
(
-
1
),
flags
(
_flags
)
{
{
if
(
utils
::
getConfigurationParameterBool
(
"OPENCV_OVIS_VERBOSE_LOG"
,
false
))
if
(
utils
::
getConfigurationParameterBool
(
"OPENCV_OVIS_VERBOSE_LOG"
,
false
))
...
...
modules/sfm/samples/trajectory_reconstruc
c
ion.cpp
→
modules/sfm/samples/trajectory_reconstruc
t
ion.cpp
View file @
ab2e8324
File moved
modules/sfm/src/projection.cpp
View file @
ab2e8324
...
@@ -55,34 +55,34 @@ namespace sfm
...
@@ -55,34 +55,34 @@ namespace sfm
template
<
typename
T
>
template
<
typename
T
>
void
void
homogeneousToEuclidean
(
const
Mat
&
_X
,
Mat
&
_x
)
homogeneousToEuclidean
(
const
Mat
&
X_
,
Mat
&
x_
)
{
{
int
d
=
_X
.
rows
-
1
;
int
d
=
X_
.
rows
-
1
;
const
Mat_
<
T
>
&
X_rows
=
_X
.
rowRange
(
0
,
d
);
const
Mat_
<
T
>
&
X_rows
=
X_
.
rowRange
(
0
,
d
);
const
Mat_
<
T
>
h
=
_X
.
row
(
d
);
const
Mat_
<
T
>
h
=
X_
.
row
(
d
);
const
T
*
h_ptr
=
h
[
0
],
*
h_ptr_end
=
h_ptr
+
h
.
cols
;
const
T
*
h_ptr
=
h
[
0
],
*
h_ptr_end
=
h_ptr
+
h
.
cols
;
const
T
*
X_ptr
=
X_rows
[
0
];
const
T
*
X_ptr
=
X_rows
[
0
];
T
*
x_ptr
=
_x
.
ptr
<
T
>
(
0
);
T
*
x_ptr
=
x_
.
ptr
<
T
>
(
0
);
for
(;
h_ptr
!=
h_ptr_end
;
++
h_ptr
,
++
X_ptr
,
++
x_ptr
)
for
(;
h_ptr
!=
h_ptr_end
;
++
h_ptr
,
++
X_ptr
,
++
x_ptr
)
{
{
const
T
*
X_col_ptr
=
X_ptr
;
const
T
*
X_col_ptr
=
X_ptr
;
T
*
x_col_ptr
=
x_ptr
,
*
x_col_ptr_end
=
x_col_ptr
+
d
*
_x
.
step1
();
T
*
x_col_ptr
=
x_ptr
,
*
x_col_ptr_end
=
x_col_ptr
+
d
*
x_
.
step1
();
for
(;
x_col_ptr
!=
x_col_ptr_end
;
X_col_ptr
+=
X_rows
.
step1
(),
x_col_ptr
+=
_x
.
step1
()
)
for
(;
x_col_ptr
!=
x_col_ptr_end
;
X_col_ptr
+=
X_rows
.
step1
(),
x_col_ptr
+=
x_
.
step1
()
)
*
x_col_ptr
=
(
*
X_col_ptr
)
/
(
*
h_ptr
);
*
x_col_ptr
=
(
*
X_col_ptr
)
/
(
*
h_ptr
);
}
}
}
}
void
void
homogeneousToEuclidean
(
InputArray
_X
,
OutputArray
_x
)
homogeneousToEuclidean
(
InputArray
X_
,
OutputArray
x_
)
{
{
// src
// src
const
Mat
X
=
_X
.
getMat
();
const
Mat
X
=
X_
.
getMat
();
// dst
// dst
_x
.
create
(
X
.
rows
-
1
,
X
.
cols
,
X
.
type
());
x_
.
create
(
X
.
rows
-
1
,
X
.
cols
,
X
.
type
());
Mat
x
=
_x
.
getMat
();
Mat
x
=
x_
.
getMat
();
// type
// type
if
(
X
.
depth
()
==
CV_32F
)
if
(
X
.
depth
()
==
CV_32F
)
...
@@ -96,11 +96,11 @@ homogeneousToEuclidean(InputArray _X, OutputArray _x)
...
@@ -96,11 +96,11 @@ homogeneousToEuclidean(InputArray _X, OutputArray _x)
}
}
void
void
euclideanToHomogeneous
(
InputArray
_x
,
OutputArray
_X
)
euclideanToHomogeneous
(
InputArray
x_
,
OutputArray
X_
)
{
{
const
Mat
x
=
_x
.
getMat
();
const
Mat
x
=
x_
.
getMat
();
const
Mat
last_row
=
Mat
::
ones
(
1
,
x
.
cols
,
x
.
type
());
const
Mat
last_row
=
Mat
::
ones
(
1
,
x
.
cols
,
x
.
type
());
vconcat
(
x
,
last_row
,
_X
);
vconcat
(
x
,
last_row
,
X_
);
}
}
template
<
typename
T
>
template
<
typename
T
>
...
@@ -111,16 +111,16 @@ projectionFromKRt(const Mat_<T> &K, const Mat_<T> &R, const Mat_<T> &t, Mat_<T>
...
@@ -111,16 +111,16 @@ projectionFromKRt(const Mat_<T> &K, const Mat_<T> &R, const Mat_<T> &t, Mat_<T>
}
}
void
void
projectionFromKRt
(
InputArray
_K
,
InputArray
_R
,
InputArray
_t
,
OutputArray
_P
)
projectionFromKRt
(
InputArray
K_
,
InputArray
R_
,
InputArray
t_
,
OutputArray
P_
)
{
{
const
Mat
K
=
_K
.
getMat
(),
R
=
_R
.
getMat
(),
t
=
_t
.
getMat
();
const
Mat
K
=
K_
.
getMat
(),
R
=
R_
.
getMat
(),
t
=
t_
.
getMat
();
const
int
depth
=
K
.
depth
();
const
int
depth
=
K
.
depth
();
CV_Assert
((
K
.
cols
==
3
&&
K
.
rows
==
3
)
&&
(
t
.
cols
==
1
&&
t
.
rows
==
3
)
&&
(
K
.
size
()
==
R
.
size
()));
CV_Assert
((
K
.
cols
==
3
&&
K
.
rows
==
3
)
&&
(
t
.
cols
==
1
&&
t
.
rows
==
3
)
&&
(
K
.
size
()
==
R
.
size
()));
CV_Assert
((
depth
==
CV_32F
||
depth
==
CV_64F
)
&&
depth
==
R
.
depth
()
&&
depth
==
t
.
depth
());
CV_Assert
((
depth
==
CV_32F
||
depth
==
CV_64F
)
&&
depth
==
R
.
depth
()
&&
depth
==
t
.
depth
());
_P
.
create
(
3
,
4
,
depth
);
P_
.
create
(
3
,
4
,
depth
);
Mat
P
=
_P
.
getMat
();
Mat
P
=
P_
.
getMat
();
// type
// type
if
(
depth
==
CV_32F
)
if
(
depth
==
CV_32F
)
...
@@ -136,33 +136,33 @@ projectionFromKRt(InputArray _K, InputArray _R, InputArray _t, OutputArray _P)
...
@@ -136,33 +136,33 @@ projectionFromKRt(InputArray _K, InputArray _R, InputArray _t, OutputArray _P)
template
<
typename
T
>
template
<
typename
T
>
void
void
KRtFromProjection
(
const
Mat_
<
T
>
&
_P
,
Mat_
<
T
>
_K
,
Mat_
<
T
>
_R
,
Mat_
<
T
>
_t
)
KRtFromProjection
(
const
Mat_
<
T
>
&
P_
,
Mat_
<
T
>
K_
,
Mat_
<
T
>
R_
,
Mat_
<
T
>
t_
)
{
{
libmv
::
Mat34
P
;
libmv
::
Mat34
P
;
libmv
::
Mat3
K
,
R
;
libmv
::
Mat3
K
,
R
;
libmv
::
Vec3
t
;
libmv
::
Vec3
t
;
cv2eigen
(
_P
,
P
);
cv2eigen
(
P_
,
P
);
libmv
::
KRt_From_P
(
P
,
&
K
,
&
R
,
&
t
);
libmv
::
KRt_From_P
(
P
,
&
K
,
&
R
,
&
t
);
eigen2cv
(
K
,
_K
);
eigen2cv
(
K
,
K_
);
eigen2cv
(
R
,
_R
);
eigen2cv
(
R
,
R_
);
eigen2cv
(
t
,
_t
);
eigen2cv
(
t
,
t_
);
}
}
void
void
KRtFromProjection
(
InputArray
_P
,
OutputArray
_K
,
OutputArray
_R
,
OutputArray
_t
)
KRtFromProjection
(
InputArray
P_
,
OutputArray
K_
,
OutputArray
R_
,
OutputArray
t_
)
{
{
const
Mat
P
=
_P
.
getMat
();
const
Mat
P
=
P_
.
getMat
();
const
int
depth
=
P
.
depth
();
const
int
depth
=
P
.
depth
();
CV_Assert
((
P
.
cols
==
4
&&
P
.
rows
==
3
)
&&
(
depth
==
CV_32F
||
depth
==
CV_64F
));
CV_Assert
((
P
.
cols
==
4
&&
P
.
rows
==
3
)
&&
(
depth
==
CV_32F
||
depth
==
CV_64F
));
_K
.
create
(
3
,
3
,
depth
);
K_
.
create
(
3
,
3
,
depth
);
_R
.
create
(
3
,
3
,
depth
);
R_
.
create
(
3
,
3
,
depth
);
_t
.
create
(
3
,
1
,
depth
);
t_
.
create
(
3
,
1
,
depth
);
Mat
K
=
_K
.
getMat
(),
R
=
_R
.
getMat
(),
t
=
_t
.
getMat
();
Mat
K
=
K_
.
getMat
(),
R
=
R_
.
getMat
(),
t
=
t_
.
getMat
();
// type
// type
if
(
depth
==
CV_32F
)
if
(
depth
==
CV_32F
)
...
@@ -177,19 +177,19 @@ KRtFromProjection( InputArray _P, OutputArray _K, OutputArray _R, OutputArray _t
...
@@ -177,19 +177,19 @@ KRtFromProjection( InputArray _P, OutputArray _K, OutputArray _R, OutputArray _t
template
<
typename
T
>
template
<
typename
T
>
T
T
depthValue
(
const
Mat_
<
T
>
&
_R
,
const
Mat_
<
T
>
&
_t
,
const
Mat_
<
T
>
&
_X
)
depthValue
(
const
Mat_
<
T
>
&
R_
,
const
Mat_
<
T
>
&
t_
,
const
Mat_
<
T
>
&
X_
)
{
{
Matx
<
T
,
3
,
3
>
R
(
_R
);
Matx
<
T
,
3
,
3
>
R
(
R_
);
Vec
<
T
,
3
>
t
(
_t
);
Vec
<
T
,
3
>
t
(
t_
);
if
(
_X
.
rows
==
3
)
if
(
X_
.
rows
==
3
)
{
{
Vec
<
T
,
3
>
X
(
_X
);
Vec
<
T
,
3
>
X
(
X_
);
return
(
R
*
X
)(
2
)
+
t
(
2
);
return
(
R
*
X
)(
2
)
+
t
(
2
);
}
}
else
else
{
{
Vec
<
T
,
4
>
X
(
_X
);
Vec
<
T
,
4
>
X
(
X_
);
Vec
<
T
,
3
>
Xe
;
Vec
<
T
,
3
>
Xe
;
homogeneousToEuclidean
(
X
,
Xe
);
homogeneousToEuclidean
(
X
,
Xe
);
return
depthValue
<
T
>
(
Mat
(
R
),
Mat
(
t
),
Mat
(
Xe
)
);
return
depthValue
<
T
>
(
Mat
(
R
),
Mat
(
t
),
Mat
(
Xe
)
);
...
@@ -197,9 +197,9 @@ depthValue( const Mat_<T> &_R, const Mat_<T> &_t, const Mat_<T> &_X )
...
@@ -197,9 +197,9 @@ depthValue( const Mat_<T> &_R, const Mat_<T> &_t, const Mat_<T> &_X )
}
}
double
double
depth
(
InputArray
_R
,
InputArray
_t
,
InputArray
_X
)
depth
(
InputArray
R_
,
InputArray
t_
,
InputArray
X_
)
{
{
const
Mat
R
=
_R
.
getMat
(),
t
=
_t
.
getMat
(),
X
=
_X
.
getMat
();
const
Mat
R
=
R_
.
getMat
(),
t
=
t_
.
getMat
(),
X
=
X_
.
getMat
();
const
int
depth
=
R
.
depth
();
const
int
depth
=
R
.
depth
();
CV_Assert
(
R
.
rows
==
3
&&
R
.
cols
==
3
&&
t
.
rows
==
3
&&
t
.
cols
==
1
);
CV_Assert
(
R
.
rows
==
3
&&
R
.
cols
==
3
&&
t
.
rows
==
3
&&
t
.
cols
==
1
);
CV_Assert
(
(
X
.
rows
==
3
&&
X
.
cols
==
1
)
||
(
X
.
rows
==
4
&&
X
.
cols
==
1
)
);
CV_Assert
(
(
X
.
rows
==
3
&&
X
.
cols
==
1
)
||
(
X
.
rows
==
4
&&
X
.
cols
==
1
)
);
...
...
modules/sfm/tutorials/sfm_trajectory_estimation/sfm_trajectory_estimation.markdown
View file @
ab2e8324
...
@@ -14,7 +14,7 @@ In this tutorial you will learn how to use the reconstruction api for camera mot
...
@@ -14,7 +14,7 @@ In this tutorial you will learn how to use the reconstruction api for camera mot
Code
Code
----
----
@include sfm/samples/trajectory_reconstruc
c
ion.cpp
@include sfm/samples/trajectory_reconstruc
t
ion.cpp
Explanation
Explanation
-----------
-----------
...
...
modules/text/CMakeLists.txt
View file @
ab2e8324
...
@@ -7,7 +7,7 @@ if(NOT CMAKE_CROSSCOMPILING OR OPENCV_FIND_TESSERACT)
...
@@ -7,7 +7,7 @@ if(NOT CMAKE_CROSSCOMPILING OR OPENCV_FIND_TESSERACT)
if
(
Tesseract_FOUND
)
if
(
Tesseract_FOUND
)
message
(
STATUS
"Tesseract: YES"
)
message
(
STATUS
"Tesseract: YES"
)
set
(
HAVE_TESSERACT 1
)
set
(
HAVE_TESSERACT 1
)
ocv_include_directories
(
${
Tesseract_INCLUDE_DIR
}
)
ocv_include_directories
(
${
Tesseract_INCLUDE_DIR
S
}
)
ocv_target_link_libraries
(
${
the_module
}
${
Tesseract_LIBRARIES
}
)
ocv_target_link_libraries
(
${
the_module
}
${
Tesseract_LIBRARIES
}
)
else
()
else
()
message
(
STATUS
"Tesseract: NO"
)
message
(
STATUS
"Tesseract: NO"
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment