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
1fe10ef5
Commit
1fe10ef5
authored
Sep 12, 2018
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1761 from alalek:build_fix_matlab
parents
b10554ca
9ef878f3
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
106 additions
and
43 deletions
+106
-43
CMakeLists.txt
modules/matlab/CMakeLists.txt
+7
-2
compile.cmake
modules/matlab/compile.cmake
+8
-1
filters.py
modules/matlab/generator/filters.py
+1
-3
gen_matlab.py
modules/matlab/generator/gen_matlab.py
+24
-8
parse_tree.py
modules/matlab/generator/parse_tree.py
+26
-5
functional.cpp
modules/matlab/generator/templates/functional.cpp
+5
-3
template_class_base.cpp
modules/matlab/generator/templates/template_class_base.cpp
+1
-2
template_function_base.cpp
...les/matlab/generator/templates/template_function_base.cpp
+1
-2
bridge.hpp
modules/matlab/include/opencv2/matlab/bridge.hpp
+33
-17
No files found.
modules/matlab/CMakeLists.txt
View file @
1fe10ef5
set
(
BUILD_opencv_matlab_INIT OFF
)
# Matlab module is broken
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# CMake file for Matlab/Octave support
# CMake file for Matlab/Octave support
#
#
...
@@ -261,6 +259,13 @@ add_custom_command(
...
@@ -261,6 +259,13 @@ add_custom_command(
COMMAND
${
CMAKE_COMMAND
}
-E copy
${
CMAKE_CURRENT_SOURCE_DIR
}
/test/help.m
${
CMAKE_CURRENT_BINARY_DIR
}
/+cv
COMMAND
${
CMAKE_COMMAND
}
-E copy
${
CMAKE_CURRENT_SOURCE_DIR
}
/test/help.m
${
CMAKE_CURRENT_BINARY_DIR
}
/+cv
COMMAND
${
CMAKE_COMMAND
}
-E touch
${
GENERATE_PROXY
}
COMMAND
${
CMAKE_COMMAND
}
-E touch
${
GENERATE_PROXY
}
COMMENT
"Generating Matlab source files"
COMMENT
"Generating Matlab source files"
DEPENDS
"
${
CMAKE_CURRENT_LIST_DIR
}
/generator/build_info.py"
DEPENDS
"
${
CMAKE_CURRENT_LIST_DIR
}
/generator/cvmex.py"
DEPENDS
"
${
CMAKE_CURRENT_LIST_DIR
}
/generator/filters.py"
DEPENDS
"
${
CMAKE_CURRENT_LIST_DIR
}
/generator/gen_matlab.py"
DEPENDS
"
${
CMAKE_CURRENT_LIST_DIR
}
/generator/parse_tree.py"
DEPENDS
"
${
CMAKE_CURRENT_LIST_DIR
}
/generator/templates/functional.cpp"
DEPENDS
"
${
CMAKE_CURRENT_LIST_DIR
}
/generator/templates/template_function_base.cpp"
)
)
# compile
# compile
...
...
modules/matlab/compile.cmake
View file @
1fe10ef5
...
@@ -28,11 +28,18 @@ endif()
...
@@ -28,11 +28,18 @@ endif()
# 2. attempt compile if required
# 2. attempt compile if required
# 3. if the compile fails, throw an error and cancel compilation
# 3. if the compile fails, throw an error and cancel compilation
file
(
GLOB SOURCE_FILES
"
${
CMAKE_CURRENT_BINARY_DIR
}
/src/*.cpp"
)
file
(
GLOB SOURCE_FILES
"
${
CMAKE_CURRENT_BINARY_DIR
}
/src/*.cpp"
)
list
(
LENGTH SOURCE_FILES __size
)
message
(
"Matlab: compiling
${
__size
}
files"
)
set
(
__index 0
)
foreach
(
SOURCE_FILE
${
SOURCE_FILES
}
)
foreach
(
SOURCE_FILE
${
SOURCE_FILES
}
)
MATH
(
EXPR __index
"
${
__index
}
+1"
)
# strip out the filename
# strip out the filename
get_filename_component
(
FILENAME
${
SOURCE_FILE
}
NAME_WE
)
get_filename_component
(
FILENAME
${
SOURCE_FILE
}
NAME_WE
)
message
(
"[
${
__index
}
/
${
__size
}
] Compiling:
${
FILENAME
}
"
)
# compile the source file using mex
# compile the source file using mex
if
(
NOT EXISTS
${
CMAKE_CURRENT_BINARY_DIR
}
/+cv/
${
FILENAME
}
.
${
MATLAB_MEXEXT
}
)
if
(
NOT EXISTS
"
${
CMAKE_CURRENT_BINARY_DIR
}
/+cv/
${
FILENAME
}
.
${
MATLAB_MEXEXT
}
"
OR
"
${
SOURCE_FILE
}
"
IS_NEWER_THAN
"
${
CMAKE_CURRENT_BINARY_DIR
}
/+cv/
${
FILENAME
}
.
${
MATLAB_MEXEXT
}
"
)
execute_process
(
execute_process
(
COMMAND
${
MATLAB_MEX_SCRIPT
}
${
MEX_OPTS
}
"CXXFLAGS=
\$
CXXFLAGS
${
MEX_CXXFLAGS
}
"
${
MEX_INCLUDE_DIRS_LIST
}
COMMAND
${
MATLAB_MEX_SCRIPT
}
${
MEX_OPTS
}
"CXXFLAGS=
\$
CXXFLAGS
${
MEX_CXXFLAGS
}
"
${
MEX_INCLUDE_DIRS_LIST
}
${
MEX_LIB_DIR
}
${
MEX_LIBS_LIST
}
${
SOURCE_FILE
}
${
MEX_LIB_DIR
}
${
MEX_LIBS_LIST
}
${
SOURCE_FILE
}
...
...
modules/matlab/generator/filters.py
View file @
1fe10ef5
...
@@ -5,8 +5,6 @@ urlexpr = re.compile(r"((https?):((//)|(\\\\))+[\w\d:#@%/;$()~_?\+-=\\\.&]*)", r
...
@@ -5,8 +5,6 @@ urlexpr = re.compile(r"((https?):((//)|(\\\\))+[\w\d:#@%/;$()~_?\+-=\\\.&]*)", r
def
inputs
(
args
):
def
inputs
(
args
):
'''Keeps only the input arguments in a list of elements.
'''Keeps only the input arguments in a list of elements.
In OpenCV input arguments are all arguments with names
not beginning with 'dst'
'''
'''
try
:
try
:
return
[
arg
for
arg
in
args
[
'only'
]
if
arg
.
I
and
not
arg
.
O
]
return
[
arg
for
arg
in
args
[
'only'
]
if
arg
.
I
and
not
arg
.
O
]
...
@@ -20,7 +18,7 @@ def ninputs(fun):
...
@@ -20,7 +18,7 @@ def ninputs(fun):
def
outputs
(
args
):
def
outputs
(
args
):
'''Determines whether any of the given arguments is an output
'''Determines whether any of the given arguments is an output
reference, and returns a list of only those elements.
reference, and returns a list of only those elements.
In OpenCV, output references are preceeded by
'dst'
In OpenCV, output references are preceeded by
CV_OUT or has *OutputArray* type
'''
'''
try
:
try
:
return
[
arg
for
arg
in
args
[
'only'
]
if
arg
.
O
and
not
arg
.
I
]
return
[
arg
for
arg
in
args
[
'only'
]
if
arg
.
O
and
not
arg
.
I
]
...
...
modules/matlab/generator/gen_matlab.py
View file @
1fe10ef5
...
@@ -4,6 +4,26 @@ from string import Template
...
@@ -4,6 +4,26 @@ from string import Template
from
parse_tree
import
ParseTree
,
todict
,
constants
from
parse_tree
import
ParseTree
,
todict
,
constants
from
filters
import
*
from
filters
import
*
updated_files
=
[]
def
update_file
(
fname
,
content
):
if
fname
in
updated_files
:
print
(
'ERROR(gen_matlab.py): attemption to write file multiple times: {}'
.
format
(
fname
))
return
updated_files
.
append
(
fname
)
if
os
.
path
.
exists
(
fname
):
with
open
(
fname
,
'rb'
)
as
f
:
old_content
=
f
.
read
()
if
old_content
==
content
:
#print('Up-to-date: {}'.format(fname))
return
print
(
'Updating: {}'
.
format
(
fname
))
else
:
print
(
'Writing: {}'
.
format
(
fname
))
with
open
(
fname
,
'wb'
)
as
f
:
f
.
write
(
content
)
class
MatlabWrapperGenerator
(
object
):
class
MatlabWrapperGenerator
(
object
):
"""
"""
MatlabWrapperGenerator is a class for generating Matlab mex sources from
MatlabWrapperGenerator is a class for generating Matlab mex sources from
...
@@ -107,24 +127,20 @@ class MatlabWrapperGenerator(object):
...
@@ -107,24 +127,20 @@ class MatlabWrapperGenerator(object):
# functions
# functions
for
method
in
namespace
.
methods
:
for
method
in
namespace
.
methods
:
populated
=
tfunction
.
render
(
fun
=
method
,
time
=
time
,
includes
=
namespace
.
name
)
populated
=
tfunction
.
render
(
fun
=
method
,
time
=
time
,
includes
=
namespace
.
name
)
with
open
(
output_source_dir
+
'/'
+
method
.
name
+
'.cpp'
,
'wb'
)
as
f
:
update_file
(
output_source_dir
+
'/'
+
method
.
name
+
'.cpp'
,
populated
.
encode
(
'utf-8'
))
f
.
write
(
populated
.
encode
(
'utf-8'
))
# classes
# classes
for
clss
in
namespace
.
classes
:
for
clss
in
namespace
.
classes
:
# cpp converter
# cpp converter
populated
=
tclassc
.
render
(
clss
=
clss
,
time
=
time
)
populated
=
tclassc
.
render
(
clss
=
clss
,
time
=
time
)
with
open
(
output_private_dir
+
'/'
+
clss
.
name
+
'Bridge.cpp'
,
'wb'
)
as
f
:
update_file
(
output_private_dir
+
'/'
+
clss
.
name
+
'Bridge.cpp'
,
populated
.
encode
(
'utf-8'
))
f
.
write
(
populated
.
encode
(
'utf-8'
))
# matlab classdef
# matlab classdef
populated
=
tclassm
.
render
(
clss
=
clss
,
time
=
time
)
populated
=
tclassm
.
render
(
clss
=
clss
,
time
=
time
)
with
open
(
output_class_dir
+
'/'
+
clss
.
name
+
'.m'
,
'wb'
)
as
f
:
update_file
(
output_class_dir
+
'/'
+
clss
.
name
+
'.m'
,
populated
.
encode
(
'utf-8'
))
f
.
write
(
populated
.
encode
(
'utf-8'
))
# create a global constants lookup table
# create a global constants lookup table
const
=
dict
(
constants
(
todict
(
parse_tree
.
namespaces
)))
const
=
dict
(
constants
(
todict
(
parse_tree
.
namespaces
)))
populated
=
tconst
.
render
(
constants
=
const
,
time
=
time
)
populated
=
tconst
.
render
(
constants
=
const
,
time
=
time
)
with
open
(
output_dir
+
'/cv.m'
,
'wb'
)
as
f
:
update_file
(
output_dir
+
'/cv.m'
,
populated
.
encode
(
'utf-8'
))
f
.
write
(
populated
.
encode
(
'utf-8'
))
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
...
...
modules/matlab/generator/parse_tree.py
View file @
1fe10ef5
...
@@ -8,6 +8,21 @@ except NameError:
...
@@ -8,6 +8,21 @@ except NameError:
# Python 3.3+
# Python 3.3+
basestring
=
str
basestring
=
str
valid_types
=
(
'int'
,
'bool'
,
'float'
,
'double'
,
'size_t'
,
'char'
,
'Mat'
,
'Scalar'
,
'String'
,
'TermCriteria'
,
'Size'
,
'Point'
,
'Point2f'
,
'Point2d'
,
'Rect'
,
'RotatedRect'
,
'RNG'
,
'DMatch'
,
'Moments'
,
'vector_Mat'
,
'vector_Point'
,
'vector_int'
,
'vector_float'
,
'vector_double'
,
'vector_String'
,
'vector_uchar'
,
'vector_Rect'
,
'vector_DMatch'
,
'vector_KeyPoint'
,
'vector_Point2f'
,
'vector_vector_char'
,
'vector_vector_DMatch'
,
'vector_vector_KeyPoint'
,
'Ptr_StereoBM'
,
'Ptr_StereoSGBM'
,
'Ptr_FeatureDetector'
,
'Ptr_CLAHE'
,
'Ptr_LineSegmentDetector'
,
'Ptr_AlignMTB'
,
'Ptr_CalibrateDebevec'
,
'Ptr_CalibrateRobertson'
,
'Ptr_DenseOpticalFlow'
,
'Ptr_DualTVL1OpticalFlow'
,
'Ptr_MergeDebevec'
,
'Ptr_MergeMertens'
,
'Ptr_MergeRobertson'
,
'Ptr_Stitcher'
,
'Ptr_Tonemap'
,
'Ptr_TonemapDrago'
,
'Ptr_TonemapDurand'
,
'Ptr_TonemapMantiuk'
,
'Ptr_TonemapReinhard'
,
'Ptr_float'
,
# Not supported:
#vector_vector_KeyPoint
)
class
ParseTree
(
object
):
class
ParseTree
(
object
):
"""
"""
The ParseTree class produces a semantic tree of C++ definitions given
The ParseTree class produces a semantic tree of C++ definitions given
...
@@ -89,7 +104,11 @@ class ParseTree(object):
...
@@ -89,7 +104,11 @@ class ParseTree(object):
methods
=
[]
methods
=
[]
constants
=
[]
constants
=
[]
for
defn
in
definitions
:
for
defn
in
definitions
:
try
:
obj
=
babel
.
translate
(
defn
)
obj
=
babel
.
translate
(
defn
)
except
Exception
as
e
:
print
(
e
)
obj
=
None
if
obj
is
None
:
if
obj
is
None
:
continue
continue
if
type
(
obj
)
is
Class
or
obj
.
clss
:
if
type
(
obj
)
is
Class
or
obj
.
clss
:
...
@@ -176,15 +195,15 @@ class Translator(object):
...
@@ -176,15 +195,15 @@ class Translator(object):
return
Constant
(
name
,
clss
,
tp
,
const
,
''
,
val
)
return
Constant
(
name
,
clss
,
tp
,
const
,
''
,
val
)
def
translateArgument
(
self
,
defn
):
def
translateArgument
(
self
,
defn
):
modifiers
=
defn
[
3
]
ref
=
'*'
if
'*'
in
defn
[
0
]
else
''
ref
=
'*'
if
'*'
in
defn
[
0
]
else
''
ref
=
'&'
if
'&'
in
defn
[
0
]
else
ref
ref
=
'&'
if
'&'
in
defn
[
0
]
or
'/Ref'
in
modifiers
else
ref
const
=
'
const '
in
' '
+
defn
[
0
]
+
' '
const
=
'
/C'
in
modifiers
tp
=
" "
.
join
([
word
for
word
in
defn
[
0
]
.
replace
(
ref
,
''
)
.
split
()
if
not
' const '
in
' '
+
word
+
' '
])
tp
=
" "
.
join
([
word
for
word
in
defn
[
0
]
.
replace
(
ref
,
''
)
.
split
()
if
not
' const '
in
' '
+
word
+
' '
])
name
=
defn
[
1
]
name
=
defn
[
1
]
default
=
defn
[
2
]
if
defn
[
2
]
else
''
default
=
defn
[
2
]
if
defn
[
2
]
else
''
modifiers
=
''
.
join
(
defn
[
3
])
I
=
True
if
'/I'
in
modifiers
or
not
'/O'
in
modifiers
else
False
I
=
True
if
not
modifiers
or
'I'
in
modifiers
else
False
O
=
True
if
'/O'
in
modifiers
else
False
O
=
True
if
'O'
in
modifiers
else
False
return
Argument
(
name
,
tp
,
const
,
I
,
O
,
ref
,
default
)
return
Argument
(
name
,
tp
,
const
,
I
,
O
,
ref
,
default
)
def
translateName
(
self
,
name
):
def
translateName
(
self
,
name
):
...
@@ -292,6 +311,8 @@ class Argument(object):
...
@@ -292,6 +311,8 @@ class Argument(object):
self
.
O
=
O
self
.
O
=
O
self
.
const
=
const
self
.
const
=
const
self
.
default
=
default
self
.
default
=
default
if
not
tp
in
valid_types
:
raise
Exception
(
"Non-supported argument type: {} (name: {})"
.
format
(
tp
,
name
))
def
__str__
(
self
):
def
__str__
(
self
):
return
(
'const '
if
self
.
const
else
''
)
+
self
.
tp
+
self
.
ref
+
\
return
(
'const '
if
self
.
const
else
''
)
+
self
.
tp
+
self
.
ref
+
\
...
...
modules/matlab/generator/templates/functional.cpp
View file @
1fe10ef5
...
@@ -104,21 +104,23 @@ addVariant("{{ fun.name }}", {{ fun.req|inputs|length }}, {{ fun.opt|inputs|leng
...
@@ -104,21 +104,23 @@ addVariant("{{ fun.name }}", {{ fun.req|inputs|length }}, {{ fun.opt|inputs|leng
{
%-
macro
handleInputs
(
fun
)
%
}
{
%-
macro
handleInputs
(
fun
)
%
}
{
%
if
fun
|
ninputs
or
(
fun
|
noutputs
and
not
fun
.
constructor
)
%
}
{
%
if
fun
|
ninputs
or
(
fun
|
noutputs
and
not
fun
.
constructor
)
%
}
// unpack the arguments
// - inputs
{
#
-----------
Inputs
-------------
#
}
{
%
for
arg
in
fun
.
req
|
inputs
%
}
{
%
for
arg
in
fun
.
req
|
inputs
%
}
{{
arg
.
tp
}}
{{
arg
.
name
}}
=
inputs
[{{
loop
.
index0
}}].
to
{{
arg
.
tp
|
toUpperCamelCase
}}();
{{
arg
.
tp
}}
{{
arg
.
name
}}
=
inputs
[{{
loop
.
index0
}}].
to
{{
arg
.
tp
|
toUpperCamelCase
}}();
{
%
endfor
%
}
{
%
endfor
%
}
// - inputs (opt)
{
%
for
opt
in
fun
.
opt
|
inputs
%
}
{
%
for
opt
in
fun
.
opt
|
inputs
%
}
{{
opt
.
tp
}}
{{
opt
.
name
}}
=
inputs
[{{
loop
.
index0
+
fun
.
req
|
inputs
|
length
}}].
empty
()
?
({{
opt
.
tp
}})
{
%
if
opt
.
ref
==
'*'
-%
}
{{
opt
.
tp
}}()
{
%-
else
-%
}
{{
opt
.
default
}}
{
%-
endif
%
}
:
inputs
[{{
loop
.
index0
+
fun
.
req
|
inputs
|
length
}}].
to
{{
opt
.
tp
|
toUpperCamelCase
}}();
{{
opt
.
tp
}}
{{
opt
.
name
}}
=
inputs
[{{
loop
.
index0
+
fun
.
req
|
inputs
|
length
}}].
empty
()
?
({{
opt
.
tp
}})
{
%
if
opt
.
ref
==
'*'
-%
}
{{
opt
.
tp
}}()
{
%-
else
-%
}
{{
opt
.
default
}}
{
%-
endif
%
}
:
inputs
[{{
loop
.
index0
+
fun
.
req
|
inputs
|
length
}}].
to
{{
opt
.
tp
|
toUpperCamelCase
}}();
{
%
endfor
%
}
{
%
endfor
%
}
{
#
-----------
Outputs
------------
#
}
// - outputs
{
%
for
arg
in
fun
.
req
|
only
|
outputs
%
}
{
%
for
arg
in
fun
.
req
|
only
|
outputs
%
}
{{
arg
.
tp
}}
{{
arg
.
name
}};
{{
arg
.
tp
}}
{{
arg
.
name
}};
{
%
endfor
%
}
{
%
endfor
%
}
// - outputs (opt)
{
%
for
opt
in
fun
.
opt
|
only
|
outputs
%
}
{
%
for
opt
in
fun
.
opt
|
only
|
outputs
%
}
{{
opt
.
tp
}}
{{
opt
.
name
}};
{{
opt
.
tp
}}
{{
opt
.
name
}};
{
%
endfor
%
}
{
%
endfor
%
}
// - return
{
%
if
not
fun
.
rtp
|
void
and
not
fun
.
constructor
%
}
{
%
if
not
fun
.
rtp
|
void
and
not
fun
.
constructor
%
}
{{
fun
.
rtp
}}
retval
;
{{
fun
.
rtp
}}
retval
;
{
%
endif
%
}
{
%
endif
%
}
...
...
modules/matlab/generator/templates/template_class_base.cpp
View file @
1fe10ef5
...
@@ -2,11 +2,10 @@
...
@@ -2,11 +2,10 @@
/*
/*
* file: {{clss.name}}Bridge.cpp
* file: {{clss.name}}Bridge.cpp
* author: A trusty code generator
* author: A trusty code generator
* date: {{time.strftime("%a, %d %b %Y %H:%M:%S", time.localtime())}}
*
*
* This file was autogenerated, do not modify.
* This file was autogenerated, do not modify.
* See LICENSE for full modification and redistribution details.
* See LICENSE for full modification and redistribution details.
* Copyright
{{time.strftime("%Y", time.localtime())}}
The OpenCV Foundation
* Copyright
2018
The OpenCV Foundation
*/
*/
#include <mex.h>
#include <mex.h>
#include <vector>
#include <vector>
...
...
modules/matlab/generator/templates/template_function_base.cpp
View file @
1fe10ef5
...
@@ -2,11 +2,10 @@
...
@@ -2,11 +2,10 @@
/*
/*
* file: {{fun.name}}.cpp
* file: {{fun.name}}.cpp
* author: A trusty code generator
* author: A trusty code generator
* date: {{time.strftime("%a, %d %b %Y %H:%M:%S", time.localtime())}}
*
*
* This file was autogenerated, do not modify.
* This file was autogenerated, do not modify.
* See LICENSE for full modification and redistribution details.
* See LICENSE for full modification and redistribution details.
* Copyright
{{time.strftime("%Y", time.localtime())}}
The OpenCV Foundation
* Copyright
2018
The OpenCV Foundation
*/
*/
#include <string>
#include <string>
#include <vector>
#include <vector>
...
...
modules/matlab/include/opencv2/matlab/bridge.hpp
View file @
1fe10ef5
...
@@ -249,13 +249,13 @@ public:
...
@@ -249,13 +249,13 @@ public:
case
mxUINT16_CLASS
:
deepCopyAndTranspose
<
uint16_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxUINT16_CLASS
:
deepCopyAndTranspose
<
uint16_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxINT32_CLASS
:
deepCopyAndTranspose
<
int32_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxINT32_CLASS
:
deepCopyAndTranspose
<
int32_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxUINT32_CLASS
:
deepCopyAndTranspose
<
uint32_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxUINT32_CLASS
:
deepCopyAndTranspose
<
uint32_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxINT64_CLASS
:
deepCopyAndTranspose
<
int64_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
//
case mxINT64_CLASS: deepCopyAndTranspose<int64_t, Scalar>(ptr_, mat); break;
case
mxUINT64_CLASS
:
deepCopyAndTranspose
<
uint64_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
//
case mxUINT64_CLASS: deepCopyAndTranspose<uint64_t, Scalar>(ptr_, mat); break;
case
mxSINGLE_CLASS
:
deepCopyAndTranspose
<
float
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxSINGLE_CLASS
:
deepCopyAndTranspose
<
float
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxDOUBLE_CLASS
:
deepCopyAndTranspose
<
double
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxDOUBLE_CLASS
:
deepCopyAndTranspose
<
double
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxCHAR_CLASS
:
deepCopyAndTranspose
<
char
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxCHAR_CLASS
:
deepCopyAndTranspose
<
char
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxLOGICAL_CLASS
:
deepCopyAndTranspose
<
int8_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
case
mxLOGICAL_CLASS
:
deepCopyAndTranspose
<
int8_t
,
Scalar
>
(
ptr_
,
mat
);
break
;
default
:
matlab
::
error
(
"Attempted to convert from unknown class"
);
default
:
matlab
::
error
(
"Attempted to convert from unknown
/unsupported
class"
);
}
}
return
mat
;
return
mat
;
}
}
...
@@ -576,13 +576,13 @@ cv::Mat Bridge::toMat<matlab::InheritType>() const {
...
@@ -576,13 +576,13 @@ cv::Mat Bridge::toMat<matlab::InheritType>() const {
case
mxUINT16_CLASS
:
return
toMat
<
uint16_t
>
();
case
mxUINT16_CLASS
:
return
toMat
<
uint16_t
>
();
case
mxINT32_CLASS
:
return
toMat
<
int32_t
>
();
case
mxINT32_CLASS
:
return
toMat
<
int32_t
>
();
case
mxUINT32_CLASS
:
return
toMat
<
int32_t
>
();
case
mxUINT32_CLASS
:
return
toMat
<
int32_t
>
();
case
mxINT64_CLASS
:
return
toMat
<
int64_t
>
();
//
case mxINT64_CLASS: return toMat<int64_t>();
case
mxUINT64_CLASS
:
return
toMat
<
int64_t
>
();
//
case mxUINT64_CLASS: return toMat<int64_t>();
case
mxSINGLE_CLASS
:
return
toMat
<
float
>
();
case
mxSINGLE_CLASS
:
return
toMat
<
float
>
();
case
mxDOUBLE_CLASS
:
return
toMat
<
float
>
();
//NOTE: OpenCV uses float as native type!
case
mxDOUBLE_CLASS
:
return
toMat
<
float
>
();
//NOTE: OpenCV uses float as native type!
case
mxCHAR_CLASS
:
return
toMat
<
int8_t
>
();
case
mxCHAR_CLASS
:
return
toMat
<
int8_t
>
();
case
mxLOGICAL_CLASS
:
return
toMat
<
int8_t
>
();
case
mxLOGICAL_CLASS
:
return
toMat
<
int8_t
>
();
default
:
matlab
::
error
(
"Attempted to convert from unknown class"
);
default
:
matlab
::
error
(
"Attempted to convert from unknown
/unsuported
class"
);
}
}
return
cv
::
Mat
();
return
cv
::
Mat
();
}
}
...
@@ -598,18 +598,26 @@ cv::Mat Bridge::toMat() const { return toMat<matlab::InheritType>(); }
...
@@ -598,18 +598,26 @@ cv::Mat Bridge::toMat() const { return toMat<matlab::InheritType>(); }
template
<
typename
InputScalar
,
typename
OutputScalar
>
template
<
typename
InputScalar
,
typename
OutputScalar
>
void
deepCopyAndTranspose
(
const
cv
::
Mat
&
in
,
matlab
::
MxArray
&
out
)
{
void
deepCopyAndTranspose
(
const
cv
::
Mat
&
in
,
matlab
::
MxArray
&
out
)
{
const
int
cols
=
out
.
cols
();
const
int
rows
=
out
.
rows
();
matlab
::
conditionalError
(
static_cast
<
size_t
>
(
in
.
rows
)
==
out
.
rows
(),
"Matrices must have the same number of rows"
);
matlab
::
conditionalError
(
static_cast
<
size_t
>
(
in
.
rows
)
==
out
.
rows
(),
"Matrices must have the same number of rows"
);
matlab
::
conditionalError
(
static_cast
<
size_t
>
(
in
.
cols
)
==
out
.
cols
(),
"Matrices must have the same number of cols"
);
matlab
::
conditionalError
(
static_cast
<
size_t
>
(
in
.
cols
)
==
out
.
cols
(),
"Matrices must have the same number of cols"
);
matlab
::
conditionalError
(
static_cast
<
size_t
>
(
in
.
channels
())
==
out
.
channels
(),
"Matrices must have the same number of channels"
);
matlab
::
conditionalError
(
static_cast
<
size_t
>
(
in
.
channels
())
==
out
.
channels
(),
"Matrices must have the same number of channels"
);
std
::
vector
<
cv
::
Mat
>
channels
;
std
::
vector
<
cv
::
Mat
>
channels
;
cv
::
split
(
in
,
channels
);
cv
::
split
(
in
,
channels
);
for
(
size_t
c
=
0
;
c
<
out
.
channels
();
++
c
)
{
for
(
size_t
c
=
0
;
c
<
out
.
channels
();
++
c
)
{
cv
::
transpose
(
channels
[
c
],
channels
[
c
]);
cv
::
Mat_
<
InputScalar
>
m
;
cv
::
Mat
outmat
(
out
.
cols
(),
out
.
rows
(),
cv
::
DataType
<
OutputScalar
>::
type
,
cv
::
transpose
(
channels
[
c
],
m
);
static_cast
<
void
*>
(
out
.
real
<
OutputScalar
>
()
+
out
.
cols
()
*
out
.
rows
()
*
c
));
OutputScalar
*
dst_plane
=
(
OutputScalar
*
)
out
.
real
<
InputScalar
>
()
+
cols
*
rows
*
c
;
channels
[
c
].
convertTo
(
outmat
,
cv
::
DataType
<
OutputScalar
>::
type
);
for
(
int
x
=
0
;
x
<
cols
;
x
++
)
{
OutputScalar
*
dst_col
=
dst_plane
+
x
*
rows
;
for
(
int
y
=
0
;
y
<
rows
;
y
++
)
{
dst_col
[
y
]
=
cv
::
saturate_cast
<
OutputScalar
>
(
m
(
y
,
x
));
}
}
}
}
//const InputScalar* inp = in.ptr<InputScalar>(0);
//const InputScalar* inp = in.ptr<InputScalar>(0);
//OutputScalar* outp = out.real<OutputScalar>();
//OutputScalar* outp = out.real<OutputScalar>();
//gemt('R', out.rows(), out.cols(), inp, in.step1(), outp, out.rows());
//gemt('R', out.rows(), out.cols(), inp, in.step1(), outp, out.rows());
...
@@ -617,17 +625,25 @@ void deepCopyAndTranspose(const cv::Mat& in, matlab::MxArray& out) {
...
@@ -617,17 +625,25 @@ void deepCopyAndTranspose(const cv::Mat& in, matlab::MxArray& out) {
template
<
typename
InputScalar
,
typename
OutputScalar
>
template
<
typename
InputScalar
,
typename
OutputScalar
>
void
deepCopyAndTranspose
(
const
matlab
::
MxArray
&
in
,
cv
::
Mat
&
out
)
{
void
deepCopyAndTranspose
(
const
matlab
::
MxArray
&
in
,
cv
::
Mat
&
out
)
{
const
int
cols
=
in
.
cols
();
const
int
rows
=
in
.
rows
();
matlab
::
conditionalError
(
in
.
rows
()
==
static_cast
<
size_t
>
(
out
.
rows
),
"Matrices must have the same number of rows"
);
matlab
::
conditionalError
(
in
.
rows
()
==
static_cast
<
size_t
>
(
out
.
rows
),
"Matrices must have the same number of rows"
);
matlab
::
conditionalError
(
in
.
cols
()
==
static_cast
<
size_t
>
(
out
.
cols
),
"Matrices must have the same number of cols"
);
matlab
::
conditionalError
(
in
.
cols
()
==
static_cast
<
size_t
>
(
out
.
cols
),
"Matrices must have the same number of cols"
);
matlab
::
conditionalError
(
in
.
channels
()
==
static_cast
<
size_t
>
(
out
.
channels
()),
"Matrices must have the same number of channels"
);
matlab
::
conditionalError
(
in
.
channels
()
==
static_cast
<
size_t
>
(
out
.
channels
()),
"Matrices must have the same number of channels"
);
std
::
vector
<
cv
::
Mat
>
channels
;
std
::
vector
<
cv
::
Mat
>
channels
;
for
(
size_t
c
=
0
;
c
<
in
.
channels
();
++
c
)
{
for
(
size_t
c
=
0
;
c
<
in
.
channels
();
++
c
)
{
cv
::
Mat
outmat
;
cv
::
Mat_
<
OutputScalar
>
m
(
cols
,
rows
);
cv
::
Mat
inmat
(
in
.
cols
(),
in
.
rows
(),
cv
::
DataType
<
InputScalar
>::
type
,
const
InputScalar
*
src_plane
=
in
.
real
<
InputScalar
>
()
+
cols
*
rows
*
c
;
static_cast
<
void
*>
(
const_cast
<
InputScalar
*>
(
in
.
real
<
InputScalar
>
()
+
in
.
cols
()
*
in
.
rows
()
*
c
)));
for
(
int
x
=
0
;
x
<
cols
;
x
++
)
inmat
.
convertTo
(
outmat
,
cv
::
DataType
<
OutputScalar
>::
type
);
{
cv
::
transpose
(
outmat
,
outmat
);
const
InputScalar
*
src_col
=
src_plane
+
x
*
rows
;
channels
.
push_back
(
outmat
);
for
(
int
y
=
0
;
y
<
rows
;
y
++
)
{
m
(
y
,
x
)
=
cv
::
saturate_cast
<
InputScalar
>
(
src_col
[
y
]);
}
}
cv
::
transpose
(
m
,
m
);
channels
.
push_back
(
m
);
}
}
cv
::
merge
(
channels
,
out
);
cv
::
merge
(
channels
,
out
);
...
...
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