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
3da93e51
Unverified
Commit
3da93e51
authored
Aug 14, 2019
by
Scott Cyphers
Committed by
GitHub
Aug 14, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Eradicate get_argument in op implementations (#3441)
parent
17f6e08c
Show whitespace changes
Inline
Side-by-side
Showing
83 changed files
with
238 additions
and
217 deletions
+238
-217
node.hpp
src/ngraph/node.hpp
+22
-0
abs.cpp
src/ngraph/op/abs.cpp
+1
-1
acos.cpp
src/ngraph/op/acos.cpp
+1
-1
add.cpp
src/ngraph/op/add.cpp
+2
-2
asin.cpp
src/ngraph/op/asin.cpp
+4
-4
atan.cpp
src/ngraph/op/atan.cpp
+4
-4
avg_pool.cpp
src/ngraph/op/avg_pool.cpp
+1
-1
batch_norm.cpp
src/ngraph/op/batch_norm.cpp
+3
-3
broadcast.cpp
src/ngraph/op/broadcast.cpp
+1
-1
concat.cpp
src/ngraph/op/concat.cpp
+3
-3
convert.cpp
src/ngraph/op/convert.cpp
+2
-2
convolution.cpp
src/ngraph/op/convolution.cpp
+8
-8
cos.cpp
src/ngraph/op/cos.cpp
+1
-1
cosh.cpp
src/ngraph/op/cosh.cpp
+1
-1
divide.cpp
src/ngraph/op/divide.cpp
+2
-2
dot.cpp
src/ngraph/op/dot.cpp
+4
-4
exp.cpp
src/ngraph/op/exp.cpp
+1
-1
batch_mat_mul.cpp
src/ngraph/op/experimental/batch_mat_mul.cpp
+6
-6
compiled_kernel.cpp
src/ngraph/op/experimental/compiled_kernel.cpp
+4
-5
dyn_broadcast.cpp
src/ngraph/op/experimental/dyn_broadcast.cpp
+4
-6
dyn_replace_slice.cpp
src/ngraph/op/experimental/dyn_replace_slice.cpp
+3
-3
dyn_reshape.cpp
src/ngraph/op/experimental/dyn_reshape.cpp
+1
-1
dyn_slice.cpp
src/ngraph/op/experimental/dyn_slice.cpp
+3
-3
quantized_avg_pool.cpp
src/ngraph/op/experimental/quantized_avg_pool.cpp
+1
-1
quantized_conv_bias.hpp
src/ngraph/op/experimental/quantized_conv_bias.hpp
+9
-9
quantized_conv_relu.hpp
src/ngraph/op/experimental/quantized_conv_relu.hpp
+2
-2
range.cpp
src/ngraph/op/experimental/range.cpp
+6
-3
tile.cpp
src/ngraph/op/experimental/tile.cpp
+2
-1
transpose.cpp
src/ngraph/op/experimental/transpose.cpp
+2
-1
clamp.cpp
src/ngraph/op/fused/clamp.cpp
+1
-1
conv_fused.cpp
src/ngraph/op/fused/conv_fused.cpp
+19
-21
conv_fused.hpp
src/ngraph/op/fused/conv_fused.hpp
+5
-5
depth_to_space.cpp
src/ngraph/op/fused/depth_to_space.cpp
+1
-1
elu.cpp
src/ngraph/op/fused/elu.cpp
+2
-2
fake_quantize.cpp
src/ngraph/op/fused/fake_quantize.cpp
+5
-5
gelu.cpp
src/ngraph/op/fused/gelu.cpp
+1
-1
gemm.cpp
src/ngraph/op/fused/gemm.cpp
+3
-3
grn.cpp
src/ngraph/op/fused/grn.cpp
+1
-1
group_conv.cpp
src/ngraph/op/fused/group_conv.cpp
+5
-5
group_conv.hpp
src/ngraph/op/fused/group_conv.hpp
+2
-2
group_conv_transpose.cpp
src/ngraph/op/fused/group_conv_transpose.cpp
+2
-2
group_conv_transpose.hpp
src/ngraph/op/fused/group_conv_transpose.hpp
+2
-2
gru_cell.cpp
src/ngraph/op/fused/gru_cell.cpp
+5
-5
hard_sigmoid.cpp
src/ngraph/op/fused/hard_sigmoid.cpp
+1
-1
lstm_cell.cpp
src/ngraph/op/fused/lstm_cell.cpp
+7
-7
mvn.cpp
src/ngraph/op/fused/mvn.cpp
+1
-1
normalize.cpp
src/ngraph/op/fused/normalize.cpp
+2
-2
prelu.cpp
src/ngraph/op/fused/prelu.cpp
+2
-2
rnn_cell.cpp
src/ngraph/op/fused/rnn_cell.cpp
+5
-5
scale_shift.cpp
src/ngraph/op/fused/scale_shift.cpp
+3
-3
shuffle_channels.cpp
src/ngraph/op/fused/shuffle_channels.cpp
+1
-1
space_to_depth.cpp
src/ngraph/op/fused/space_to_depth.cpp
+1
-1
split.cpp
src/ngraph/op/fused/split.cpp
+1
-1
squared_difference.cpp
src/ngraph/op/fused/squared_difference.cpp
+2
-2
squeeze.cpp
src/ngraph/op/fused/squeeze.cpp
+2
-2
unsqueeze.cpp
src/ngraph/op/fused/unsqueeze.cpp
+3
-3
get_output_element.cpp
src/ngraph/op/get_output_element.cpp
+4
-4
log.cpp
src/ngraph/op/log.cpp
+1
-1
max_pool.cpp
src/ngraph/op/max_pool.cpp
+1
-1
maximum.cpp
src/ngraph/op/maximum.cpp
+4
-4
minimum.cpp
src/ngraph/op/minimum.cpp
+4
-4
multiply.cpp
src/ngraph/op/multiply.cpp
+2
-2
negative.cpp
src/ngraph/op/negative.cpp
+1
-1
pad.cpp
src/ngraph/op/pad.cpp
+1
-1
power.cpp
src/ngraph/op/power.cpp
+2
-2
relu.cpp
src/ngraph/op/relu.cpp
+1
-1
replace_slice.cpp
src/ngraph/op/replace_slice.cpp
+4
-4
reshape.cpp
src/ngraph/op/reshape.cpp
+1
-1
result.cpp
src/ngraph/op/result.cpp
+2
-2
reverse.cpp
src/ngraph/op/reverse.cpp
+1
-1
reverse_sequence.cpp
src/ngraph/op/reverse_sequence.cpp
+3
-3
select.cpp
src/ngraph/op/select.cpp
+3
-3
sigmoid.cpp
src/ngraph/op/sigmoid.cpp
+2
-2
sin.cpp
src/ngraph/op/sin.cpp
+1
-1
sinh.cpp
src/ngraph/op/sinh.cpp
+1
-1
slice.cpp
src/ngraph/op/slice.cpp
+1
-1
softmax.cpp
src/ngraph/op/softmax.cpp
+1
-1
sqrt.cpp
src/ngraph/op/sqrt.cpp
+1
-1
subtract.cpp
src/ngraph/op/subtract.cpp
+2
-2
sum.cpp
src/ngraph/op/sum.cpp
+2
-2
tan.cpp
src/ngraph/op/tan.cpp
+1
-1
tanh.cpp
src/ngraph/op/tanh.cpp
+1
-1
topk.cpp
src/ngraph/op/topk.cpp
+1
-2
No files found.
src/ngraph/node.hpp
View file @
3da93e51
...
...
@@ -389,6 +389,9 @@ namespace ngraph
/// \return A vector containing a handle for each of this node's inputs, in order.
std
::
vector
<
Input
<
const
Node
>>
inputs
()
const
;
/// \return A vector containing the values for each input
std
::
vector
<
Output
<
Node
>>
input_values
()
const
;
/// \return A vector containing a handle for each of this node's outputs, in order.
// TODO: Rename to get_outputs()?
std
::
vector
<
Output
<
Node
>>
outputs
();
...
...
@@ -404,6 +407,8 @@ namespace ngraph
/// \throw std::out_of_range if the node does not have at least `input_index+1` inputs.
Input
<
const
Node
>
input
(
size_t
input_index
)
const
;
Output
<
Node
>
input_value
(
size_t
input_index
)
const
;
/// \return A handle to the `output_index`th output of this node.
/// \throw std::out_of_range if the node does not have at least `output_index+1` outputs.
Output
<
Node
>
output
(
size_t
output_index
);
...
...
@@ -629,6 +634,11 @@ namespace ngraph
return
Input
<
Node
>
(
this
,
input_index
);
}
inline
Output
<
Node
>
Node
::
input_value
(
size_t
input_index
)
const
{
return
input
(
input_index
).
get_source_output
();
}
inline
Input
<
const
Node
>
Node
::
input
(
size_t
input_index
)
const
{
if
(
input_index
>=
m_inputs
.
size
())
...
...
@@ -705,6 +715,18 @@ namespace ngraph
return
result
;
}
inline
std
::
vector
<
Output
<
Node
>>
Node
::
input_values
()
const
{
std
::
vector
<
Output
<
Node
>>
result
;
for
(
size_t
i
=
0
;
i
<
get_input_size
();
i
++
)
{
result
.
emplace_back
(
input
(
i
).
get_source_output
());
}
return
result
;
}
inline
std
::
vector
<
Input
<
const
Node
>>
Node
::
inputs
()
const
{
std
::
vector
<
Input
<
const
Node
>>
result
;
...
...
src/ngraph/op/abs.cpp
View file @
3da93e51
...
...
@@ -39,7 +39,7 @@ void op::Abs::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
*
make_shared
<
op
::
Sign
>
(
x
));
}
src/ngraph/op/acos.cpp
View file @
3da93e51
...
...
@@ -48,7 +48,7 @@ void op::Acos::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
auto
one
=
make_shared
<
op
::
ScalarConstantLike
>
(
x
,
1.0
);
auto
ones
=
make_shared
<
op
::
BroadcastLike
>
(
one
,
x
,
AxisSet
());
...
...
src/ngraph/op/add.cpp
View file @
3da93e51
...
...
@@ -42,8 +42,8 @@ void op::Add::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
adjoints
.
add_delta
(
x
,
delta
);
adjoints
.
add_delta
(
y
,
delta
);
...
...
src/ngraph/op/asin.cpp
View file @
3da93e51
...
...
@@ -49,14 +49,14 @@ void op::Asin::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
auto
one
=
make_shared
<
op
::
Constant
>
(
x
->
get_element_type
(),
Shape
{},
vector
<
string
>
{
"1"
});
auto
one
=
make_shared
<
op
::
Constant
>
(
x
.
get_element_type
(),
Shape
{},
vector
<
string
>
{
"1"
});
AxisSet
axes
;
for
(
size_t
i
=
0
;
i
<
x
->
get_shape
().
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
x
.
get_shape
().
size
();
i
++
)
axes
.
insert
(
i
);
auto
ones
=
make_shared
<
op
::
Broadcast
>
(
one
,
x
->
get_shape
(),
axes
);
auto
ones
=
make_shared
<
op
::
Broadcast
>
(
one
,
x
.
get_shape
(),
axes
);
adjoints
.
add_delta
(
x
,
delta
/
make_shared
<
op
::
Sqrt
>
(
ones
-
x
*
x
));
}
src/ngraph/op/atan.cpp
View file @
3da93e51
...
...
@@ -48,14 +48,14 @@ void op::Atan::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
auto
one
=
make_shared
<
op
::
Constant
>
(
x
->
get_element_type
(),
Shape
{},
vector
<
string
>
{
"1"
});
auto
one
=
make_shared
<
op
::
Constant
>
(
x
.
get_element_type
(),
Shape
{},
vector
<
string
>
{
"1"
});
AxisSet
axes
;
for
(
size_t
i
=
0
;
i
<
x
->
get_shape
().
size
();
i
++
)
for
(
size_t
i
=
0
;
i
<
x
.
get_shape
().
size
();
i
++
)
axes
.
insert
(
i
);
auto
ones
=
make_shared
<
op
::
Broadcast
>
(
one
,
x
->
get_shape
(),
axes
);
auto
ones
=
make_shared
<
op
::
Broadcast
>
(
one
,
x
.
get_shape
(),
axes
);
adjoints
.
add_delta
(
x
,
delta
/
(
ones
+
x
*
x
));
}
src/ngraph/op/avg_pool.cpp
View file @
3da93e51
...
...
@@ -361,7 +361,7 @@ void op::AvgPool::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
auto
delta
=
deltas
.
at
(
0
);
auto
operand
=
get_argument
(
0
);
auto
operand
=
input_value
(
0
);
auto
&
operand_shape
=
get_input_shape
(
0
);
auto
backprop
=
make_shared
<
op
::
AvgPoolBackprop
>
(
operand_shape
,
delta
,
...
...
src/ngraph/op/batch_norm.cpp
View file @
3da93e51
...
...
@@ -77,9 +77,9 @@ std::shared_ptr<Node> op::BatchNormTraining::copy_with_new_args(const NodeVector
void
op
::
BatchNormTraining
::
generate_adjoints
(
autodiff
::
Adjoints
&
adjoints
,
const
NodeVector
&
deltas
)
{
auto
gamma
=
input
(
0
).
get_source_output
(
);
auto
beta
=
input
(
1
).
get_source_output
(
);
auto
data
=
input
(
2
).
get_source_output
(
);
auto
gamma
=
input
_value
(
0
);
auto
beta
=
input
_value
(
1
);
auto
data
=
input
_value
(
2
);
// Extract mean and variance outputs from BatchNormBase
// as these are used by BatchNormTrainingBackprop.
...
...
src/ngraph/op/broadcast.cpp
View file @
3da93e51
...
...
@@ -90,7 +90,7 @@ void op::Broadcast::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVe
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
make_shared
<
op
::
Sum
>
(
delta
,
m_broadcast_axes
));
}
...
...
src/ngraph/op/concat.cpp
View file @
3da93e51
...
...
@@ -111,9 +111,9 @@ void op::Concat::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVecto
size_t
pos
=
0
;
for
(
auto
input
:
input
s
())
for
(
auto
value
:
input_value
s
())
{
auto
arg_shape
=
input
.
get_shape
();
auto
arg_shape
=
value
.
get_shape
();
auto
slice_width
=
arg_shape
[
m_concatenation_axis
];
...
...
@@ -123,7 +123,7 @@ void op::Concat::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVecto
arg_delta_slice_upper
[
m_concatenation_axis
]
=
next_pos
;
adjoints
.
add_delta
(
input
.
get_source_output
()
,
value
,
make_shared
<
op
::
Slice
>
(
delta
,
arg_delta_slice_lower
,
arg_delta_slice_upper
,
arg_delta_slice_strides
));
...
...
src/ngraph/op/convert.cpp
View file @
3da93e51
...
...
@@ -45,7 +45,7 @@ void op::Convert::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
make_shared
<
op
::
Convert
>
(
delta
,
x
->
get_element_type
()));
adjoints
.
add_delta
(
x
,
make_shared
<
op
::
Convert
>
(
delta
,
x
.
get_element_type
()));
}
src/ngraph/op/convolution.cpp
View file @
3da93e51
...
...
@@ -184,11 +184,11 @@ void op::Convolution::generate_adjoints(autodiff::Adjoints& adjoints, const Node
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
const
auto
x_shape
=
x
->
get_shape
();
auto
x
=
input_value
(
0
);
const
auto
x_shape
=
x
.
get_shape
();
auto
f
=
get_argument
(
1
);
const
auto
f_shape
=
f
->
get_shape
();
auto
f
=
input_value
(
1
);
const
auto
f_shape
=
f
.
get_shape
();
adjoints
.
add_delta
(
x
,
make_shared
<
op
::
ConvolutionBackpropData
>
(
x_shape
,
...
...
@@ -300,11 +300,11 @@ void op::ConvolutionBackpropData::generate_adjoints(autodiff::Adjoints& adjoints
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
1
);
const
auto
x_shape
=
x
->
get_shape
();
auto
x
=
input_value
(
1
);
const
auto
x_shape
=
x
.
get_shape
();
auto
f
=
get_argument
(
0
);
const
auto
f_shape
=
f
->
get_shape
();
auto
f
=
input_value
(
0
);
const
auto
f_shape
=
f
.
get_shape
();
auto
data_conv
=
make_shared
<
op
::
Convolution
>
(
delta
,
f
,
...
...
src/ngraph/op/cos.cpp
View file @
3da93e51
...
...
@@ -40,7 +40,7 @@ void op::Cos::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
-
delta
*
(
make_shared
<
op
::
Sin
>
(
x
)));
}
src/ngraph/op/cosh.cpp
View file @
3da93e51
...
...
@@ -39,7 +39,7 @@ void op::Cosh::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
*
(
make_shared
<
op
::
Sinh
>
(
x
)));
}
src/ngraph/op/divide.cpp
View file @
3da93e51
...
...
@@ -57,8 +57,8 @@ void op::Divide::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVecto
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
adjoints
.
add_delta
(
x
,
delta
/
y
);
adjoints
.
add_delta
(
y
,
-
delta
*
shared_from_this
()
/
y
);
...
...
src/ngraph/op/dot.cpp
View file @
3da93e51
...
...
@@ -179,11 +179,11 @@ void op::Dot::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
auto
x_shape
=
x
->
get_shape
();
// shape IJ
auto
y_shape
=
y
->
get_shape
();
// shape JK
auto
x_shape
=
x
.
get_shape
();
// shape IJ
auto
y_shape
=
y
.
get_shape
();
// shape JK
auto
delta_shape
=
delta
->
get_shape
();
// shape IK
Shape
I_shape
;
...
...
src/ngraph/op/exp.cpp
View file @
3da93e51
...
...
@@ -38,7 +38,7 @@ void op::Exp::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
*
shared_from_this
());
}
src/ngraph/op/experimental/batch_mat_mul.cpp
View file @
3da93e51
...
...
@@ -81,15 +81,15 @@ void op::BatchMatMul::generate_adjoints(autodiff::Adjoints& adjoints, const Node
{
auto
delta
=
deltas
.
at
(
0
);
// NxIxK
auto
arg0
=
get_argument
(
0
);
// NxIxJ
auto
arg1
=
get_argument
(
1
);
// NxJxK
auto
arg0
=
input_value
(
0
);
// NxIxJ
auto
arg1
=
input_value
(
1
);
// NxJxK
auto
delta_dot_arg1
=
make_shared
<
op
::
BatchMatMul
>
(
delta
,
util
::
batch_mat_transpose
(
arg1
));
// IK.KJ->IJ
auto
delta_dot_arg1
=
make_shared
<
op
::
BatchMatMul
>
(
delta
,
util
::
batch_mat_transpose
(
arg1
.
get_node_shared_ptr
()
));
// IK.KJ->IJ
adjoints
.
add_delta
(
arg0
,
delta_dot_arg1
);
auto
arg0_dot_delta
=
make_shared
<
BatchMatMul
>
(
util
::
batch_mat_transpose
(
arg0
),
delta
);
// JI.IK->JK
auto
arg0_dot_delta
=
make_shared
<
BatchMatMul
>
(
util
::
batch_mat_transpose
(
arg0
.
get_node_shared_ptr
()
),
delta
);
// JI.IK->JK
adjoints
.
add_delta
(
arg1
,
arg0_dot_delta
);
}
...
...
src/ngraph/op/experimental/compiled_kernel.cpp
View file @
3da93e51
...
...
@@ -26,7 +26,7 @@ const string op::CompiledKernel::type_name{"CompiledKernel"};
shared_ptr
<
Node
>
ngraph
::
op
::
CompiledKernel
::
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
{
auto
args
=
inputs
();
auto
args
=
input
_value
s
();
if
(
new_args
.
size
()
!=
args
.
size
())
{
throw
ngraph_error
(
"number of arguments don't match"
);
...
...
@@ -36,17 +36,16 @@ shared_ptr<Node> ngraph::op::CompiledKernel::copy_with_new_args(const NodeVector
NodeMap
nm
;
for
(
size_t
i
=
0
;
i
<
args
.
size
();
i
++
)
{
nm
[
args
.
at
(
i
).
get_
source_output
().
get_
node
()]
=
new_args
.
at
(
i
);
nm
[
args
.
at
(
i
).
get_node
()]
=
new_args
.
at
(
i
);
}
NodeVector
new_node_list
;
for
(
auto
n
:
m_node_list
)
{
OutputVector
cur_args
;
for
(
auto
a
:
n
->
inputs
())
for
(
auto
a
:
n
->
input
_value
s
())
{
auto
o
=
a
.
get_source_output
();
cur_args
.
push_back
(
o
.
for_node
(
nm
.
at
(
o
.
get_node
())));
cur_args
.
push_back
(
a
.
for_node
(
nm
.
at
(
a
.
get_node
())));
}
auto
new_n
=
n
->
copy_with_new_inputs
(
cur_args
);
nm
[
n
.
get
()]
=
new_n
;
...
...
src/ngraph/op/experimental/dyn_broadcast.cpp
View file @
3da93e51
...
...
@@ -63,20 +63,18 @@ void op::DynBroadcast::validate_and_infer_types()
axes_shape_rank
);
PartialShape
result_shape
{
PartialShape
::
dynamic
()};
if
(
input
(
1
).
get_source_output
(
).
get_node_shared_ptr
()
->
is_constant
())
if
(
input
_value
(
1
).
get_node_shared_ptr
()
->
is_constant
())
{
result_shape
=
static_pointer_cast
<
op
::
Constant
>
(
input
(
1
).
get_source_output
().
get_node_shared_ptr
())
result_shape
=
static_pointer_cast
<
op
::
Constant
>
(
input_value
(
1
).
get_node_shared_ptr
())
->
get_shape_val
();
}
bool
axes_known
=
false
;
AxisSet
broadcast_axes
;
if
(
input
(
2
).
get_source_output
(
).
get_node_shared_ptr
()
->
is_constant
())
if
(
input
_value
(
2
).
get_node_shared_ptr
()
->
is_constant
())
{
axes_known
=
true
;
broadcast_axes
=
static_pointer_cast
<
op
::
Constant
>
(
input
(
2
).
get_source_output
().
get_node_shared_ptr
())
broadcast_axes
=
static_pointer_cast
<
op
::
Constant
>
(
input_value
(
2
).
get_node_shared_ptr
())
->
get_axis_set_val
();
}
...
...
src/ngraph/op/experimental/dyn_replace_slice.cpp
View file @
3da93e51
...
...
@@ -107,9 +107,9 @@ void op::DynReplaceSlice::validate_and_infer_types()
set_input_is_relevant_to_shape
(
3
);
set_input_is_relevant_to_shape
(
4
);
auto
lower_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
2
));
auto
upper_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
3
));
auto
strides
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
4
));
auto
lower_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
2
).
get_node_shared_ptr
(
));
auto
upper_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
3
).
get_node_shared_ptr
(
));
auto
strides
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
4
).
get_node_shared_ptr
(
));
// TODO(amprocte): We can get a bit more information here about the ranks of arg and
// replacement by inspecting the attributes.
...
...
src/ngraph/op/experimental/dyn_reshape.cpp
View file @
3da93e51
...
...
@@ -50,7 +50,7 @@ void op::DynReshape::validate_and_infer_types()
set_input_is_relevant_to_shape
(
1
);
if
(
auto
const_shape
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
1
)))
if
(
auto
const_shape
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
1
).
get_node_shared_ptr
(
)))
{
std
::
vector
<
int64_t
>
out_shape_val
=
const_shape
->
get_vector
<
int64_t
>
();
NODE_VALIDATION_CHECK
(
this
,
...
...
src/ngraph/op/experimental/dyn_slice.cpp
View file @
3da93e51
...
...
@@ -86,9 +86,9 @@ void op::DynSlice::validate_and_infer_types()
set_input_is_relevant_to_shape
(
2
);
set_input_is_relevant_to_shape
(
3
);
auto
lower_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
1
));
auto
upper_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
2
));
auto
strides
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
3
));
auto
lower_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
1
).
get_node_shared_ptr
(
));
auto
upper_bounds
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
2
).
get_node_shared_ptr
(
));
auto
strides
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
3
).
get_node_shared_ptr
(
));
if
(
lower_bounds
&&
upper_bounds
&&
strides
)
{
...
...
src/ngraph/op/experimental/quantized_avg_pool.cpp
View file @
3da93e51
...
...
@@ -40,7 +40,7 @@ op::QuantizedAvgPool::QuantizedAvgPool(const Output<Node>& arg,
void
op
::
QuantizedAvgPool
::
validate_and_infer_types
()
{
auto
arg
(
input
(
0
).
get_source_output
(
));
auto
arg
(
input
_value
(
0
));
if
(
arg
.
get_element_type
()
!=
element
::
u8
&&
arg
.
get_element_type
()
!=
element
::
i8
)
{
throw
ngraph_error
(
"QuantizedAvgPool supported only for i8/u8!"
);
...
...
src/ngraph/op/experimental/quantized_conv_bias.hpp
View file @
3da93e51
...
...
@@ -47,9 +47,9 @@ namespace ngraph
const
CoordinateDiff
&
get_padding_below
()
const
{
return
m_padding_below
;
}
const
CoordinateDiff
&
get_padding_above
()
const
{
return
m_padding_above
;
}
const
Strides
&
get_data_dilation_strides
()
const
{
return
m_data_dilation_strides
;
}
Output
<
Node
>
get_bias
()
{
return
input
(
2
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_bias
()
{
return
input
_value
(
2
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
_value
(
0
);
}
bool
with_relu
()
const
{
return
m_with_relu
;
}
virtual
std
::
shared_ptr
<
Node
>
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
override
;
...
...
@@ -87,9 +87,9 @@ namespace ngraph
const
CoordinateDiff
&
get_padding_below
()
const
{
return
m_padding_below
;
}
const
CoordinateDiff
&
get_padding_above
()
const
{
return
m_padding_above
;
}
const
Strides
&
get_data_dilation_strides
()
const
{
return
m_data_dilation_strides
;
}
Output
<
Node
>
get_bias
()
{
return
input
(
2
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_bias
()
{
return
input
_value
(
2
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
_value
(
0
);
}
bool
with_relu
()
const
{
return
m_with_relu
;
}
virtual
std
::
shared_ptr
<
Node
>
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
override
;
...
...
@@ -127,9 +127,9 @@ namespace ngraph
const
CoordinateDiff
&
get_padding_below
()
const
{
return
m_padding_below
;
}
const
CoordinateDiff
&
get_padding_above
()
const
{
return
m_padding_above
;
}
const
Strides
&
get_data_dilation_strides
()
const
{
return
m_data_dilation_strides
;
}
Output
<
Node
>
get_bias
()
{
return
input
(
2
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_bias
()
{
return
input
_value
(
2
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
_value
(
0
);
}
bool
with_relu
()
const
{
return
m_with_relu
;
}
virtual
std
::
shared_ptr
<
Node
>
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
override
;
...
...
src/ngraph/op/experimental/quantized_conv_relu.hpp
View file @
3da93e51
...
...
@@ -45,8 +45,8 @@ namespace ngraph
const
CoordinateDiff
&
get_padding_below
()
const
{
return
m_padding_below
;
}
const
CoordinateDiff
&
get_padding_above
()
const
{
return
m_padding_above
;
}
const
Strides
&
get_data_dilation_strides
()
const
{
return
m_data_dilation_strides
;
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
_value
(
0
);
}
bool
with_relu
()
const
{
return
true
;
}
virtual
std
::
shared_ptr
<
Node
>
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
override
;
...
...
src/ngraph/op/experimental/range.cpp
View file @
3da93e51
...
...
@@ -123,9 +123,12 @@ static
template
<
typename
T
>
static
PartialShape
infer_output_shape
(
const
op
::
Range
*
node
,
const
element
::
Type
&
et
)
{
auto
const_start
=
dynamic_pointer_cast
<
op
::
Constant
>
(
node
->
get_argument
(
0
));
auto
const_stop
=
dynamic_pointer_cast
<
op
::
Constant
>
(
node
->
get_argument
(
1
));
auto
const_step
=
dynamic_pointer_cast
<
op
::
Constant
>
(
node
->
get_argument
(
2
));
auto
const_start
=
dynamic_pointer_cast
<
op
::
Constant
>
(
node
->
input_value
(
0
).
get_node_shared_ptr
());
auto
const_stop
=
dynamic_pointer_cast
<
op
::
Constant
>
(
node
->
input_value
(
1
).
get_node_shared_ptr
());
auto
const_step
=
dynamic_pointer_cast
<
op
::
Constant
>
(
node
->
input_value
(
2
).
get_node_shared_ptr
());
T
start
=
static_cast
<
T
>
(
0
);
T
stop
=
static_cast
<
T
>
(
0
);
...
...
src/ngraph/op/experimental/tile.cpp
View file @
3da93e51
...
...
@@ -60,7 +60,8 @@ void op::Tile::validate_and_infer_types()
auto
out_shape
=
PartialShape
::
dynamic
(
output_rank
);
if
(
auto
const_repeats
=
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
1
)))
if
(
auto
const_repeats
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
1
).
get_node_shared_ptr
()))
{
if
(
arg_shape
.
is_static
())
{
...
...
src/ngraph/op/experimental/transpose.cpp
View file @
3da93e51
...
...
@@ -47,7 +47,8 @@ void op::Transpose::validate_and_infer_types()
set_input_is_relevant_to_shape
(
1
);
if
(
auto
input_const
=
std
::
dynamic_pointer_cast
<
op
::
Constant
>
(
get_argument
(
1
)))
if
(
auto
input_const
=
std
::
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
1
).
get_node_shared_ptr
()))
{
auto
permutation
=
input_const
->
get_axis_vector_val
();
NODE_VALIDATION_CHECK
(
this
,
...
...
src/ngraph/op/fused/clamp.cpp
View file @
3da93e51
...
...
@@ -40,7 +40,7 @@ void op::Clamp::pre_validate_and_infer_types()
NodeVector
op
::
Clamp
::
decompose_op
()
const
{
const
auto
data
=
input
(
0
).
get_source_output
(
);
const
auto
data
=
input
_value
(
0
);
const
auto
data_shape
=
data
.
get_shape
();
const
auto
clamp_min
=
builder
::
make_constant
(
data
.
get_element_type
(),
data_shape
,
m_min
);
...
...
src/ngraph/op/fused/conv_fused.cpp
View file @
3da93e51
...
...
@@ -91,8 +91,8 @@ op::ConvolutionBias::ConvolutionBias(const Output<Node>& data_batch,
op
::
ConvolutionBias
::
ConvolutionBias
(
const
shared_ptr
<
op
::
Convolution
>&
conv
,
const
Output
<
Node
>&
bias
,
const
bool
with_relu
)
:
ConvolutionBias
(
conv
->
input
(
0
).
get_source_output
(
),
conv
->
input
(
1
).
get_source_output
(
),
:
ConvolutionBias
(
conv
->
input
_value
(
0
),
conv
->
input
_value
(
1
),
bias
,
conv
->
get_window_movement_strides
(),
conv
->
get_window_dilation_strides
(),
...
...
@@ -201,8 +201,8 @@ shared_ptr<Node> op::ConvolutionBias::copy_with_new_args(const NodeVector& new_a
NodeVector
op
::
ConvolutionBias
::
decompose_op
()
const
{
auto
conv
=
make_shared
<
op
::
Convolution
>
(
input
(
0
).
get_source_output
(
),
input
(
1
).
get_source_output
(
),
auto
conv
=
make_shared
<
op
::
Convolution
>
(
input
_value
(
0
),
input
_value
(
1
),
m_window_movement_strides
,
m_window_dilation_strides
,
m_padding_below
,
...
...
@@ -216,8 +216,7 @@ NodeVector op::ConvolutionBias::decompose_op() const
}
auto
conv_bias
=
make_shared
<
op
::
Add
>
(
conv
,
make_shared
<
op
::
Broadcast
>
(
input
(
2
).
get_source_output
(),
conv
->
get_shape
(),
bcast_axes
));
conv
,
make_shared
<
op
::
Broadcast
>
(
input_value
(
2
),
conv
->
get_shape
(),
bcast_axes
));
if
(
m_with_relu
)
{
return
{
make_shared
<
op
::
Relu
>
(
conv_bias
)};
...
...
@@ -236,13 +235,13 @@ void op::ConvolutionBias::generate_adjoints(autodiff::Adjoints& adjoints, const
delta
=
make_shared
<
op
::
ReluBackprop
>
(
shared_from_this
(),
delta
);
}
auto
data
=
input
(
0
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
const
auto
data_shape
=
data
.
get_shape
();
auto
filter
=
input
(
1
).
get_source_output
(
);
auto
filter
=
input
_value
(
1
);
const
auto
filter_shape
=
filter
.
get_shape
();
auto
bias
=
input
(
2
).
get_source_output
(
);
auto
bias
=
input
_value
(
2
);
const
auto
bias_shape
=
bias
.
get_shape
();
// using regular convolution backprop for data
...
...
@@ -339,9 +338,9 @@ shared_ptr<Node>
NodeVector
op
::
ConvolutionBiasBackpropFiltersBias
::
decompose_op
()
const
{
auto
conv_bprop
=
make_shared
<
op
::
ConvolutionBackpropFilters
>
(
input
(
0
).
get_source_output
(
),
auto
conv_bprop
=
make_shared
<
op
::
ConvolutionBackpropFilters
>
(
input
_value
(
0
),
m_filters_shape
,
input
(
1
).
get_source_output
(
),
input
_value
(
1
),
m_window_movement_strides_forward
,
m_window_dilation_strides_forward
,
m_padding_below_forward
,
...
...
@@ -355,7 +354,7 @@ NodeVector op::ConvolutionBiasBackpropFiltersBias::decompose_op() const
reduce_axes
.
insert
(
i
);
}
auto
bias_bprop
=
make_shared
<
op
::
Sum
>
(
input
(
1
).
get_source_output
(
),
reduce_axes
);
auto
bias_bprop
=
make_shared
<
op
::
Sum
>
(
input
_value
(
1
),
reduce_axes
);
return
{
conv_bprop
,
bias_bprop
};
}
...
...
@@ -384,9 +383,9 @@ op::ConvolutionBiasAdd::ConvolutionBiasAdd(const Output<Node>& data_batch,
op
::
ConvolutionBiasAdd
::
ConvolutionBiasAdd
(
const
std
::
shared_ptr
<
op
::
ConvolutionBias
>&
conv
,
const
Output
<
Node
>&
add_input
,
bool
with_relu
)
:
ConvolutionBiasAdd
(
conv
->
input
(
0
).
get_source_output
(
),
conv
->
input
(
1
).
get_source_output
(
),
conv
->
input
(
2
).
get_source_output
(
),
:
ConvolutionBiasAdd
(
conv
->
input
_value
(
0
),
conv
->
input
_value
(
1
),
conv
->
input
_value
(
2
),
add_input
,
conv
->
get_window_movement_strides
(),
conv
->
get_window_dilation_strides
(),
...
...
@@ -457,8 +456,8 @@ std::shared_ptr<Node> op::ConvolutionBiasAdd::copy_with_new_args(const NodeVecto
NodeVector
op
::
ConvolutionBiasAdd
::
decompose_op
()
const
{
auto
conv
=
make_shared
<
op
::
Convolution
>
(
input
(
0
).
get_source_output
(
),
input
(
1
).
get_source_output
(
),
auto
conv
=
make_shared
<
op
::
Convolution
>
(
input
_value
(
0
),
input
_value
(
1
),
m_window_movement_strides
,
m_window_dilation_strides
,
m_padding_below
,
...
...
@@ -472,14 +471,13 @@ NodeVector op::ConvolutionBiasAdd::decompose_op() const
}
auto
conv_bias
=
make_shared
<
op
::
Add
>
(
conv
,
make_shared
<
op
::
Broadcast
>
(
input
(
2
).
get_source_output
(),
conv
->
get_shape
(),
bcast_axes
));
conv
,
make_shared
<
op
::
Broadcast
>
(
input_value
(
2
),
conv
->
get_shape
(),
bcast_axes
));
if
(
m_with_relu
)
{
return
{
make_shared
<
op
::
Relu
>
(
conv_bias
+
input
(
3
).
get_source_output
(
))};
return
{
make_shared
<
op
::
Relu
>
(
conv_bias
+
input
_value
(
3
))};
}
else
{
return
{
conv_bias
+
input
(
3
).
get_source_output
(
)};
return
{
conv_bias
+
input
_value
(
3
)};
}
}
src/ngraph/op/fused/conv_fused.hpp
View file @
3da93e51
...
...
@@ -55,9 +55,9 @@ namespace ngraph
const
CoordinateDiff
&
get_padding_below
()
const
{
return
m_padding_below
;
}
const
CoordinateDiff
&
get_padding_above
()
const
{
return
m_padding_above
;
}
const
Strides
&
get_data_dilation_strides
()
const
{
return
m_data_dilation_strides
;
}
Output
<
Node
>
get_bias
()
{
return
input
(
2
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_bias
()
{
return
input
_value
(
2
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
_value
(
0
);
}
bool
with_relu
()
const
{
return
m_with_relu
;
}
virtual
std
::
shared_ptr
<
Node
>
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
override
;
...
...
@@ -201,8 +201,8 @@ namespace ngraph
const
CoordinateDiff
&
get_padding_below
()
const
{
return
m_padding_below
;
}
const
CoordinateDiff
&
get_padding_above
()
const
{
return
m_padding_above
;
}
const
Strides
&
get_data_dilation_strides
()
const
{
return
m_data_dilation_strides
;
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
_value
(
0
);
}
bool
with_relu
()
const
{
return
m_with_relu
;
}
virtual
std
::
shared_ptr
<
Node
>
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
override
;
...
...
src/ngraph/op/fused/depth_to_space.cpp
View file @
3da93e51
...
...
@@ -35,7 +35,7 @@ op::DepthToSpace::DepthToSpace(const Output<Node>& data, const size_t block_size
NodeVector
op
::
DepthToSpace
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
const
Shape
&
data_shape
=
data
.
get_shape
();
// Set default values to each dimension to be able to work with both 3D or 4D data.
...
...
src/ngraph/op/fused/elu.cpp
View file @
3da93e51
...
...
@@ -37,8 +37,8 @@ op::Elu::Elu(const Output<Node>& data, const Output<Node>& alpha)
NodeVector
op
::
Elu
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
alpha_node
=
input
(
1
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
auto
alpha_node
=
input
_value
(
1
);
alpha_node
=
ngraph
::
op
::
numpy_style_broadcast
(
alpha_node
,
data
.
get_shape
());
...
...
src/ngraph/op/fused/fake_quantize.cpp
View file @
3da93e51
...
...
@@ -100,11 +100,11 @@ void op::FakeQuantize::pre_validate_and_infer_types()
NodeVector
op
::
FakeQuantize
::
decompose_op
()
const
{
Output
<
Node
>
data
{
input
(
0
).
get_source_output
(
)};
Output
<
Node
>
input_low
{
input
(
1
).
get_source_output
(
)};
Output
<
Node
>
input_high
{
input
(
2
).
get_source_output
(
)};
Output
<
Node
>
output_low
{
input
(
3
).
get_source_output
(
)};
Output
<
Node
>
output_high
{
input
(
4
).
get_source_output
(
)};
Output
<
Node
>
data
{
input
_value
(
0
)};
Output
<
Node
>
input_low
{
input
_value
(
1
)};
Output
<
Node
>
input_high
{
input
_value
(
2
)};
Output
<
Node
>
output_low
{
input
_value
(
3
)};
Output
<
Node
>
output_high
{
input
_value
(
4
)};
if
(
input_low
.
get_shape
().
size
()
==
0
)
{
...
...
src/ngraph/op/fused/gelu.cpp
View file @
3da93e51
...
...
@@ -36,7 +36,7 @@ op::Gelu::Gelu(const Output<Node>& data)
// f(x) = 0.5 * x * (1.0 + erf( x / sqrt(2.0) )
NodeVector
op
::
Gelu
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
shared_ptr
<
ngraph
::
Node
>
half
=
builder
::
make_constant
(
data
.
get_element_type
(),
data
.
get_shape
(),
0.5
);
...
...
src/ngraph/op/fused/gemm.cpp
View file @
3da93e51
...
...
@@ -45,9 +45,9 @@ op::Gemm::Gemm(const Output<Node>& A,
NodeVector
op
::
Gemm
::
decompose_op
()
const
{
auto
A
=
input
(
0
).
get_source_output
(
);
auto
B
=
input
(
1
).
get_source_output
(
);
auto
C
=
input
(
2
).
get_source_output
(
);
auto
A
=
input
_value
(
0
);
auto
B
=
input
_value
(
1
);
auto
C
=
input
_value
(
2
);
if
(
m_transA
)
{
...
...
src/ngraph/op/fused/grn.cpp
View file @
3da93e51
...
...
@@ -56,7 +56,7 @@ void op::GRN::pre_validate_and_infer_types()
NodeVector
op
::
GRN
::
decompose_op
()
const
{
Output
<
Node
>
data
{
input
(
0
).
get_source_output
(
)};
Output
<
Node
>
data
{
input
_value
(
0
)};
const
Shape
&
input_shape
{
data
.
get_shape
()};
// Reshape to 4D tensor.
...
...
src/ngraph/op/fused/group_conv.cpp
View file @
3da93e51
...
...
@@ -129,8 +129,8 @@ shared_ptr<Node> op::GroupConvolution::copy_with_new_args(const NodeVector& new_
NodeVector
op
::
GroupConvolution
::
decompose_op
()
const
{
auto
data
=
input
(
0
);
auto
filters
=
input
(
1
);
auto
data
=
input
_value
(
0
);
auto
filters
=
input
_value
(
1
);
// Split one convolution op to N ops where N is the number of groups
// and concat results after computation.
// reference: https://github.com/NervanaSystems/ngraph-mxnet/blob/fdd692/src/ngraph/ngraph_emitter.cc#L822-L856
...
...
@@ -151,13 +151,13 @@ NodeVector op::GroupConvolution::decompose_op() const
// slice data
data_lower_bounds
[
1
]
=
group
*
data_group_size
;
data_upper_bounds
[
1
]
=
(
group
+
1
)
*
data_group_size
;
auto
sliced_data
=
std
::
make_shared
<
ngraph
::
op
::
Slice
>
(
data
.
get_source_output
()
,
data_lower_bounds
,
data_upper_bounds
);
auto
sliced_data
=
std
::
make_shared
<
ngraph
::
op
::
Slice
>
(
data
,
data_lower_bounds
,
data_upper_bounds
);
// slice filters
filters_lower_bounds
[
0
]
=
group
*
filters_group_size
;
filters_upper_bounds
[
0
]
=
(
group
+
1
)
*
filters_group_size
;
auto
sliced_filters
=
std
::
make_shared
<
ngraph
::
op
::
Slice
>
(
filters
.
get_source_output
()
,
filters_lower_bounds
,
filters_upper_bounds
);
filters
,
filters_lower_bounds
,
filters_upper_bounds
);
convolution_nodes
.
push_back
(
std
::
make_shared
<
ngraph
::
op
::
Convolution
>
(
sliced_data
,
...
...
src/ngraph/op/fused/group_conv.hpp
View file @
3da93e51
...
...
@@ -49,8 +49,8 @@ namespace ngraph
const
CoordinateDiff
&
get_padding_below
()
const
{
return
m_padding_below
;
}
const
CoordinateDiff
&
get_padding_above
()
const
{
return
m_padding_above
;
}
const
Strides
&
get_data_dilation_strides
()
const
{
return
m_data_dilation_strides
;
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
Output
<
Node
>
get_data_batch
()
{
return
input
_value
(
0
);
}
size_t
get_groups
()
const
{
return
m_groups
;
}
const
PadType
&
get_pad_type
()
const
{
return
m_pad_type
;
}
virtual
std
::
shared_ptr
<
Node
>
...
...
src/ngraph/op/fused/group_conv_transpose.cpp
View file @
3da93e51
...
...
@@ -267,8 +267,8 @@ Shape op::GroupConvolutionTranspose::get_data_batch_shape() const
NodeVector
op
::
GroupConvolutionTranspose
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
filters
=
input
(
1
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
auto
filters
=
input
_value
(
1
);
const
Shape
data_batch_shape
=
get_data_batch_shape
();
const
size_t
num_spatial_dims
=
data
.
get_shape
().
size
()
-
2
;
...
...
src/ngraph/op/fused/group_conv_transpose.hpp
View file @
3da93e51
...
...
@@ -114,8 +114,8 @@ namespace ngraph
const
Shape
&
output_shape
,
const
std
::
size_t
groups
=
1UL
);
Output
<
Node
>
get_data
()
{
return
input
(
0
).
get_source_output
(
);
}
Output
<
Node
>
get_filters
()
{
return
input
(
1
).
get_source_output
(
);
}
Output
<
Node
>
get_data
()
{
return
input
_value
(
0
);
}
Output
<
Node
>
get_filters
()
{
return
input
_value
(
1
);
}
const
Strides
&
get_strides
()
const
{
return
m_strides
;
}
const
Strides
&
get_dilations
()
const
{
return
m_dilations
;
}
const
CoordinateDiff
&
get_padding_begin
()
const
{
return
m_padding_begin
;
}
...
...
src/ngraph/op/fused/gru_cell.cpp
View file @
3da93e51
...
...
@@ -186,11 +186,11 @@ NodeVector op::GRUCell::decompose_op() const
// Ht = (1 - zt) (.) ht + zt (.) Ht-1
// -------------------
Output
<
Node
>
X
=
input
(
0
).
get_source_output
(
);
Output
<
Node
>
W
=
input
(
1
).
get_source_output
(
);
Output
<
Node
>
R
=
input
(
2
).
get_source_output
(
);
Output
<
Node
>
H_t
=
input
(
3
).
get_source_output
(
);
Output
<
Node
>
B
=
input
(
4
).
get_source_output
(
);
Output
<
Node
>
X
=
input
_value
(
0
);
Output
<
Node
>
W
=
input
_value
(
1
);
Output
<
Node
>
R
=
input
_value
(
2
);
Output
<
Node
>
H_t
=
input
_value
(
3
);
Output
<
Node
>
B
=
input
_value
(
4
);
// Get W and R biases separately.
NodeVector
b_W_R
=
builder
::
split
(
B
,
2
);
...
...
src/ngraph/op/fused/hard_sigmoid.cpp
View file @
3da93e51
...
...
@@ -39,7 +39,7 @@ op::HardSigmoid::HardSigmoid(const Output<Node>& data, float alpha, float beta)
NodeVector
op
::
HardSigmoid
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
auto
data_shape
=
data
.
get_shape
();
size_t
elem_count
=
shape_size
(
data_shape
);
...
...
src/ngraph/op/fused/lstm_cell.cpp
View file @
3da93e51
...
...
@@ -224,11 +224,11 @@ NodeVector op::LSTMCell::decompose_op() const
// Ht = ot (.) h(Ct)
// --------------------
Output
<
Node
>
X
=
input
(
0
).
get_source_output
(
);
Output
<
Node
>
W
=
input
(
1
).
get_source_output
(
);
Output
<
Node
>
R
=
input
(
2
).
get_source_output
(
);
Output
<
Node
>
H_t
=
input
(
3
).
get_source_output
(
);
Output
<
Node
>
C_t
=
input
(
4
).
get_source_output
(
);
Output
<
Node
>
X
=
input
_value
(
0
);
Output
<
Node
>
W
=
input
_value
(
1
);
Output
<
Node
>
R
=
input
_value
(
2
);
Output
<
Node
>
H_t
=
input
_value
(
3
);
Output
<
Node
>
C_t
=
input
_value
(
4
);
Output
<
Node
>
bias
=
get_bias
();
NodeVector
p_iof
=
get_peephole_weights
();
...
...
@@ -278,7 +278,7 @@ Output<Node> op::LSTMCell::get_bias() const
{
Output
<
Node
>
bias
;
// Split B onto Wb an Rb and add them.
NodeVector
b_W_R
=
builder
::
split
(
input
(
5
).
get_source_output
(
),
2
);
NodeVector
b_W_R
=
builder
::
split
(
input
_value
(
5
),
2
);
bias
=
b_W_R
.
at
(
0
)
+
b_W_R
.
at
(
1
);
return
bias
;
}
...
...
@@ -286,7 +286,7 @@ Output<Node> op::LSTMCell::get_bias() const
NodeVector
op
::
LSTMCell
::
get_peephole_weights
()
const
{
Output
<
Node
>
P
;
P
=
input
(
6
).
get_source_output
(
);
P
=
input
_value
(
6
);
return
builder
::
split
(
P
,
s_peepholes_count
);
}
...
...
src/ngraph/op/fused/mvn.cpp
View file @
3da93e51
...
...
@@ -59,7 +59,7 @@ op::MVN::MVN(const Output<Node>& data, AxisSet reduction_axes, bool normalize_va
NodeVector
op
::
MVN
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
auto
data_shape
=
data
.
get_shape
();
// assume that data has n and c channels.
// calculate mean normalization
...
...
src/ngraph/op/fused/normalize.cpp
View file @
3da93e51
...
...
@@ -88,7 +88,7 @@ void op::Normalize::pre_validate_and_infer_types()
NodeVector
op
::
Normalize
::
decompose_op
()
const
{
Output
<
Node
>
data
{
input
(
0
).
get_source_output
(
)};
Output
<
Node
>
data
{
input
_value
(
0
)};
const
Shape
input_shape
{
data
.
get_shape
()};
// Reshape to 4D tensor.
...
...
@@ -111,7 +111,7 @@ NodeVector op::Normalize::decompose_op() const
Output
<
Node
>
norm
=
builder
::
l2_norm
(
data
,
reduction_axes
,
m_eps
);
norm
=
make_broadcast_node
(
norm
,
data
.
get_shape
(),
0
);
Output
<
Node
>
scale_node
{
input
(
1
).
get_source_output
(
)};
Output
<
Node
>
scale_node
{
input
_value
(
1
)};
// Broadcast scale to data tensor shape.
if
(
m_channel_shared
)
...
...
src/ngraph/op/fused/prelu.cpp
View file @
3da93e51
...
...
@@ -37,9 +37,9 @@ op::PRelu::PRelu(const Output<Node>& data, const Output<Node>& slope)
NodeVector
op
::
PRelu
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
auto
data_shape
=
data
.
get_shape
();
auto
slope
=
input
(
1
).
get_source_output
(
);
auto
slope
=
input
_value
(
1
);
auto
slope_shape
=
slope
.
get_shape
();
if
((
slope_shape
.
size
()
==
1
)
&&
(
slope_shape
.
at
(
0
)
!=
1
))
...
...
src/ngraph/op/fused/rnn_cell.cpp
View file @
3da93e51
...
...
@@ -167,10 +167,10 @@ NodeVector op::RNNCell::decompose_op() const
// Ht = f(Xt*(Wi^T) + Ht-1*(Ri^T) + Wbi + Rbi)
// --------------------
Output
<
Node
>
X
=
input
(
0
).
get_source_output
(
);
Output
<
Node
>
W
=
input
(
1
).
get_source_output
(
);
Output
<
Node
>
R
=
input
(
2
).
get_source_output
(
);
Output
<
Node
>
H_t
=
input
(
3
).
get_source_output
(
);
Output
<
Node
>
X
=
input
_value
(
0
);
Output
<
Node
>
W
=
input
_value
(
1
);
Output
<
Node
>
R
=
input
_value
(
2
);
Output
<
Node
>
H_t
=
input
_value
(
3
);
Output
<
Node
>
bias
=
get_bias
();
// Xt*(W^T)
...
...
@@ -190,7 +190,7 @@ Output<Node> op::RNNCell::get_bias() const
{
Output
<
Node
>
bias
;
// Split B onto Wb an Rb and add them.
NodeVector
b_W_R
=
builder
::
split
(
input
(
4
).
get_source_output
(
),
2
);
NodeVector
b_W_R
=
builder
::
split
(
input
_value
(
4
),
2
);
bias
=
b_W_R
.
at
(
0
)
+
b_W_R
.
at
(
1
);
return
bias
;
}
...
...
src/ngraph/op/fused/scale_shift.cpp
View file @
3da93e51
...
...
@@ -33,9 +33,9 @@ op::ScaleShift::ScaleShift(const Output<Node>& data,
NodeVector
op
::
ScaleShift
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
scale
=
input
(
1
).
get_source_output
(
);
auto
shift
=
input
(
2
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
auto
scale
=
input
_value
(
1
);
auto
shift
=
input
_value
(
2
);
// broadcast all data
auto
broadcasted_nodes
=
numpy_style_broadcast_values
({
data
,
scale
,
shift
});
...
...
src/ngraph/op/fused/shuffle_channels.cpp
View file @
3da93e51
...
...
@@ -74,7 +74,7 @@ void op::ShuffleChannels::pre_validate_and_infer_types()
NodeVector
op
::
ShuffleChannels
::
decompose_op
()
const
{
const
auto
data
=
input
(
0
).
get_source_output
(
);
const
auto
data
=
input
_value
(
0
);
const
auto
&
data_shape
=
data
.
get_shape
();
const
auto
reshaped
=
builder
::
reshape
(
data
,
get_pre_shuffle_shape
(
data_shape
));
...
...
src/ngraph/op/fused/space_to_depth.cpp
View file @
3da93e51
...
...
@@ -34,7 +34,7 @@ op::SpaceToDepth::SpaceToDepth(const Output<Node>& data, const size_t block_size
NodeVector
op
::
SpaceToDepth
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
data
=
input
_value
(
0
);
const
Shape
&
data_shape
=
data
.
get_shape
();
// Set default values to each dimension to be able to work with both 3D or 4D data.
...
...
src/ngraph/op/fused/split.cpp
View file @
3da93e51
...
...
@@ -84,7 +84,7 @@ void op::Split::pre_validate_and_infer_types()
NodeVector
op
::
Split
::
decompose_op
()
const
{
return
builder
::
split
(
input
(
0
).
get_source_output
(
),
m_splits
,
m_axis
);
return
builder
::
split
(
input
_value
(
0
),
m_splits
,
m_axis
);
}
shared_ptr
<
Node
>
op
::
Split
::
copy_with_new_args
(
const
NodeVector
&
new_args
)
const
...
...
src/ngraph/op/fused/squared_difference.cpp
View file @
3da93e51
...
...
@@ -34,8 +34,8 @@ op::SquaredDifference::SquaredDifference(const Output<Node>& x1, const Output<No
NodeVector
op
::
SquaredDifference
::
decompose_op
()
const
{
const
auto
x1
=
input
(
0
).
get_source_output
(
);
const
auto
x2
=
input
(
1
).
get_source_output
(
);
const
auto
x1
=
input
_value
(
0
);
const
auto
x2
=
input
_value
(
1
);
const
auto
broadcasted
=
numpy_style_broadcast_values
({
x1
,
x2
});
...
...
src/ngraph/op/fused/squeeze.cpp
View file @
3da93e51
...
...
@@ -34,8 +34,8 @@ op::Squeeze::Squeeze(const Output<Node>& data, const Output<Node>& axes)
NodeVector
op
::
Squeeze
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
axes_node
=
input
(
1
).
get_source_output
(
).
get_node_shared_ptr
();
auto
data
=
input
_value
(
0
);
auto
axes_node
=
input
_value
(
1
).
get_node_shared_ptr
();
// Currently only support Constant node for axes.
NODE_VALIDATION_CHECK
(
this
,
...
...
src/ngraph/op/fused/unsqueeze.cpp
View file @
3da93e51
...
...
@@ -34,7 +34,7 @@ op::Unsqueeze::Unsqueeze(const Output<Node>& data, const Output<Node>& axes)
void
op
::
Unsqueeze
::
pre_validate_and_infer_types
()
{
auto
axes_node
=
input
(
1
).
get_source_output
(
).
get_node_shared_ptr
();
auto
axes_node
=
input
_value
(
1
).
get_node_shared_ptr
();
// Currently only support Constant node for axes.
NODE_VALIDATION_CHECK
(
this
,
...
...
@@ -44,8 +44,8 @@ void op::Unsqueeze::pre_validate_and_infer_types()
NodeVector
op
::
Unsqueeze
::
decompose_op
()
const
{
auto
data
=
input
(
0
).
get_source_output
(
);
auto
axes_node
=
input
(
1
).
get_source_output
(
).
get_node_shared_ptr
();
auto
data
=
input
_value
(
0
);
auto
axes_node
=
input
_value
(
1
).
get_node_shared_ptr
();
// Get value of axes from Constant
auto
axes_constant
=
dynamic_pointer_cast
<
op
::
Constant
>
(
axes_node
);
...
...
src/ngraph/op/get_output_element.cpp
View file @
3da93e51
...
...
@@ -33,7 +33,7 @@ op::GetOutputElement::GetOutputElement(const shared_ptr<Node>& arg, size_t n)
void
op
::
GetOutputElement
::
validate_and_infer_types
()
{
NODE_VALIDATION_CHECK
(
this
,
m_n
<
input
(
0
).
get_source_output
(
).
get_node
()
->
get_output_size
(),
m_n
<
input
_value
(
0
).
get_node
()
->
get_output_size
(),
"Output at index "
,
m_n
,
" requested, but node has only "
,
...
...
@@ -51,19 +51,19 @@ shared_ptr<Node> op::GetOutputElement::copy_with_new_args(const NodeVector& new_
Output
<
Node
>
op
::
GetOutputElement
::
get_as_output
()
const
{
return
input
(
0
).
get_source_output
(
);
return
input
_value
(
0
);
}
NodeVector
op
::
GetOutputElement
::
get_arguments
()
const
{
return
NodeVector
{
input
(
0
).
get_source_output
(
).
get_node_shared_ptr
()};
return
NodeVector
{
input
_value
(
0
).
get_node_shared_ptr
()};
}
void
op
::
GetOutputElement
::
generate_adjoints
(
autodiff
::
Adjoints
&
adjoints
,
const
NodeVector
&
deltas
)
{
auto
delta
=
deltas
.
at
(
0
);
adjoints
.
add_delta
(
input
(
0
).
get_source_output
(
).
get_node_shared_ptr
(),
delta
,
get_n
());
adjoints
.
add_delta
(
input
_value
(
0
).
get_node_shared_ptr
(),
delta
,
get_n
());
}
NodeVector
op
::
get_output_elements
(
const
shared_ptr
<
Node
>&
mon
)
...
...
src/ngraph/op/log.cpp
View file @
3da93e51
...
...
@@ -38,7 +38,7 @@ void op::Log::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
/
x
);
}
src/ngraph/op/max_pool.cpp
View file @
3da93e51
...
...
@@ -256,7 +256,7 @@ void op::MaxPool::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
auto
delta
=
deltas
.
at
(
0
);
auto
operand
=
input
(
0
).
get_source_output
(
);
auto
operand
=
input
_value
(
0
);
auto
backprop
=
make_shared
<
op
::
MaxPoolBackprop
>
(
operand
,
delta
,
...
...
src/ngraph/op/maximum.cpp
View file @
3da93e51
...
...
@@ -50,10 +50,10 @@ void op::Maximum::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
adjoints
.
add_delta
(
x
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Greater
>
(
x
,
y
),
x
->
get_element_type
()));
x
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Greater
>
(
x
,
y
),
x
.
get_element_type
()));
adjoints
.
add_delta
(
y
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Greater
>
(
y
,
x
),
y
->
get_element_type
()));
y
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Greater
>
(
y
,
x
),
y
.
get_element_type
()));
}
src/ngraph/op/minimum.cpp
View file @
3da93e51
...
...
@@ -50,11 +50,11 @@ void op::Minimum::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
adjoints
.
add_delta
(
x
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Less
>
(
x
,
y
),
x
->
get_element_type
()));
x
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Less
>
(
x
,
y
),
x
.
get_element_type
()));
adjoints
.
add_delta
(
y
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Less
>
(
y
,
x
),
y
->
get_element_type
()));
y
,
delta
*
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Less
>
(
y
,
x
),
y
.
get_element_type
()));
}
src/ngraph/op/multiply.cpp
View file @
3da93e51
...
...
@@ -44,8 +44,8 @@ void op::Multiply::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVec
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
adjoints
.
add_delta
(
x
,
delta
*
y
);
adjoints
.
add_delta
(
y
,
x
*
delta
);
...
...
src/ngraph/op/negative.cpp
View file @
3da93e51
...
...
@@ -37,7 +37,7 @@ void op::Negative::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVec
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
-
delta
);
}
...
...
src/ngraph/op/pad.cpp
View file @
3da93e51
...
...
@@ -172,5 +172,5 @@ std::shared_ptr<Node> op::Pad::get_default_value() const
{
axes
.
insert
(
i
);
}
return
std
::
make_shared
<
op
::
Broadcast
>
(
get_argument
(
1
),
get_shape
(),
axes
);
return
std
::
make_shared
<
op
::
Broadcast
>
(
input_value
(
1
),
get_shape
(),
axes
);
}
src/ngraph/op/power.cpp
View file @
3da93e51
...
...
@@ -45,8 +45,8 @@ void op::Power::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
auto
log_x
=
make_shared
<
op
::
Log
>
(
x
);
...
...
src/ngraph/op/relu.cpp
View file @
3da93e51
...
...
@@ -52,5 +52,5 @@ void op::Relu::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
auto
delta
=
deltas
.
at
(
0
);
auto
backprop
=
make_shared
<
op
::
ReluBackprop
>
(
shared_from_this
(),
delta
);
adjoints
.
add_delta
(
get_argument
(
0
),
backprop
);
adjoints
.
add_delta
(
input_value
(
0
),
backprop
);
}
src/ngraph/op/replace_slice.cpp
View file @
3da93e51
...
...
@@ -178,10 +178,10 @@ void op::ReplaceSlice::generate_adjoints(autodiff::Adjoints& adjoints, const Nod
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
y
=
get_argument
(
1
);
auto
&
y_element_type
=
input
(
1
)
.
get_element_type
();
auto
y_shape
=
input
(
1
)
.
get_shape
();
auto
x
=
input_value
(
0
);
auto
y
=
input_value
(
1
);
auto
&
y_element_type
=
y
.
get_element_type
();
auto
y_shape
=
y
.
get_shape
();
auto
zeros_shaped_like_y
=
op
::
Constant
::
create
(
y_element_type
,
y_shape
,
{
0.0
});
...
...
src/ngraph/op/reshape.cpp
View file @
3da93e51
...
...
@@ -143,5 +143,5 @@ void op::Reshape::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
reshape
=
make_shared
<
op
::
Reshape
>
(
reshape
,
x_input_order
,
x_shape
);
}
adjoints
.
add_delta
(
get_argument
(
0
),
reshape
);
adjoints
.
add_delta
(
input_value
(
0
),
reshape
);
}
src/ngraph/op/result.cpp
View file @
3da93e51
...
...
@@ -32,7 +32,7 @@ op::Result::Result(const Output<Node>& arg, bool needs_default_layout)
{
constructor_validate_and_infer_types
();
// always borrow the placement conf even the default one
set_placement_index
(
get_argument
(
0
)
->
get_placement_index
());
set_placement_index
(
input_value
(
0
).
get_node
(
)
->
get_placement_index
());
}
void
op
::
Result
::
validate_and_infer_types
()
...
...
@@ -55,5 +55,5 @@ void op::Result::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVecto
{
auto
delta
=
deltas
.
at
(
0
);
adjoints
.
add_delta
(
get_argument
(
0
),
delta
);
adjoints
.
add_delta
(
input_value
(
0
),
delta
);
}
src/ngraph/op/reverse.cpp
View file @
3da93e51
...
...
@@ -65,7 +65,7 @@ void op::Reverse::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
adjoints
.
add_delta
(
x
,
make_shared
<
op
::
Reverse
>
(
delta
,
m_reversed_axes
));
}
src/ngraph/op/reverse_sequence.cpp
View file @
3da93e51
...
...
@@ -102,8 +102,8 @@ shared_ptr<Node> op::ReverseSequence::copy_with_new_args(const NodeVector& new_a
void
op
::
ReverseSequence
::
generate_adjoints
(
autodiff
::
Adjoints
&
adjoints
,
const
NodeVector
&
deltas
)
{
auto
x
=
input
(
0
).
get_source_output
(
);
auto
rs_delta
=
make_shared
<
ReverseSequence
>
(
deltas
.
at
(
0
),
input
(
1
).
get_source_output
(
),
m_batch_axis
,
m_seq_axis
);
auto
x
=
input
_value
(
0
);
auto
rs_delta
=
make_shared
<
ReverseSequence
>
(
deltas
.
at
(
0
),
input_value
(
1
),
m_batch_axis
,
m_seq_axis
);
adjoints
.
add_delta
(
x
,
rs_delta
);
}
src/ngraph/op/select.cpp
View file @
3da93e51
...
...
@@ -71,9 +71,9 @@ void op::Select::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVecto
{
auto
delta
=
deltas
.
at
(
0
);
auto
p
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
(
1
).
get_source_output
(
);
auto
y
=
input
(
2
).
get_source_output
(
);
auto
p
=
input
_value
(
0
);
auto
x
=
input
_value
(
1
);
auto
y
=
input
_value
(
2
);
auto
p_as_x_type
=
make_shared
<
op
::
Convert
>
(
p
,
x
.
get_element_type
());
auto
not_p_as_y_type
=
make_shared
<
op
::
Convert
>
(
make_shared
<
op
::
Not
>
(
p
),
y
.
get_element_type
());
...
...
src/ngraph/op/sigmoid.cpp
View file @
3da93e51
...
...
@@ -52,6 +52,6 @@ void op::Sigmoid::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
{
auto
delta
=
deltas
.
at
(
0
);
auto
backprop
=
make_shared
<
op
::
SigmoidBackprop
>
(
input
(
0
).
get_source_output
(
),
delta
);
adjoints
.
add_delta
(
input
(
0
).
get_source_output
(
),
backprop
);
auto
backprop
=
make_shared
<
op
::
SigmoidBackprop
>
(
input
_value
(
0
),
delta
);
adjoints
.
add_delta
(
input
_value
(
0
),
backprop
);
}
src/ngraph/op/sin.cpp
View file @
3da93e51
...
...
@@ -39,7 +39,7 @@ void op::Sin::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
*
(
make_shared
<
op
::
Cos
>
(
x
)));
}
src/ngraph/op/sinh.cpp
View file @
3da93e51
...
...
@@ -39,7 +39,7 @@ void op::Sinh::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
x
=
input_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
*
(
make_shared
<
op
::
Cosh
>
(
x
)));
}
src/ngraph/op/slice.cpp
View file @
3da93e51
...
...
@@ -135,7 +135,7 @@ void op::Slice::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
adjoints
.
add_delta_to_slice
(
x
,
delta
,
m_lower_bounds
,
m_upper_bounds
,
m_strides
);
}
src/ngraph/op/softmax.cpp
View file @
3da93e51
...
...
@@ -87,6 +87,6 @@ void op::Softmax::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVect
auto
adjoint
=
z
-
builder
::
make_with_numpy_broadcast
<
op
::
Multiply
>
(
output
(
0
),
zreshape
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
adjoints
.
add_delta
(
x
,
adjoint
);
}
src/ngraph/op/sqrt.cpp
View file @
3da93e51
...
...
@@ -39,7 +39,7 @@ void op::Sqrt::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
/
(
shared_from_this
()
+
shared_from_this
()));
}
src/ngraph/op/subtract.cpp
View file @
3da93e51
...
...
@@ -45,8 +45,8 @@ void op::Subtract::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVec
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
y
=
input
(
1
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
auto
y
=
input
_value
(
1
);
adjoints
.
add_delta
(
x
,
delta
);
adjoints
.
add_delta
(
y
,
-
delta
);
...
...
src/ngraph/op/sum.cpp
View file @
3da93e51
...
...
@@ -44,8 +44,8 @@ void op::Sum::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
get_argument
(
0
);
auto
&
x_shape
=
input
(
0
)
.
get_shape
();
auto
x
=
input_value
(
0
);
auto
&
x_shape
=
x
.
get_shape
();
adjoints
.
add_delta
(
x
,
make_shared
<
op
::
Broadcast
>
(
delta
,
x_shape
,
get_reduction_axes
()));
}
src/ngraph/op/tan.cpp
View file @
3da93e51
...
...
@@ -40,7 +40,7 @@ void op::Tan::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
auto
c
=
make_shared
<
op
::
Cos
>
(
x
);
...
...
src/ngraph/op/tanh.cpp
View file @
3da93e51
...
...
@@ -39,7 +39,7 @@ void op::Tanh::generate_adjoints(autodiff::Adjoints& adjoints, const NodeVector&
{
auto
delta
=
deltas
.
at
(
0
);
auto
x
=
input
(
0
).
get_source_output
(
);
auto
x
=
input
_value
(
0
);
adjoints
.
add_delta
(
x
,
delta
-
(
delta
*
(
shared_from_this
()
*
shared_from_this
())));
}
src/ngraph/op/topk.cpp
View file @
3da93e51
...
...
@@ -59,8 +59,7 @@ op::TopK::TopK(const Output<Node>& arg,
size_t
op
::
TopK
::
get_k
()
const
{
size_t
k
=
0
;
if
(
auto
const_op
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input
(
1
).
get_source_output
().
get_node_shared_ptr
()))
if
(
auto
const_op
=
dynamic_pointer_cast
<
op
::
Constant
>
(
input_value
(
1
).
get_node_shared_ptr
()))
{
k
=
const_op
->
get_vector
<
int64_t
>
()[
0
];
}
...
...
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