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
ffa20eee
Commit
ffa20eee
authored
Oct 28, 2018
by
Sergey Shalnov
Committed by
Robert Kimball
Oct 28, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
IntelGPU backend: Improved dump graph functionality (#1935)
parent
36544d1b
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
212 additions
and
83 deletions
+212
-83
visualize_tree.cpp
src/ngraph/runtime/intelgpu/visualize_tree.cpp
+212
-83
No files found.
src/ngraph/runtime/intelgpu/visualize_tree.cpp
View file @
ffa20eee
...
@@ -21,14 +21,25 @@
...
@@ -21,14 +21,25 @@
#include "ngraph/runtime/intelgpu/visualize_tree.hpp"
#include "ngraph/runtime/intelgpu/visualize_tree.hpp"
#include "ngraph/node.hpp"
#include "ngraph/node.hpp"
#include "ngraph/op/argmax.hpp"
#include "ngraph/op/argmin.hpp"
#include "ngraph/op/avg_pool.hpp"
#include "ngraph/op/avg_pool.hpp"
#include "ngraph/op/batch_norm.hpp"
#include "ngraph/op/batch_norm.hpp"
#include "ngraph/op/broadcast.hpp"
#include "ngraph/op/broadcast.hpp"
#include "ngraph/op/concat.hpp"
#include "ngraph/op/concat.hpp"
#include "ngraph/op/constant.hpp"
#include "ngraph/op/convolution.hpp"
#include "ngraph/op/convolution.hpp"
#include "ngraph/op/dot.hpp"
#include "ngraph/op/get_output_element.hpp"
#include "ngraph/op/get_output_element.hpp"
#include "ngraph/op/lrn.hpp"
#include "ngraph/op/max.hpp"
#include "ngraph/op/max_pool.hpp"
#include "ngraph/op/max_pool.hpp"
#include "ngraph/op/min.hpp"
#include "ngraph/op/one_hot.hpp"
#include "ngraph/op/pad.hpp"
#include "ngraph/op/product.hpp"
#include "ngraph/op/product.hpp"
#include "ngraph/op/reduce.hpp"
#include "ngraph/op/reduce_window.hpp"
#include "ngraph/op/reshape.hpp"
#include "ngraph/op/reshape.hpp"
#include "ngraph/op/sum.hpp"
#include "ngraph/op/sum.hpp"
#include "ngraph/util.hpp"
#include "ngraph/util.hpp"
...
@@ -40,6 +51,7 @@ using namespace std;
...
@@ -40,6 +51,7 @@ using namespace std;
enum
class
OP_TYPEID
enum
class
OP_TYPEID
{
{
#include "ngraph/op/op_tbl.hpp"
#include "ngraph/op/op_tbl.hpp"
UNDEFINED_OP
};
};
#undef NGRAPH_OP
#undef NGRAPH_OP
...
@@ -57,13 +69,13 @@ static OP_TYPEID get_typeid(const string& s)
...
@@ -57,13 +69,13 @@ static OP_TYPEID get_typeid(const string& s)
auto
it
=
typeid_map
.
find
(
s
);
auto
it
=
typeid_map
.
find
(
s
);
if
(
it
==
typeid_map
.
end
())
if
(
it
==
typeid_map
.
end
())
{
{
throw
unsupported_op
(
"Unsupported op '"
+
s
+
"'"
)
;
return
OP_TYPEID
::
UNDEFINED_OP
;
}
}
return
it
->
second
;
return
it
->
second
;
}
}
static
const
string
table_begin
=
"<table border=
\"
0
\"
>"
;
static
const
string
table_begin
=
"
\n
<table border=
\"
0
\"
>"
;
static
const
string
table_end
=
"</table>"
;
static
const
string
table_end
=
"
\n
</table>"
;
static
const
string
cell_end
=
"</td>"
;
static
const
string
cell_end
=
"</td>"
;
static
const
string
table_row_end
=
cell_end
+
"</tr>"
;
static
const
string
table_row_end
=
cell_end
+
"</tr>"
;
static
const
string
font_small_begin
=
"<font point-size=
\"
7
\"
>"
;
static
const
string
font_small_begin
=
"<font point-size=
\"
7
\"
>"
;
...
@@ -76,7 +88,25 @@ static string cell_begin(const string& align = string("left"))
...
@@ -76,7 +88,25 @@ static string cell_begin(const string& align = string("left"))
static
string
table_row_begin
(
const
string
&
align
=
string
(
"left"
))
static
string
table_row_begin
(
const
string
&
align
=
string
(
"left"
))
{
{
return
string
(
"<tr>"
)
+
cell_begin
(
align
);
return
string
(
"
\n
<tr>"
)
+
cell_begin
(
align
);
}
template
<
typename
T
>
static
string
print_table_row_dims
(
const
string
&
name
,
const
T
&
shape
)
{
return
table_row_begin
()
+
font_small_begin
+
name
+
vector_to_string
(
shape
)
+
font_end
+
table_row_end
;
}
template
<
typename
T
>
static
string
print_table_row_value
(
const
string
&
name
,
T
val
)
{
stringstream
result
;
result
<<
table_row_begin
()
<<
font_small_begin
<<
name
<<
":"
<<
val
<<
font_end
<<
table_row_end
;
return
result
.
str
();
}
}
void
print_node_parameters
(
ostringstream
&
writer
,
const
shared_ptr
<
Node
>&
node
)
void
print_node_parameters
(
ostringstream
&
writer
,
const
shared_ptr
<
Node
>&
node
)
...
@@ -87,10 +117,8 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
...
@@ -87,10 +117,8 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
{
{
const
shared_ptr
<
op
::
BatchNormTrainingBackprop
>
batch_norm
=
const
shared_ptr
<
op
::
BatchNormTrainingBackprop
>
batch_norm
=
static_pointer_cast
<
op
::
BatchNormTrainingBackprop
>
(
node
);
static_pointer_cast
<
op
::
BatchNormTrainingBackprop
>
(
node
);
const
double
eps
=
batch_norm
->
get_eps_value
();
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"EPS:"
<<
eps
<<
font_end
writer
<<
print_table_row_value
(
"EPS"
,
batch_norm
->
get_eps_value
());
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
BatchNormInference
:
case
OP_TYPEID
:
:
BatchNormInference
:
...
@@ -98,10 +126,8 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
...
@@ -98,10 +126,8 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
{
{
const
shared_ptr
<
op
::
BatchNormBase
>
batch_norm
=
const
shared_ptr
<
op
::
BatchNormBase
>
batch_norm
=
static_pointer_cast
<
op
::
BatchNormBase
>
(
node
);
static_pointer_cast
<
op
::
BatchNormBase
>
(
node
);
const
double
eps
=
batch_norm
->
get_eps_value
();
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"EPS:"
<<
eps
<<
font_end
writer
<<
print_table_row_value
(
"EPS"
,
batch_norm
->
get_eps_value
());
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
GetOutputElement
:
case
OP_TYPEID
:
:
GetOutputElement
:
...
@@ -109,22 +135,17 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
...
@@ -109,22 +135,17 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
const
shared_ptr
<
op
::
GetOutputElement
>
elem
=
const
shared_ptr
<
op
::
GetOutputElement
>
elem
=
static_pointer_cast
<
op
::
GetOutputElement
>
(
node
);
static_pointer_cast
<
op
::
GetOutputElement
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"element:"
<<
elem
->
get_n
()
<<
font_end
writer
<<
print_table_row_value
(
"element"
,
elem
->
get_n
());
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
MaxPool
:
case
OP_TYPEID
:
:
MaxPool
:
{
{
const
shared_ptr
<
op
::
MaxPool
>
max_pool
=
static_pointer_cast
<
op
::
MaxPool
>
(
node
);
const
shared_ptr
<
op
::
MaxPool
>
max_pool
=
static_pointer_cast
<
op
::
MaxPool
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"win_shape"
writer
<<
print_table_row_dims
(
"win_shape"
,
max_pool
->
get_window_shape
())
<<
vector_to_string
(
max_pool
->
get_window_shape
())
<<
font_end
<<
table_row_end
<<
print_table_row_dims
(
"win_strides"
,
max_pool
->
get_window_movement_strides
())
<<
table_row_begin
()
<<
font_small_begin
<<
"win_strides"
<<
print_table_row_dims
(
"pad_above"
,
max_pool
->
get_padding_above
())
<<
vector_to_string
(
max_pool
->
get_window_movement_strides
())
<<
font_end
<<
print_table_row_dims
(
"pad_below"
,
max_pool
->
get_padding_below
());
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_above"
<<
vector_to_string
(
max_pool
->
get_padding_above
())
<<
font_end
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_below"
<<
vector_to_string
(
max_pool
->
get_padding_below
())
<<
font_end
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
MaxPoolBackprop
:
case
OP_TYPEID
:
:
MaxPoolBackprop
:
...
@@ -132,31 +153,22 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
...
@@ -132,31 +153,22 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
const
shared_ptr
<
op
::
MaxPoolBackprop
>
max_pool_b
=
const
shared_ptr
<
op
::
MaxPoolBackprop
>
max_pool_b
=
static_pointer_cast
<
op
::
MaxPoolBackprop
>
(
node
);
static_pointer_cast
<
op
::
MaxPoolBackprop
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"win_shape"
writer
<<
print_table_row_dims
(
"win_shape"
,
max_pool_b
->
get_window_shape
())
<<
vector_to_string
(
max_pool_b
->
get_window_shape
())
<<
font_end
<<
table_row_end
<<
print_table_row_dims
(
"win_strides"
,
max_pool_b
->
get_window_movement_strides
())
<<
table_row_begin
()
<<
font_small_begin
<<
"win_strides"
<<
print_table_row_dims
(
"pad_above"
,
max_pool_b
->
get_padding_above
())
<<
vector_to_string
(
max_pool_b
->
get_window_movement_strides
())
<<
font_end
<<
print_table_row_dims
(
"pad_below"
,
max_pool_b
->
get_padding_below
());
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_above"
<<
vector_to_string
(
max_pool_b
->
get_padding_above
())
<<
font_end
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_below"
<<
vector_to_string
(
max_pool_b
->
get_padding_below
())
<<
font_end
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
AvgPool
:
case
OP_TYPEID
:
:
AvgPool
:
{
{
const
shared_ptr
<
op
::
AvgPool
>
avg_pool
=
static_pointer_cast
<
op
::
AvgPool
>
(
node
);
const
shared_ptr
<
op
::
AvgPool
>
avg_pool
=
static_pointer_cast
<
op
::
AvgPool
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"win_shape"
writer
<<
print_table_row_dims
(
"win_shape"
,
avg_pool
->
get_window_shape
())
<<
vector_to_string
(
avg_pool
->
get_window_shape
())
<<
font_end
<<
table_row_end
<<
print_table_row_dims
(
"win_strides"
,
avg_pool
->
get_window_movement_strides
())
<<
table_row_begin
()
<<
font_small_begin
<<
"win_strides"
<<
print_table_row_dims
(
"pad_above"
,
avg_pool
->
get_padding_above
())
<<
vector_to_string
(
avg_pool
->
get_window_movement_strides
())
<<
font_end
<<
print_table_row_dims
(
"pad_below"
,
avg_pool
->
get_padding_below
())
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_above"
<<
print_table_row_value
(
"pad_included"
,
<<
vector_to_string
(
avg_pool
->
get_padding_above
())
<<
font_end
<<
table_row_end
avg_pool
->
get_include_padding_in_avg_computation
());
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_below"
<<
vector_to_string
(
avg_pool
->
get_padding_below
())
<<
font_end
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_included:"
<<
avg_pool
->
get_include_padding_in_avg_computation
()
<<
font_end
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
AvgPoolBackprop
:
case
OP_TYPEID
:
:
AvgPoolBackprop
:
...
@@ -164,79 +176,196 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
...
@@ -164,79 +176,196 @@ void print_node_parameters(ostringstream& writer, const shared_ptr<Node>& node)
const
shared_ptr
<
op
::
AvgPoolBackprop
>
avg_pool_b
=
const
shared_ptr
<
op
::
AvgPoolBackprop
>
avg_pool_b
=
static_pointer_cast
<
op
::
AvgPoolBackprop
>
(
node
);
static_pointer_cast
<
op
::
AvgPoolBackprop
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"win_shape"
writer
<<
print_table_row_dims
(
"win_shape"
,
avg_pool_b
->
get_window_shape
())
<<
vector_to_string
(
avg_pool_b
->
get_window_shape
())
<<
font_end
<<
table_row_end
<<
print_table_row_dims
(
"win_strides"
,
avg_pool_b
->
get_window_movement_strides
())
<<
table_row_begin
()
<<
font_small_begin
<<
"win_strides"
<<
print_table_row_dims
(
"pad_above"
,
avg_pool_b
->
get_padding_above
())
<<
vector_to_string
(
avg_pool_b
->
get_window_movement_strides
())
<<
font_end
<<
print_table_row_dims
(
"pad_below"
,
avg_pool_b
->
get_padding_below
())
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_above"
<<
print_table_row_value
(
"pad_included"
,
<<
vector_to_string
(
avg_pool_b
->
get_padding_above
())
<<
font_end
<<
table_row_end
avg_pool_b
->
get_include_padding_in_avg_computation
());
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_below"
<<
vector_to_string
(
avg_pool_b
->
get_padding_below
())
<<
font_end
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_included:"
<<
avg_pool_b
->
get_include_padding_in_avg_computation
()
<<
font_end
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
Broadcast
:
case
OP_TYPEID
:
:
Broadcast
:
{
{
const
shared_ptr
<
op
::
Broadcast
>
broadcast
=
static_pointer_cast
<
op
::
Broadcast
>
(
node
);
const
shared_ptr
<
op
::
Broadcast
>
broadcast
=
static_pointer_cast
<
op
::
Broadcast
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"broadcast_axis"
writer
<<
print_table_row_dims
(
"broadcast_axis"
,
broadcast
->
get_broadcast_axes
());
<<
vector_to_string
(
broadcast
->
get_broadcast_axes
())
<<
font_end
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
Max
:
case
OP_TYPEID
:
:
Min
:
case
OP_TYPEID
:
:
Product
:
case
OP_TYPEID
:
:
Sum
:
case
OP_TYPEID
:
:
Sum
:
{
{
const
shared_ptr
<
op
::
Sum
>
sum
=
static_pointer_cast
<
op
::
Sum
>
(
node
);
const
shared_ptr
<
op
::
util
::
ArithmeticReduction
>
arith_op
=
static_pointer_cast
<
op
::
util
::
ArithmeticReduction
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"reduction_axis"
writer
<<
print_table_row_dims
(
"reduction_axis"
,
arith_op
->
get_reduction_axes
());
<<
vector_to_string
(
sum
->
get_reduction_axes
())
<<
font_end
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
Product
:
case
OP_TYPEID
:
:
ArgMin
:
case
OP_TYPEID
:
:
ArgMax
:
{
const
shared_ptr
<
op
::
util
::
IndexReduction
>
arg_op
=
static_pointer_cast
<
op
::
util
::
IndexReduction
>
(
node
);
writer
<<
print_table_row_value
(
"reduction_axis"
,
arg_op
->
get_reduction_axis
())
<<
table_row_begin
()
<<
font_small_begin
<<
"idx_elem_type:"
<<
arg_op
->
get_element_type
()
<<
font_end
<<
table_row_end
;
break
;
}
case
OP_TYPEID
:
:
LRN
:
{
const
shared_ptr
<
op
::
LRN
>
lrn_op
=
static_pointer_cast
<
op
::
LRN
>
(
node
);
writer
<<
print_table_row_value
(
"nsize"
,
lrn_op
->
get_nsize
())
<<
print_table_row_value
(
"bias"
,
lrn_op
->
get_bias
())
<<
print_table_row_value
(
"alpha"
,
lrn_op
->
get_alpha
())
<<
print_table_row_value
(
"beta"
,
lrn_op
->
get_beta
());
break
;
}
case
OP_TYPEID
:
:
OneHot
:
{
const
shared_ptr
<
op
::
OneHot
>
one_hot_op
=
static_pointer_cast
<
op
::
OneHot
>
(
node
);
writer
<<
print_table_row_value
(
"one_hot_axis"
,
one_hot_op
->
get_one_hot_axis
());
break
;
}
case
OP_TYPEID
:
:
Dot
:
{
{
const
shared_ptr
<
op
::
Product
>
prod
=
static_pointer_cast
<
op
::
Produc
t
>
(
node
);
const
shared_ptr
<
op
::
Dot
>
dot_op
=
static_pointer_cast
<
op
::
Do
t
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"reduction_axis"
writer
<<
print_table_row_value
(
"reduction_axes_count"
,
dot_op
->
get_reduction_axes_count
());
<<
vector_to_string
(
prod
->
get_reduction_axes
())
<<
font_end
<<
table_row_end
;
break
;
}
case
OP_TYPEID
:
:
Constant
:
{
size_t
val_id
=
0
;
const
shared_ptr
<
op
::
Constant
>
constant_op
=
static_pointer_cast
<
op
::
Constant
>
(
node
);
const
vector
<
string
>&
values
=
constant_op
->
get_value_strings
();
// let's print no more than 3 items
for
(
auto
it
=
values
.
cbegin
();
(
it
!=
values
.
cend
())
&&
(
val_id
<
3
);
++
it
)
{
writer
<<
print_table_row_value
(
"value["
+
to_string
(
val_id
)
+
"]"
,
*
it
);
++
val_id
;
}
break
;
break
;
}
}
case
OP_TYPEID
:
:
Reshape
:
case
OP_TYPEID
:
:
Reshape
:
{
{
const
shared_ptr
<
op
::
Reshape
>
op_reshape
=
static_pointer_cast
<
op
::
Reshape
>
(
node
);
const
shared_ptr
<
op
::
Reshape
>
op_reshape
=
static_pointer_cast
<
op
::
Reshape
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
writer
<<
print_table_row_dims
(
"broadcast_axes"
,
op_reshape
->
get_input_order
())
<<
"broadcast_axes:"
<<
vector_to_string
(
op_reshape
->
get_input_order
())
<<
font_end
<<
print_table_row_value
(
"transpose"
,
op_reshape
->
get_is_transpose
());
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"transpose:"
<<
op_reshape
->
get_is_transpose
()
<<
font_end
<<
table_row_end
;
break
;
break
;
}
}
case
OP_TYPEID
:
:
Concat
:
case
OP_TYPEID
:
:
Concat
:
{
{
const
shared_ptr
<
op
::
Concat
>
concat_op
=
static_pointer_cast
<
op
::
Concat
>
(
node
);
const
shared_ptr
<
op
::
Concat
>
concat_op
=
static_pointer_cast
<
op
::
Concat
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
writer
<<
print_table_row_value
(
"concat_axis"
,
concat_op
->
get_concatenation_axis
());
<<
"concat_axis:"
<<
concat_op
->
get_concatenation_axis
()
<<
font_end
break
;
<<
table_row_end
;
}
case
OP_TYPEID
:
:
Reduce
:
{
const
shared_ptr
<
op
::
Reduce
>
red_op
=
static_pointer_cast
<
op
::
Reduce
>
(
node
);
const
AxisSet
&
axis
=
red_op
->
get_reduction_axes
();
writer
<<
print_table_row_dims
(
"reduction_axis"
,
red_op
->
get_reduction_axes
())
<<
print_table_row_value
(
"Function:TBD"
,
0
);
break
;
}
case
OP_TYPEID
:
:
ReduceWindow
:
{
const
shared_ptr
<
op
::
ReduceWindow
>
red_win_op
=
static_pointer_cast
<
op
::
ReduceWindow
>
(
node
);
writer
<<
print_table_row_dims
(
"window_shape"
,
red_win_op
->
get_window_shape
())
<<
print_table_row_dims
(
"window_stride"
,
red_win_op
->
get_window_movement_strides
())
<<
print_table_row_value
(
"Function:TBD"
,
0
);
break
;
}
case
OP_TYPEID
:
:
Pad
:
{
const
shared_ptr
<
op
::
Pad
>
pad
=
static_pointer_cast
<
op
::
Pad
>
(
node
);
writer
<<
print_table_row_dims
(
"pad_above"
,
pad
->
get_padding_above
())
<<
print_table_row_dims
(
"pad_below"
,
pad
->
get_padding_below
())
<<
print_table_row_dims
(
"pad_interior"
,
pad
->
get_padding_interior
());
break
;
break
;
}
}
case
OP_TYPEID
:
:
Convolution
:
case
OP_TYPEID
:
:
Convolution
:
{
{
const
shared_ptr
<
op
::
Convolution
>
conv_op
=
static_pointer_cast
<
op
::
Convolution
>
(
node
);
const
shared_ptr
<
op
::
Convolution
>
conv_op
=
static_pointer_cast
<
op
::
Convolution
>
(
node
);
writer
<<
table_row_begin
()
<<
font_small_begin
<<
"win_stride"
writer
<<
print_table_row_dims
(
"win_stride"
,
conv_op
->
get_window_movement_strides
())
<<
vector_to_string
(
conv_op
->
get_window_movement_strides
())
<<
font_end
<<
print_table_row_dims
(
"win_dilation"
,
conv_op
->
get_window_dilation_strides
())
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"win_dilation"
<<
print_table_row_dims
(
"data_dilation"
,
conv_op
->
get_data_dilation_strides
())
<<
vector_to_string
(
conv_op
->
get_window_dilation_strides
())
<<
font_end
<<
print_table_row_dims
(
"pad_above"
,
conv_op
->
get_padding_above
())
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"data_dilation"
<<
print_table_row_dims
(
"pad_below"
,
conv_op
->
get_padding_below
())
<<
vector_to_string
(
conv_op
->
get_data_dilation_strides
())
<<
font_end
<<
print_table_row_dims
(
"def_val"
,
conv_op
->
get_default_value
()
->
get_shape
());
<<
table_row_end
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_below"
break
;
<<
vector_to_string
(
conv_op
->
get_padding_below
())
<<
font_end
<<
table_row_end
}
<<
table_row_begin
()
<<
font_small_begin
<<
"pad_above"
case
OP_TYPEID
:
:
ConvolutionBackpropFilters
:
<<
vector_to_string
(
conv_op
->
get_padding_above
())
<<
font_end
<<
table_row_end
{
<<
table_row_begin
()
<<
font_small_begin
<<
"def_val"
const
shared_ptr
<
op
::
ConvolutionBackpropFilters
>
conv_op_filt
=
<<
vector_to_string
(
conv_op
->
get_default_value
()
->
get_shape
())
<<
font_end
static_pointer_cast
<
op
::
ConvolutionBackpropFilters
>
(
node
);
<<
table_row_end
;
writer
<<
print_table_row_dims
(
"filters_shape"
,
conv_op_filt
->
get_filters_shape
())
<<
print_table_row_dims
(
"window_movement_strides_forward"
,
conv_op_filt
->
get_window_movement_strides_forward
())
<<
print_table_row_dims
(
"window_dilation_strides_forward"
,
conv_op_filt
->
get_window_dilation_strides_forward
())
<<
print_table_row_dims
(
"data_dilation_strides_forward"
,
conv_op_filt
->
get_data_dilation_strides_forward
())
<<
print_table_row_dims
(
"pad_above_forward"
,
conv_op_filt
->
get_padding_above_forward
())
<<
print_table_row_dims
(
"pad_below_forward"
,
conv_op_filt
->
get_padding_below_forward
())
<<
print_table_row_dims
(
"window_movement_strides_backward"
,
conv_op_filt
->
get_window_movement_strides_backward
())
<<
print_table_row_dims
(
"window_dilation_strides_backward"
,
conv_op_filt
->
get_window_dilation_strides_backward
())
<<
print_table_row_dims
(
"data_dilation_strides_backward"
,
conv_op_filt
->
get_data_dilation_strides_backward
())
<<
print_table_row_dims
(
"padding_above_backward"
,
conv_op_filt
->
get_padding_above_backward
())
<<
print_table_row_dims
(
"padding_below_backward"
,
conv_op_filt
->
get_padding_below_backward
());
break
;
}
case
OP_TYPEID
:
:
ConvolutionBackpropData
:
{
const
shared_ptr
<
op
::
ConvolutionBackpropData
>
conv_op_data
=
static_pointer_cast
<
op
::
ConvolutionBackpropData
>
(
node
);
writer
<<
print_table_row_dims
(
"data_batch_shape"
,
conv_op_data
->
get_data_batch_shape
())
<<
print_table_row_dims
(
"window_movement_strides_forward"
,
conv_op_data
->
get_window_movement_strides_forward
())
<<
print_table_row_dims
(
"window_dilation_strides_forward"
,
conv_op_data
->
get_window_dilation_strides_forward
())
<<
print_table_row_dims
(
"data_dilation_strides_forward"
,
conv_op_data
->
get_data_dilation_strides_forward
())
<<
print_table_row_dims
(
"pad_above_forward"
,
conv_op_data
->
get_padding_above_forward
())
<<
print_table_row_dims
(
"pad_below_forward"
,
conv_op_data
->
get_padding_below_forward
())
<<
print_table_row_dims
(
"window_movement_strides_backward"
,
conv_op_data
->
get_window_movement_strides_backward
())
<<
print_table_row_dims
(
"window_dilation_strides_backward"
,
conv_op_data
->
get_window_dilation_strides_backward
())
<<
print_table_row_dims
(
"data_dilation_strides_backward"
,
conv_op_data
->
get_data_dilation_strides_backward
())
<<
print_table_row_dims
(
"padding_above_backward"
,
conv_op_data
->
get_padding_above_backward
())
<<
print_table_row_dims
(
"padding_below_backward"
,
conv_op_data
->
get_padding_below_backward
());
break
;
}
case
OP_TYPEID
:
:
UNDEFINED_OP
:
default
:
{
;
// Some operations are not defined in ngraph/op/op_tbl.hpp
}
}
}
}
}
}
...
@@ -290,7 +419,7 @@ void print_node(ostringstream& writer, const shared_ptr<Node>& node)
...
@@ -290,7 +419,7 @@ void print_node(ostringstream& writer, const shared_ptr<Node>& node)
print_node_parameters
(
writer
,
node
);
print_node_parameters
(
writer
,
node
);
writer
<<
table_end
;
writer
<<
table_end
;
writer
<<
" >]
\n
"
;
writer
<<
" >]
;
\n
"
;
}
}
void
runtime
::
intelgpu
::
visualize_tree
(
const
shared_ptr
<
Function
>&
func
,
void
runtime
::
intelgpu
::
visualize_tree
(
const
shared_ptr
<
Function
>&
func
,
...
@@ -301,7 +430,7 @@ void runtime::intelgpu::visualize_tree(const shared_ptr<Function>& func,
...
@@ -301,7 +430,7 @@ void runtime::intelgpu::visualize_tree(const shared_ptr<Function>& func,
ostringstream
writer
;
ostringstream
writer
;
// Begin of the main graph
// Begin of the main graph
writer
<<
"digraph ngraph
\n
{
\n
"
;
writer
<<
"digraph ngraph
\n
{
\n
splines=
\"
line
\"
;
\n\n
"
;
for
(
const
shared_ptr
<
Node
>
op
:
func
->
get_ordered_ops
())
for
(
const
shared_ptr
<
Node
>
op
:
func
->
get_ordered_ops
())
{
{
...
@@ -324,7 +453,7 @@ void runtime::intelgpu::visualize_tree(const shared_ptr<Function>& func,
...
@@ -324,7 +453,7 @@ void runtime::intelgpu::visualize_tree(const shared_ptr<Function>& func,
}
}
// print summary with operations used
// print summary with operations used
writer
<<
"subgraph clusterFooter
\n
{
\n
margin=0
\n
style=
\"
invis
\"\n
LEGEND ["
writer
<<
"
\n
subgraph clusterFooter
\n
{
\n
margin=0
\n
style=
\"
invis
\"\n
LEGEND ["
<<
"shape=box style=filled fillcolor=gray margin=0 label=<"
<<
table_begin
<<
"shape=box style=filled fillcolor=gray margin=0 label=<"
<<
table_begin
<<
table_row_begin
(
"center"
)
<<
"Operations summary"
<<
table_row_end
;
<<
table_row_begin
(
"center"
)
<<
"Operations summary"
<<
table_row_end
;
size_t
total_op_count
=
0
;
size_t
total_op_count
=
0
;
...
@@ -336,7 +465,7 @@ void runtime::intelgpu::visualize_tree(const shared_ptr<Function>& func,
...
@@ -336,7 +465,7 @@ void runtime::intelgpu::visualize_tree(const shared_ptr<Function>& func,
total_op_count
+=
it
.
second
;
total_op_count
+=
it
.
second
;
}
}
writer
<<
table_row_begin
()
<<
"Total:"
<<
cell_end
<<
cell_begin
()
<<
total_op_count
writer
<<
table_row_begin
()
<<
"Total:"
<<
cell_end
<<
cell_begin
()
<<
total_op_count
<<
table_row_end
<<
table_end
<<
"
>]
\n
}
\n
"
;
<<
table_row_end
<<
table_end
<<
"
\n
>];
\n
}
\n
"
;
// End of the main graph
// End of the main graph
writer
<<
"}
\n
"
;
writer
<<
"}
\n
"
;
...
...
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