Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
N
ngraph
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
ngraph
Commits
42b4f4d0
Commit
42b4f4d0
authored
Feb 22, 2018
by
pthoreho
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- elementwise Add mkldnn support in cpu emitter
parent
233e4b1b
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
64 additions
and
7 deletions
+64
-7
cpu_emitter.cpp
src/ngraph/runtime/cpu/cpu_emitter.cpp
+62
-7
mkldnn_utils.cpp
src/ngraph/runtime/cpu/mkldnn_utils.cpp
+2
-0
No files found.
src/ngraph/runtime/cpu/cpu_emitter.cpp
View file @
42b4f4d0
...
@@ -172,13 +172,68 @@ namespace ngraph
...
@@ -172,13 +172,68 @@ namespace ngraph
<<
", "
<<
args
[
1
].
get_size
()
<<
", 1>, Eigen::Unaligned> arg1("
<<
", "
<<
args
[
1
].
get_size
()
<<
", 1>, Eigen::Unaligned> arg1("
<<
args
[
1
].
get_name
()
<<
");
\n
"
;
<<
args
[
1
].
get_name
()
<<
");
\n
"
;
writer
<<
"out = arg0 + arg1;
\n
"
;
writer
<<
"out = arg0 + arg1;
\n
"
;
#else
#else
writer
<<
"#pragma omp parallel for
\n
"
;
if
(
args
[
0
].
get_element_type
()
==
element
::
f32
&&
args
[
1
].
get_element_type
()
==
element
::
f32
)
writer
<<
"for (size_t i = 0; i < "
<<
out
[
0
].
get_size
()
<<
"; i++)
\n
"
;
{
writer
<<
"{
\n
"
;
auto
input0_size_1d
=
1
;
writer
<<
" "
<<
out
[
0
].
get_name
()
<<
"[i] = "
<<
args
[
0
].
get_name
()
<<
"[i] + "
auto
input1_size_1d
=
1
;
<<
args
[
1
].
get_name
()
<<
"[i];
\n
"
;
auto
result_size_1d
=
1
;
writer
<<
"}
\n
"
;
auto
src_size
=
args
[
0
].
get_shape
().
size
();
for
(
size_t
i
=
0
;
i
<
src_size
;
i
++
)
{
input0_size_1d
*=
args
[
0
].
get_shape
()[
i
];
input1_size_1d
*=
args
[
1
].
get_shape
()[
i
];
result_size_1d
*=
out
[
0
].
get_shape
()[
i
];
}
const
string
&
et
=
get_mkldnn_data_type
(
args
[
0
].
get_element_type
().
c_type_string
());
// Bind to CPU engine
writer
<<
"engine cpu_engine = engine(engine::cpu, 0);
\n
"
;
writer
<<
"std::vector<float>scale_vector(2, 1);
\n
"
;
writer
<<
"std::vector<memory::primitive_desc> inputs_pd;
\n
"
;
writer
<<
"std::vector<memory::primitive::at> inputs_primitive;
\n
"
;
// memory desc for inputs
writer
<<
"memory::desc input0_data_desc = memory::desc({"
<<
input0_size_1d
<<
"}, "
<<
et
<<
", memory::format::x);
\n
"
;
writer
<<
"memory::desc input1_data_desc = memory::desc({"
<<
input1_size_1d
<<
"}, "
<<
et
<<
", memory::format::x);
\n
"
;
writer
<<
"memory::desc result_desc = memory::desc({"
<<
result_size_1d
<<
"}, "
<<
et
<<
", memory::format::x);
\n
"
;
// memory for the user data
writer
<<
"memory input0_data = memory({input0_data_desc, cpu_engine}, "
<<
args
[
0
].
get_name
()
<<
");
\n
"
;
writer
<<
"memory input1_data = memory({input1_data_desc, cpu_engine}, "
<<
args
[
1
].
get_name
()
<<
");
\n
"
;
writer
<<
"memory result = memory({result_desc, cpu_engine}, "
<<
out
[
0
].
get_name
()
<<
");
\n
"
;
writer
<<
"inputs_pd.push_back(memory::primitive_desc(input0_data_desc, cpu_engine));
\n
"
;
writer
<<
"inputs_pd.push_back(memory::primitive_desc(input1_data_desc, cpu_engine));
\n
"
;
writer
<<
"inputs_primitive.push_back(primitive::at(input0_data));
\n
"
;
writer
<<
"inputs_primitive.push_back(primitive::at(input1_data));
\n
"
;
// elementwise sum primtive descriptor
writer
<<
"sum::primitive_desc sum_pd = sum::primitive_desc(result_desc, scale_vector, inputs_pd);
\n
"
;
// sum primitive
writer
<<
"sum sum_primitive = sum(sum_pd, inputs_primitive, result);
\n
"
;
// create stream and execute
writer
<<
"stream s = stream(stream::kind::eager);
\n
"
<<
"s.submit({sum_primitive}).wait();
\n
"
;
}
else
{
writer
<<
"#pragma omp parallel for
\n
"
;
writer
<<
"for (size_t i = 0; i < "
<<
out
[
0
].
get_size
()
<<
"; i++)
\n
"
;
writer
<<
"{
\n
"
;
writer
<<
" "
<<
out
[
0
].
get_name
()
<<
"[i] = "
<<
args
[
0
].
get_name
()
<<
"[i] + "
<<
args
[
1
].
get_name
()
<<
"[i];
\n
"
;
writer
<<
"}
\n
"
;
}
#endif
#endif
writer
.
indent
--
;
writer
.
indent
--
;
writer
<<
"}
\n
"
;
writer
<<
"}
\n
"
;
...
...
src/ngraph/runtime/cpu/mkldnn_utils.cpp
View file @
42b4f4d0
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
#include <unordered_set>
#include <unordered_set>
#include "ngraph/node.hpp"
#include "ngraph/node.hpp"
#include "ngraph/ops/add.hpp"
#include "ngraph/ops/avg_pool.hpp"
#include "ngraph/ops/avg_pool.hpp"
#include "ngraph/ops/batch_norm.hpp"
#include "ngraph/ops/batch_norm.hpp"
#include "ngraph/ops/convolution.hpp"
#include "ngraph/ops/convolution.hpp"
...
@@ -39,6 +40,7 @@ namespace ngraph
...
@@ -39,6 +40,7 @@ namespace ngraph
#define TI(x) std::type_index(typeid(x))
#define TI(x) std::type_index(typeid(x))
static
const
std
::
unordered_set
<
std
::
type_index
>
s_op_registry
{
static
const
std
::
unordered_set
<
std
::
type_index
>
s_op_registry
{
TI
(
ngraph
::
op
::
Add
),
TI
(
ngraph
::
op
::
AvgPool
),
TI
(
ngraph
::
op
::
AvgPool
),
TI
(
ngraph
::
op
::
AvgPoolBackprop
),
TI
(
ngraph
::
op
::
AvgPoolBackprop
),
TI
(
ngraph
::
op
::
BatchNorm
),
TI
(
ngraph
::
op
::
BatchNorm
),
...
...
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