未验证 提交 488b2387 编写于 作者: L Leo Chen 提交者: GitHub

Feature/expand params in auto-generated pybind functions for dygraph operators (#23181)

* expand parameters, test=develop

* support resnet, test=develop

* fix resnet, test=develop

* support duplicable out, test=develop

* support ptb

* fix bugs, test=develop

* support null input, test=develop

* fix bugs, test=develop

* fix batchNorm is_test, test=develop

* refine code, test=develop

* follow comments, test=develop

* follow comments, test=develop

* follow comments, test=develop

* follow comments, test=develop
上级 9474d140
...@@ -18,13 +18,45 @@ ...@@ -18,13 +18,45 @@
#include <pybind11/complex.h> #include <pybind11/complex.h>
#include <pybind11/functional.h> #include <pybind11/functional.h>
#include <pybind11/stl.h> #include <pybind11/stl.h>
#include <memory>
#include <string>
#include <vector>
#include "paddle/fluid/framework/attribute.h" #include "paddle/fluid/framework/attribute.h"
#include "paddle/fluid/framework/op_info.h" #include "paddle/fluid/framework/op_info.h"
#include "paddle/fluid/framework/variable.h" #include "paddle/fluid/framework/variable.h"
#include "paddle/fluid/imperative/tracer.h" #include "paddle/fluid/imperative/tracer.h"
#include "paddle/fluid/imperative/type_defs.h" #include "paddle/fluid/imperative/type_defs.h"
#include "paddle/fluid/pybind/imperative.h" #include "paddle/fluid/pybind/imperative.h"
namespace py = pybind11;
namespace paddle {
namespace pybind {
static inline void ConstructAttrMapFromPyArgs(framework::AttributeMap* attrs,
const py::args& args) {
PADDLE_ENFORCE_EQ(
args.size() % 2, 0,
platform::errors::InvalidArgument(
"The number of arguments for arributes should be even."));
for (size_t i = 0; i < args.size(); i += 2) {
auto name = args[i].cast<std::string>();
auto value = args[i + 1].cast<framework::Attribute>();
(*attrs)[name] = value;
}
}
static inline std::vector<std::shared_ptr<imperative::VarBase>>
ConstructDuplicableOutput(const size_t num) {
auto tracer = imperative::GetCurrentTracer();
std::vector<std::shared_ptr<imperative::VarBase>> res;
res.reserve(num);
for (size_t i = 0; i < num; i++) {
auto var_base_name = tracer->GenerateUniqueName();
res.emplace_back(new imperative::VarBase(var_base_name));
}
return res;
}
} // namespace pybind
} // namespace paddle
// This include must be the last line // This include must be the last line
#include "paddle/fluid/pybind/op_function_impl.h" #include "paddle/fluid/pybind/op_function_impl.h"
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
#include <algorithm>
#include <fstream> #include <fstream>
#include <iostream> #include <iostream>
#include <string> #include <string>
...@@ -23,46 +24,93 @@ ...@@ -23,46 +24,93 @@
#include "paddle/fluid/pybind/pybind.h" #include "paddle/fluid/pybind/pybind.h"
#include "paddle/fluid/string/string_helper.h" #include "paddle/fluid/string/string_helper.h"
std::map<std::string, std::set<std::string>> op_ins_map = {
{"layer_norm", {"X", "Scale", "Bias"}},
{"gru_unit", {"Input", "HiddenPrev", "Weight", "Bias"}},
{"label_smooth", {"X", "PriorDist"}},
{"assign", {"X"}},
};
std::map<std::string, std::set<std::string>> op_passing_out_map = {
{"sgd", {"ParamOut"}},
{"adam",
{"ParamOut", "Moment1Out", "Moment2Out", "Beta1PowOut", "Beta2PowOut"}},
{"momentum", {"ParamOut", "VelocityOut"}},
{"batch_norm", {"MeanOut", "VarianceOut"}},
{"accuracy", {"Correct", "Total"}},
{"fill_constant", {"Out"}}};
// clang-format off // clang-format off
const char* OUT_INITIALIZER_TEMPLATE = const char* OUT_INITIALIZER_TEMPLATE =
R"({"%s", {std::shared_ptr<imperative::VarBase>(new imperative::VarBase(tracer->GenerateUniqueName()))}})"; R"({"%s", {std::shared_ptr<imperative::VarBase>(new imperative::VarBase(tracer->GenerateUniqueName()))}})";
const char* OUT_DUPLICABLE_INITIALIZER_TEMPLATE = R"({"%s", ConstructDuplicableOutput(%s)})";
const char* INPUT_INITIALIZER_TEMPLATE = R"({"%s", {%s}})";
const char* INPUT_LIST_INITIALIZER_TEMPLATE = R"({"%s", %s})";
const char* INPUT_INITIALIZER_TEMPLATE_WITH_NULL = R"(
if (%s != nullptr) {
ins["%s"] = {%s};
}
)";
const char* INPUT_INITIALIZER_TEMPLATE_WITH_NULL_LIST = R"(
if (%s != nullptr) {
ins["%s"] = %s;
}
)";
// if inputs is list, no need {}
const char* ARG_OUT_NUM = R"(%sNum)";
const char* ARG_OUT_NUM_TYPE = R"(size_t )";
const char* VAR_TYPE = R"(std::shared_ptr<imperative::VarBase>)";
const char* VAR_LIST_TYPE = R"(std::vector<std::shared_ptr<imperative::VarBase>>)";
const char* ARG_TEMPLATE = R"(const %s& %s)";
const char* RETURN_TUPLE_TYPE = R"(std::tuple<%s>)";
const char* RETURN_TYPE = R"(%s)";
const char* RETURN_TUPLE_TEMPLATE = R"(std::make_tuple(%s))";
const char* RETURN_LIST_TEMPLATE = R"(outs["%s"])";
const char* RETURN_TEMPLATE = R"(outs["%s"][0])";
const char* FUNCTION_ARGS = R"(%s, const py::args& args)";
const char* FUNCTION_ARGS_NO_INPUT = R"(const py::args& args)";
const char* OP_FUNCTION_TEMPLATE = const char* OP_FUNCTION_TEMPLATE =
R"( R"(
inline imperative::NameVarBaseMap %s(const imperative::NameVarBaseMap& ins, const framework::AttributeMap& attrs, %s %s(%s)
imperative::NameVarBaseMap outs, const std::map<std::string, size_t>& out_nums)
{ {
framework::AttributeMap attrs;
ConstructAttrMapFromPyArgs(&attrs, args);
{
py::gil_scoped_release release;
auto tracer = imperative::GetCurrentTracer(); auto tracer = imperative::GetCurrentTracer();
if (outs.size() == 0) { imperative::NameVarBaseMap outs = %s;
if (out_nums.size() == 0) { imperative::NameVarBaseMap ins = %s;
imperative::NameVarBaseMap outs_ = %s; %s
outs = std::move(outs_); tracer->TraceOp("%s", ins, outs, attrs);
} else { return %s;
for (auto &pair : out_nums) {
for (size_t i = 0; i < pair.second; i ++) {
auto var_base_name = tracer->GenerateUniqueName();
outs[pair.first].emplace_back(new imperative::VarBase(var_base_name));
}
}
}
} }
tracer->TraceOp("%s", std::move(ins), std::move(outs), std::move(attrs));
return outs;
})"; })";
const char* PYBIND_ITEM_TEMPLATE = const char* PYBIND_ITEM_TEMPLATE = R"( %s.def("%s", &%s);)";
R"(
%s.def("%s", &%s, py::arg("ins"), py::arg("attrs")=framework::AttributeMap(), py::arg("outs")=imperative::NameVarBaseMap(),
py::arg("out_nums")=std::map<std::string, size_t>(), py::call_guard<py::gil_scoped_release>());)";
// clang-format on // clang-format on
static inline bool FindInputInSpecialization(const std::string& op_type,
const std::string& in_name) {
return op_ins_map[op_type].count(in_name);
}
static inline bool FindOutoutInSpecialization(const std::string& op_type,
const std::string& out_name) {
return op_passing_out_map[op_type].count(out_name);
}
static std::tuple<std::vector<std::string>, std::vector<std::string>> static std::tuple<std::vector<std::string>, std::vector<std::string>>
GenerateOpFunctions(const std::string& module_name) { GenerateOpFunctions(const std::string& module_name) {
auto& op_info_map = paddle::framework::OpInfoMap::Instance().map(); auto& op_info_map = paddle::framework::OpInfoMap::Instance().map();
std::vector<std::string> op_function_list, bind_function_list; std::vector<std::string> op_function_list, bind_function_list;
auto& all_kernels = paddle::framework::OperatorWithKernel::AllOpKernels();
for (auto& pair : op_info_map) { for (auto& pair : op_info_map) {
auto& op_info = pair.second; auto& op_info = pair.second;
auto op_proto = op_info.proto_; auto op_proto = op_info.proto_;
...@@ -70,27 +118,131 @@ GenerateOpFunctions(const std::string& module_name) { ...@@ -70,27 +118,131 @@ GenerateOpFunctions(const std::string& module_name) {
continue; continue;
} }
auto& op_type = op_proto->type(); auto& op_type = op_proto->type();
// Skip ooerator which is not inherit form OperatorWithKernel, like while,
// since only OperatorWithKernel can run in dygraph mode.
if (!all_kernels.count(op_type)) {
continue;
}
std::string input_args = "";
std::string ins_initializer = "{";
std::string ins_initializer_with_null = "";
std::string py_arg = "";
for (auto& input : op_proto->inputs()) {
auto& in_name = input.name();
// skip those dispensable inputs, like ResidualData in conv2d
if (input.dispensable() && !FindInputInSpecialization(op_type, in_name)) {
continue;
}
const auto in_type = input.duplicable() ? VAR_LIST_TYPE : VAR_TYPE;
auto input_arg = paddle::string::Sprintf(ARG_TEMPLATE, in_type, in_name);
input_args += input_arg;
input_args += ",";
if (input.dispensable()) {
const auto in_template = input.duplicable()
? INPUT_INITIALIZER_TEMPLATE_WITH_NULL_LIST
: INPUT_INITIALIZER_TEMPLATE_WITH_NULL;
ins_initializer_with_null +=
paddle::string::Sprintf(in_template, in_name, in_name, in_name);
} else {
const auto in_template = input.duplicable()
? INPUT_LIST_INITIALIZER_TEMPLATE
: INPUT_INITIALIZER_TEMPLATE;
ins_initializer +=
paddle::string::Sprintf(in_template, in_name, in_name);
ins_initializer += ",";
}
}
if (ins_initializer.back() == ',') {
ins_initializer.pop_back();
}
ins_initializer += "}";
if (input_args.back() == ',') {
input_args.pop_back();
}
// Generate outs initializer // Generate outs initializer
std::string outs_initializer = "{"; std::string outs_initializer = "{";
std::string return_type = "";
std::string return_str = "";
int outs_num = 0;
for (auto& output : op_proto->outputs()) { for (auto& output : op_proto->outputs()) {
if (output.dispensable()) {
continue;
}
const auto out_type = output.duplicable() ? VAR_LIST_TYPE : VAR_TYPE;
const auto return_template =
output.duplicable() ? RETURN_LIST_TEMPLATE : RETURN_TEMPLATE;
auto& out_name = output.name(); auto& out_name = output.name();
auto out_initializer_str = std::string out_initializer_str;
if (FindOutoutInSpecialization(op_type, out_name)) {
if (input_args != "") {
input_args += ",";
}
input_args += out_type;
input_args += out_name;
const auto out_template = output.duplicable()
? INPUT_LIST_INITIALIZER_TEMPLATE
: INPUT_INITIALIZER_TEMPLATE;
out_initializer_str +=
paddle::string::Sprintf(out_template, out_name, out_name);
} else {
// There are few Operators that have duplicable output, like `Out` in
// split op. We need to specify the number of variables for the
// duplicable output, as the argument OutNum;
if (output.duplicable()) {
if (input_args != "") {
input_args += ",";
}
auto out_num_str = paddle::string::Sprintf(ARG_OUT_NUM, out_name);
input_args += ARG_OUT_NUM_TYPE;
input_args += out_num_str;
out_initializer_str = paddle::string::Sprintf(
OUT_DUPLICABLE_INITIALIZER_TEMPLATE, out_name, out_num_str);
} else {
out_initializer_str =
paddle::string::Sprintf(OUT_INITIALIZER_TEMPLATE, out_name); paddle::string::Sprintf(OUT_INITIALIZER_TEMPLATE, out_name);
}
}
return_type += out_type;
return_type += ",";
return_str += paddle::string::Sprintf(return_template, out_name);
return_str += ",";
outs_num += 1;
outs_initializer += out_initializer_str; outs_initializer += out_initializer_str;
outs_initializer += ","; outs_initializer += ",";
} }
if (outs_initializer.back() == ',') { if (outs_initializer.back() == ',') {
outs_initializer.pop_back(); outs_initializer.pop_back();
return_type.pop_back();
return_str.pop_back();
} }
outs_initializer += "}"; outs_initializer += "}";
if (outs_num == 0) {
return_type = "void";
}
if (outs_num > 1) {
return_str = paddle::string::Sprintf(RETURN_TUPLE_TEMPLATE, return_str);
return_type = paddle::string::Sprintf(RETURN_TUPLE_TYPE, return_type);
}
std::string function_args = "";
if (input_args == "") {
function_args =
paddle::string::Sprintf(FUNCTION_ARGS_NO_INPUT, input_args);
} else {
function_args = paddle::string::Sprintf(FUNCTION_ARGS, input_args);
}
std::string func_name = "imperative_" + op_type; std::string func_name = "imperative_" + op_type;
// generate op funtcion body // generate op funtcion body
auto op_function_str = paddle::string::Sprintf( auto op_function_str = paddle::string::Sprintf(
OP_FUNCTION_TEMPLATE, func_name, outs_initializer, op_type); OP_FUNCTION_TEMPLATE, return_type, func_name, function_args,
outs_initializer, ins_initializer, ins_initializer_with_null, op_type,
return_str);
// generate pybind item // generate pybind item
auto bind_function_str = paddle::string::Sprintf( auto bind_function_str = paddle::string::Sprintf(
...@@ -99,7 +251,6 @@ GenerateOpFunctions(const std::string& module_name) { ...@@ -99,7 +251,6 @@ GenerateOpFunctions(const std::string& module_name) {
op_function_list.emplace_back(std::move(op_function_str)); op_function_list.emplace_back(std::move(op_function_str));
bind_function_list.emplace_back(std::move(bind_function_str)); bind_function_list.emplace_back(std::move(bind_function_str));
} }
return std::make_tuple(op_function_list, bind_function_list); return std::make_tuple(op_function_list, bind_function_list);
} }
...@@ -119,7 +270,6 @@ int main(int argc, char* argv[]) { ...@@ -119,7 +270,6 @@ int main(int argc, char* argv[]) {
out << "#include " + header + "\n"; out << "#include " + header + "\n";
} }
// all op functions
auto op_funcs = GenerateOpFunctions("m"); auto op_funcs = GenerateOpFunctions("m");
out << "namespace py = pybind11;" out << "namespace py = pybind11;"
......
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
from __future__ import print_function from __future__ import print_function
from .. import core from .. import core
from ..framework import Variable, convert_np_dtype_to_dtype_ from ..framework import Variable, convert_np_dtype_to_dtype_, _varbase_creator
from ..layers.layer_function_generator import OpProtoHolder from ..layers.layer_function_generator import OpProtoHolder
from . import to_variable, no_grad from . import to_variable, no_grad
...@@ -42,17 +42,11 @@ def monkey_patch_math_varbase(): ...@@ -42,17 +42,11 @@ def monkey_patch_math_varbase():
@no_grad @no_grad
def create_tensor(value, dtype, shape): def create_tensor(value, dtype, shape):
value = float(value) out = _varbase_creator(dtype=dtype)
inputs = {} out = core.ops.fill_constant(out, 'dtype', dtype, 'shape', shape,
attrs = { 'value', value, 'force_cpu', False)
'dtype': dtype, out.stop_gradient = True
'shape': shape, return out
'value': value,
'force_cpu': False
}
outs = core.ops.fill_constant(inputs, attrs)
outs['Out'][0].stop_gradient = True
return outs['Out'][0]
def create_scalar(value, dtype): def create_scalar(value, dtype):
return create_tensor(value, dtype, shape=[1]) return create_tensor(value, dtype, shape=[1])
...@@ -102,19 +96,11 @@ def monkey_patch_math_varbase(): ...@@ -102,19 +96,11 @@ def monkey_patch_math_varbase():
print("new var's dtype is: {}, numpy dtype is {}".format(new_variable.dtype, new_variable.numpy().dtype)) print("new var's dtype is: {}, numpy dtype is {}".format(new_variable.dtype, new_variable.numpy().dtype))
""" """
inputs = {'X': [self]} return core.ops.cast(self, 'in_dtype', self.dtype, 'out_dtype',
attrs = { convert_np_dtype_to_dtype_(dtype))
"in_dtype": self.dtype,
"out_dtype": convert_np_dtype_to_dtype_(dtype)
}
outs = core.ops.cast(inputs, attrs)
return outs['Out'][0]
def _scalar_elementwise_op_(var, scale, bias): def _scalar_elementwise_op_(var, scale, bias):
inputs = {'X': [var]} return core.ops.scale(var, 'scale', scale, 'bias', bias)
attrs = {"scale": scale, "bias": bias}
outs = core.ops.scale(inputs, attrs)
return outs['Out'][0]
def _neg_(var): def _neg_(var):
return _scalar_elementwise_op_(var, -1.0, 0.0) return _scalar_elementwise_op_(var, -1.0, 0.0)
...@@ -208,11 +194,8 @@ def monkey_patch_math_varbase(): ...@@ -208,11 +194,8 @@ def monkey_patch_math_varbase():
other_var = tmp other_var = tmp
axis = -1 axis = -1
op = getattr(core.ops, op_type) math_op = getattr(core.ops, op_type)
inputs = {'X': [self], 'Y': [other_var]} return math_op(self, other_var, 'aixs', axis)
attrs = {'axis': axis}
outs = op(inputs, attrs)
return outs['Out'][0]
comment = OpProtoHolder.instance().get_op_proto(op_type).comment comment = OpProtoHolder.instance().get_op_proto(op_type).comment
......
...@@ -218,6 +218,17 @@ class Conv2D(layers.Layer): ...@@ -218,6 +218,17 @@ class Conv2D(layers.Layer):
is_bias=True) is_bias=True)
def forward(self, input): def forward(self, input):
if in_dygraph_mode() and self._l_type == 'conv2d':
attrs = ('strides', self._stride, 'paddings', self._padding,
'dilations', self._dilation, 'groups', self._groups
if self._groups else 1, 'use_cudnn', self._use_cudnn)
out = core.ops.conv2d(input, self.weight, *attrs)
pre_bias = out
pre_act = dygraph_utils._append_bias_in_dygraph(pre_bias, self.bias,
1)
return dygraph_utils._append_activation_in_dygraph(pre_act,
self._act)
inputs = { inputs = {
'Input': [input], 'Input': [input],
'Filter': [self.weight], 'Filter': [self.weight],
...@@ -230,17 +241,6 @@ class Conv2D(layers.Layer): ...@@ -230,17 +241,6 @@ class Conv2D(layers.Layer):
'use_cudnn': self._use_cudnn, 'use_cudnn': self._use_cudnn,
'use_mkldnn': False, 'use_mkldnn': False,
} }
if in_dygraph_mode() and self._l_type == 'conv2d':
outs = core.ops.conv2d(inputs, attrs)
pre_bias = outs['Output'][0]
pre_act = dygraph_utils._append_bias_in_dygraph(pre_bias, self.bias,
1)
return dygraph_utils._append_activation_in_dygraph(pre_act,
self._act)
pre_bias = self._helper.create_variable_for_type_inference( pre_bias = self._helper.create_variable_for_type_inference(
dtype=self._dtype) dtype=self._dtype)
...@@ -825,6 +825,14 @@ class Pool2D(layers.Layer): ...@@ -825,6 +825,14 @@ class Pool2D(layers.Layer):
self._l_type = 'pool2d' self._l_type = 'pool2d'
def forward(self, input): def forward(self, input):
if in_dygraph_mode():
attrs = ('pooling_type', self._pool_type, 'ksize', self._pool_size,
'global_pooling', self._global_pooling, 'strides',
self._pool_stride, 'paddings', self._pool_padding,
'use_cudnn', self._use_cudnn, 'ceil_mode', self._ceil_mode,
'use_mkldnn', False, 'exclusive', self._exclusive)
return core.ops.pool2d(input, *attrs)
attrs = { attrs = {
"pooling_type": self._pool_type, "pooling_type": self._pool_type,
"ksize": self._pool_size, "ksize": self._pool_size,
...@@ -838,10 +846,6 @@ class Pool2D(layers.Layer): ...@@ -838,10 +846,6 @@ class Pool2D(layers.Layer):
} }
inputs = {"X": [input]} inputs = {"X": [input]}
if in_dygraph_mode():
outs = core.ops.pool2d(inputs, attrs)
return outs['Out'][0]
pool_out = self._helper.create_variable_for_type_inference(self._dtype) pool_out = self._helper.create_variable_for_type_inference(self._dtype)
self._helper.append_op( self._helper.append_op(
...@@ -922,21 +926,20 @@ class Linear(layers.Layer): ...@@ -922,21 +926,20 @@ class Linear(layers.Layer):
shape=[output_dim], attr=bias_attr, dtype=dtype, is_bias=True) shape=[output_dim], attr=bias_attr, dtype=dtype, is_bias=True)
def forward(self, input): def forward(self, input):
attrs = {
"x_num_col_dims": len(input.shape) - 1,
"y_num_col_dims": 1,
}
inputs = {"X": [input], "Y": [self.weight]}
if in_dygraph_mode(): if in_dygraph_mode():
outs = core.ops.mul(inputs, attrs) pre_bias = core.ops.mul(input, self.weight, 'x_num_col_dims',
pre_bias = outs['Out'][0] len(input.shape) - 1, 'y_num_col_dims', 1)
pre_act = dygraph_utils._append_bias_in_dygraph( pre_act = dygraph_utils._append_bias_in_dygraph(
pre_bias, self.bias, axis=len(input.shape) - 1) pre_bias, self.bias, axis=len(input.shape) - 1)
return dygraph_utils._append_activation_in_dygraph(pre_act, return dygraph_utils._append_activation_in_dygraph(pre_act,
self._act) self._act)
attrs = {
"x_num_col_dims": len(input.shape) - 1,
"y_num_col_dims": 1,
}
inputs = {"X": [input], "Y": [self.weight]}
tmp = self._helper.create_variable_for_type_inference(self._dtype) tmp = self._helper.create_variable_for_type_inference(self._dtype)
self._helper.append_op( self._helper.append_op(
...@@ -1128,8 +1131,22 @@ class BatchNorm(layers.Layer): ...@@ -1128,8 +1131,22 @@ class BatchNorm(layers.Layer):
# mean and mean_out share the same memory # mean and mean_out share the same memory
mean_out = self._mean mean_out = self._mean
# variance and variance out share the same memory # variance and variance out share the same memory
variance_out = self._variance variance_out = self._variance
if in_dygraph_mode():
_is_test = (not _dygraph_tracer()._train_mode) and (
not self._trainable_statistics)
attrs = ("momentum", self._momentum, "epsilon", self._epsilon,
"is_test", _is_test, "data_layout", self._data_layout,
"use_mkldnn", False, "fuse_with_relu",
self._fuse_with_relu, "use_global_stats",
self._use_global_stats)
batch_norm_out, _, _, _, _ = core.ops.batch_norm(
input, self.weight, self.bias, self._mean, self._variance,
mean_out, variance_out, *attrs)
return dygraph_utils._append_activation_in_dygraph(
batch_norm_out, act=self._act)
attrs = { attrs = {
"momentum": self._momentum, "momentum": self._momentum,
"epsilon": self._epsilon, "epsilon": self._epsilon,
...@@ -1149,14 +1166,6 @@ class BatchNorm(layers.Layer): ...@@ -1149,14 +1166,6 @@ class BatchNorm(layers.Layer):
"Variance": [self._variance] "Variance": [self._variance]
} }
if in_dygraph_mode():
attrs['is_test'] = not _dygraph_tracer()._train_mode
saved_mean = _varbase_creator(dtype=self._dtype)
saved_variance = _varbase_creator(dtype=self._dtype)
batch_norm_out = _varbase_creator(dtype=self._dtype)
batch_norm_out.stop_gradient = False
# inplace is not supported currently
else:
saved_mean = self._helper.create_variable_for_type_inference( saved_mean = self._helper.create_variable_for_type_inference(
dtype=self._dtype, stop_gradient=True) dtype=self._dtype, stop_gradient=True)
saved_variance = self._helper.create_variable_for_type_inference( saved_variance = self._helper.create_variable_for_type_inference(
...@@ -1172,11 +1181,6 @@ class BatchNorm(layers.Layer): ...@@ -1172,11 +1181,6 @@ class BatchNorm(layers.Layer):
"SavedVariance": [saved_variance] "SavedVariance": [saved_variance]
} }
if in_dygraph_mode():
outs = core.ops.batch_norm(inputs, attrs, outputs)
return dygraph_utils._append_activation_in_dygraph(
batch_norm_out, act=self._act)
self._helper.append_op( self._helper.append_op(
type="batch_norm", inputs=inputs, outputs=outputs, attrs=attrs) type="batch_norm", inputs=inputs, outputs=outputs, attrs=attrs)
...@@ -1315,6 +1319,12 @@ class Embedding(layers.Layer): ...@@ -1315,6 +1319,12 @@ class Embedding(layers.Layer):
is_bias=False) is_bias=False)
def forward(self, input): def forward(self, input):
if in_dygraph_mode():
return core.ops.lookup_table_v2(
self.weight, input, 'is_sparse', self._is_sparse,
'is_distributed', self._is_distributed, 'remote_prefetch',
self._remote_prefetch, 'padding_idx', self._padding_idx)
attrs = { attrs = {
'is_sparse': self._is_sparse, 'is_sparse': self._is_sparse,
'is_distributed': self._is_distributed, 'is_distributed': self._is_distributed,
...@@ -1322,11 +1332,6 @@ class Embedding(layers.Layer): ...@@ -1322,11 +1332,6 @@ class Embedding(layers.Layer):
'padding_idx': self._padding_idx 'padding_idx': self._padding_idx
} }
if in_dygraph_mode():
inputs = {'Ids': [input], 'W': [self.weight]}
outs = core.ops.lookup_table_v2(inputs, attrs)
return outs['Out'][0]
out = self._helper.create_variable_for_type_inference(self._dtype) out = self._helper.create_variable_for_type_inference(self._dtype)
self._helper.append_op( self._helper.append_op(
type='lookup_table_v2', type='lookup_table_v2',
...@@ -1436,6 +1441,7 @@ class LayerNorm(layers.Layer): ...@@ -1436,6 +1441,7 @@ class LayerNorm(layers.Layer):
else: else:
if self._param_attr: if self._param_attr:
logging.warn("param_attr are only available with scale is True") logging.warn("param_attr are only available with scale is True")
self.weight = None
if self._shift: if self._shift:
assert self._bias_attr is not False assert self._bias_attr is not False
...@@ -1447,6 +1453,7 @@ class LayerNorm(layers.Layer): ...@@ -1447,6 +1453,7 @@ class LayerNorm(layers.Layer):
else: else:
if self._bias_attr: if self._bias_attr:
logging.warn("bias_attr are only available with shift is True") logging.warn("bias_attr are only available with shift is True")
self.bias = None
def forward(self, input): def forward(self, input):
input_shape = list(input.shape) input_shape = list(input.shape)
...@@ -1460,24 +1467,25 @@ class LayerNorm(layers.Layer): ...@@ -1460,24 +1467,25 @@ class LayerNorm(layers.Layer):
'Given normalized_shape is ' + str_normalized_shape + 'Given normalized_shape is ' + str_normalized_shape +
', expected input with shape [*, ' + str_normalized_shape[ ', expected input with shape [*, ' + str_normalized_shape[
1:] + ', but got input shape ' + str(input_shape)) 1:] + ', but got input shape ' + str(input_shape))
if in_dygraph_mode():
pre_act, _, _ = core.ops.layer_norm(
input, self.weight, self.bias, 'epsilon', self._epsilon,
'begin_norm_axis', self._begin_norm_axis)
return dygraph_utils._append_activation_in_dygraph(
pre_act, act=self._act)
inputs = dict() inputs = dict()
inputs['X'] = [input] inputs['X'] = [input]
if self._scale: if self._scale:
inputs['Scale'] = [self.weight] inputs['Scale'] = [self.weight]
if self._shift: if self._shift:
inputs['Bias'] = [self.bias] inputs['Bias'] = [self.bias]
attrs = { attrs = {
"epsilon": self._epsilon, "epsilon": self._epsilon,
"begin_norm_axis": self._begin_norm_axis "begin_norm_axis": self._begin_norm_axis
} }
if in_dygraph_mode():
outs = core.ops.layer_norm(inputs, attrs)
pre_act = outs['Y'][0]
return dygraph_utils._append_activation_in_dygraph(
pre_act, act=self._act)
# create output # create output
mean_out = self._helper.create_variable_for_type_inference( mean_out = self._helper.create_variable_for_type_inference(
dtype=self._dtype, stop_gradient=True) dtype=self._dtype, stop_gradient=True)
...@@ -1642,6 +1650,12 @@ class GRUUnit(layers.Layer): ...@@ -1642,6 +1650,12 @@ class GRUUnit(layers.Layer):
attr=bias_attr, shape=bias_size, dtype=dtype, is_bias=True) attr=bias_attr, shape=bias_size, dtype=dtype, is_bias=True)
def forward(self, input, hidden): def forward(self, input, hidden):
if in_dygraph_mode():
gate, reset_hidden_pre, updated_hidden = core.ops.gru_unit(
input, hidden, self.weight, self.bias, 'activation',
self.activation, 'gate_activation', self.gate_activation)
return updated_hidden, reset_hidden_pre, gate
inputs = { inputs = {
'Input': [input], 'Input': [input],
'HiddenPrev': [hidden], 'HiddenPrev': [hidden],
...@@ -1653,12 +1667,6 @@ class GRUUnit(layers.Layer): ...@@ -1653,12 +1667,6 @@ class GRUUnit(layers.Layer):
'activation': self.activation, 'activation': self.activation,
'gate_activation': self.gate_activation, 'gate_activation': self.gate_activation,
} }
if in_dygraph_mode():
outs = core.ops.gru_unit(inputs, attrs)
return outs['Hidden'][0], outs['ResetHiddenPrev'][0], outs['Gate'][
0]
gate = self._helper.create_variable_for_type_inference(self._dtype) gate = self._helper.create_variable_for_type_inference(self._dtype)
reset_hidden_pre = self._helper.create_variable_for_type_inference( reset_hidden_pre = self._helper.create_variable_for_type_inference(
self._dtype) self._dtype)
...@@ -2310,6 +2318,18 @@ class Conv2DTranspose(layers.Layer): ...@@ -2310,6 +2318,18 @@ class Conv2DTranspose(layers.Layer):
is_bias=True) is_bias=True)
def forward(self, input): def forward(self, input):
if in_dygraph_mode():
op = getattr(core.ops, self._op_type)
out = op(input, self.weight, 'output_size', self._output_size,
'strides', self._stride, 'paddings', self._padding,
'dilations', self._dilation, 'groups', self._groups,
'use_cudnn', self._use_cudnn)
pre_bias = out
pre_act = dygraph_utils._append_bias_in_dygraph(pre_bias, self.bias,
1)
return dygraph_utils._append_activation_in_dygraph(
pre_act, act=self._act)
inputs = {'Input': [input], 'Filter': [self.weight]} inputs = {'Input': [input], 'Filter': [self.weight]}
attrs = { attrs = {
'output_size': self._output_size, 'output_size': self._output_size,
...@@ -2320,15 +2340,6 @@ class Conv2DTranspose(layers.Layer): ...@@ -2320,15 +2340,6 @@ class Conv2DTranspose(layers.Layer):
'use_cudnn': self._use_cudnn 'use_cudnn': self._use_cudnn
} }
if in_dygraph_mode():
op = getattr(core.ops, self._op_type)
outs = op(inputs, attrs)
pre_bias = outs['Output'][0]
pre_act = dygraph_utils._append_bias_in_dygraph(pre_bias, self.bias,
1)
return dygraph_utils._append_activation_in_dygraph(
pre_act, act=self._act)
pre_bias = self._helper.create_variable_for_type_inference( pre_bias = self._helper.create_variable_for_type_inference(
dtype=input.dtype) dtype=input.dtype)
self._helper.append_op( self._helper.append_op(
......
...@@ -33,15 +33,15 @@ def _append_activation_in_dygraph(input, ...@@ -33,15 +33,15 @@ def _append_activation_in_dygraph(input,
""" """
if not act: if not act:
return input return input
attrs = {}
if (use_cudnn is not None) and use_cudnn: attrs = ()
attrs['use_cudnn'] = use_cudnn if use_cudnn:
if (use_mkldnn is not None) and use_mkldnn: attrs = ('use_cudnn', use_cudnn)
attrs['use_mkldnn'] = use_mkldnn if use_mkldnn:
inputs = {"X": [input]} attrs += ('use_mkldnn', use_mkldnn)
act_op = getattr(core.ops, act) act_op = getattr(core.ops, act)
res = act_op(inputs, attrs) return act_op(input, *attrs)
return res['Out'][0]
@dygraph_only @dygraph_only
...@@ -58,7 +58,4 @@ def _append_bias_in_dygraph(input, bias=None, axis=1): ...@@ -58,7 +58,4 @@ def _append_bias_in_dygraph(input, bias=None, axis=1):
if not bias: if not bias:
return input return input
attrs = {'axis': axis} return core.ops.elementwise_add(input, bias, 'axis', axis)
inputs = {'X': [input], 'Y': [bias]}
outs = core.ops.elementwise_add(inputs, attrs)
return outs['Out'][0]
...@@ -253,10 +253,8 @@ def generate_activation_fn(op_type): ...@@ -253,10 +253,8 @@ def generate_activation_fn(op_type):
def func(x, name=None): def func(x, name=None):
if in_dygraph_mode(): if in_dygraph_mode():
inputs = {'X': [x]}
op = getattr(core.ops, op_type) op = getattr(core.ops, op_type)
outs = op(inputs) return op(x)
return outs['Out'][0]
check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'], check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'],
op_type) op_type)
......
...@@ -238,13 +238,13 @@ def cross_entropy(input, label, soft_label=False, ignore_index=kIgnoreIndex): ...@@ -238,13 +238,13 @@ def cross_entropy(input, label, soft_label=False, ignore_index=kIgnoreIndex):
if not soft_label: if not soft_label:
return cross_entropy2(input, label, ignore_index) return cross_entropy2(input, label, ignore_index)
if in_dygraph_mode():
return core.ops.cross_entropy(input, label, "soft_label", soft_label,
"ignore_index", ignore_index)
inputs = {'X': [input], 'Label': [label]} inputs = {'X': [input], 'Label': [label]}
attrs = {"soft_label": soft_label, "ignore_index": ignore_index} attrs = {"soft_label": soft_label, "ignore_index": ignore_index}
if in_dygraph_mode():
outs = core.ops.cross_entropy(inputs, attrs)
return outs['Y'][0]
check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'], check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'],
'cross_entropy') 'cross_entropy')
helper = LayerHelper('cross_entropy', **locals()) helper = LayerHelper('cross_entropy', **locals())
...@@ -255,13 +255,13 @@ def cross_entropy(input, label, soft_label=False, ignore_index=kIgnoreIndex): ...@@ -255,13 +255,13 @@ def cross_entropy(input, label, soft_label=False, ignore_index=kIgnoreIndex):
def cross_entropy2(input, label, ignore_index=kIgnoreIndex): def cross_entropy2(input, label, ignore_index=kIgnoreIndex):
inputs = {'X': [input], 'Label': [label]}
attrs = {'ignore_index': ignore_index}
if in_dygraph_mode(): if in_dygraph_mode():
outs = core.ops.cross_entropy2(inputs, attrs) loss, _, _ = core.ops.cross_entropy2(input, label, 'ignore_index',
return outs['Y'][0] ignore_index)
return loss
inputs = {'X': [input], 'Label': [label]}
attrs = {'ignore_index': ignore_index}
check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'], check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'],
'cross_entropy2') 'cross_entropy2')
helper = LayerHelper('cross_entropy2', **locals()) helper = LayerHelper('cross_entropy2', **locals())
...@@ -1233,21 +1233,22 @@ def softmax_with_cross_entropy(logits, ...@@ -1233,21 +1233,22 @@ def softmax_with_cross_entropy(logits,
out = fluid.layers.softmax_with_cross_entropy( out = fluid.layers.softmax_with_cross_entropy(
logits=fc, label=label) logits=fc, label=label)
""" """
if in_dygraph_mode():
softmax, loss = core.ops.softmax_with_cross_entropy(
logits, label, 'soft_label', soft_label, 'ignore_index',
ignore_index, 'numeric_stable_mode', numeric_stable_mode, 'axis',
axis)
if not return_softmax:
return loss
else:
return loss, softmax
attrs = { attrs = {
'soft_label': soft_label, 'soft_label': soft_label,
'ignore_index': ignore_index, 'ignore_index': ignore_index,
'numeric_stable_mode': numeric_stable_mode, 'numeric_stable_mode': numeric_stable_mode,
'axis': axis 'axis': axis
} }
if in_dygraph_mode():
inputs = {'Logits': [logits], 'Label': [label]}
outs = core.ops.softmax_with_cross_entropy(inputs, attrs)
if not return_softmax:
return outs['Loss'][0]
else:
return outs['Loss'][0], outs['Softmax'][0]
helper = LayerHelper('softmax_with_cross_entropy', **locals()) helper = LayerHelper('softmax_with_cross_entropy', **locals())
softmax = helper.create_variable_for_type_inference(dtype=logits.dtype) softmax = helper.create_variable_for_type_inference(dtype=logits.dtype)
loss = helper.create_variable_for_type_inference(dtype=logits.dtype) loss = helper.create_variable_for_type_inference(dtype=logits.dtype)
......
...@@ -74,24 +74,15 @@ def accuracy(input, label, k=1, correct=None, total=None): ...@@ -74,24 +74,15 @@ def accuracy(input, label, k=1, correct=None, total=None):
#[array([0.6666667], dtype=float32)] #[array([0.6666667], dtype=float32)]
""" """
if in_dygraph_mode(): if in_dygraph_mode():
topk_out, topk_indices = nn.topk(input, k=k)
inputs = {
"Out": [topk_out],
"Indices": [topk_indices],
"Label": [label]
}
acc_out = _varbase_creator(dtype="float32")
if correct is None: if correct is None:
correct = _varbase_creator(dtype="int64") correct = _varbase_creator(dtype="int32")
if total is None: if total is None:
total = _varbase_creator(dtype="int64") total = _varbase_creator(dtype="int32")
outputs = {
"Accuracy": [acc_out], topk_out, topk_indices = nn.topk(input, k=k)
"Correct": [correct], _acc, _, _ = core.ops.accuracy(topk_out, topk_indices, label, correct,
"Total": [total] total)
} return _acc
outs = core.ops.accuracy(inputs, {}, outputs)
return outs['Accuracy'][0]
helper = LayerHelper("accuracy", **locals()) helper = LayerHelper("accuracy", **locals())
check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'], check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'],
...@@ -99,9 +90,9 @@ def accuracy(input, label, k=1, correct=None, total=None): ...@@ -99,9 +90,9 @@ def accuracy(input, label, k=1, correct=None, total=None):
topk_out, topk_indices = nn.topk(input, k=k) topk_out, topk_indices = nn.topk(input, k=k)
acc_out = helper.create_variable_for_type_inference(dtype="float32") acc_out = helper.create_variable_for_type_inference(dtype="float32")
if correct is None: if correct is None:
correct = helper.create_variable_for_type_inference(dtype="int64") correct = helper.create_variable_for_type_inference(dtype="int32")
if total is None: if total is None:
total = helper.create_variable_for_type_inference(dtype="int64") total = helper.create_variable_for_type_inference(dtype="int32")
helper.append_op( helper.append_op(
type="accuracy", type="accuracy",
inputs={ inputs={
......
...@@ -192,11 +192,8 @@ def _elementwise_op_in_dygraph(x, ...@@ -192,11 +192,8 @@ def _elementwise_op_in_dygraph(x,
act=None, act=None,
use_mkldnn=False, use_mkldnn=False,
op_name=None): op_name=None):
attrs = {'axis': axis, 'use_mkldnn': use_mkldnn}
inputs = {'X': [x], 'Y': [y]}
op = getattr(core.ops, op_name) op = getattr(core.ops, op_name)
outs = op(inputs, attrs) out = op(x, y, 'axis', axis, 'use_mkldnn', use_mkldnn)
out = outs['Out'][0]
return dygraph_utils._append_activation_in_dygraph( return dygraph_utils._append_activation_in_dygraph(
out, act, use_mkldnn=use_mkldnn) out, act, use_mkldnn=use_mkldnn)
...@@ -835,11 +832,16 @@ def dropout(x, ...@@ -835,11 +832,16 @@ def dropout(x,
return attrs return attrs
if in_dygraph_mode(): if in_dygraph_mode():
attrs = get_attrs(default_main_program(), dropout_prob, is_test, seed) if (seed is None or
attrs['is_test'] = not _dygraph_tracer()._train_mode seed == 0) and default_main_program().random_seed != 0:
inputs = {'X': [x]} seed = default_main_program().random_seed
outs = core.ops.dropout(inputs, attrs) seed = seed if seed is not None else 0
return outs['Out'][0] _is_test = not _dygraph_tracer()._train_mode
out, mask = core.ops.dropout(x, 'dropout_prob', dropout_prob, 'is_test',
_is_test, 'fix_seed', seed is not None,
'seed', seed, 'dropout_implementation',
dropout_implementation)
return out
helper = LayerHelper('dropout', **locals()) helper = LayerHelper('dropout', **locals())
check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'], check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'],
...@@ -1118,12 +1120,12 @@ def softmax(input, use_cudnn=False, name=None, axis=-1): ...@@ -1118,12 +1120,12 @@ def softmax(input, use_cudnn=False, name=None, axis=-1):
fetch_list=[result[0]]) fetch_list=[result[0]])
print(output) print(output)
""" """
inputs = {"X": [input]}
attrs = {"axis": axis, "use_cudnn": use_cudnn}
if in_dygraph_mode(): if in_dygraph_mode():
outs = core.ops.softmax(inputs, attrs) return core.ops.softmax(input, 'axis', axis, 'use_cudnn', use_cudnn)
return outs['Out'][0]
inputs = {"X": [input]}
attrs = {"axis": axis, "use_cudnn": use_cudnn}
helper = LayerHelper('softmax', **locals()) helper = LayerHelper('softmax', **locals())
check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'], check_variable_and_dtype(input, 'input', ['float16', 'float32', 'float64'],
...@@ -3887,17 +3889,17 @@ def reduce_sum(input, dim=None, keep_dim=False, name=None): ...@@ -3887,17 +3889,17 @@ def reduce_sum(input, dim=None, keep_dim=False, name=None):
""" """
if dim is not None and not isinstance(dim, list): if dim is not None and not isinstance(dim, list):
dim = [dim] dim = [dim]
if in_dygraph_mode():
reduce_all = True if dim == None or dim == [] else False
dim = dim if dim != None and dim != [] else [0]
return core.ops.reduce_sum(input, 'dim', dim, 'keep_dim', keep_dim,
'reduce_all', reduce_all)
attrs = { attrs = {
'dim': dim if dim != None and dim != [] else [0], 'dim': dim if dim != None and dim != [] else [0],
'keep_dim': keep_dim, 'keep_dim': keep_dim,
'reduce_all': True if dim == None or dim == [] else False 'reduce_all': True if dim == None or dim == [] else False
} }
if in_dygraph_mode():
inputs = {'X': [input]}
outs = core.ops.reduce_sum(inputs, attrs)
return outs['Out'][0]
check_variable_and_dtype( check_variable_and_dtype(
input, 'input', ['float32', 'float64', 'int32', 'int64'], 'reduce_sum') input, 'input', ['float32', 'float64', 'int32', 'int64'], 'reduce_sum')
helper = LayerHelper('reduce_sum', **locals()) helper = LayerHelper('reduce_sum', **locals())
...@@ -3962,17 +3964,17 @@ def reduce_mean(input, dim=None, keep_dim=False, name=None): ...@@ -3962,17 +3964,17 @@ def reduce_mean(input, dim=None, keep_dim=False, name=None):
if dim is not None and not isinstance(dim, list): if dim is not None and not isinstance(dim, list):
dim = [dim] dim = [dim]
if in_dygraph_mode():
reduce_all = True if dim == None or dim == [] else False
dim = dim if dim != None and dim != [] else [0]
return core.ops.reduce_mean(input, 'dim', dim, 'keep_dim', keep_dim,
'reduce_all', reduce_all)
attrs = { attrs = {
'dim': dim if dim != None and dim != [] else [0], 'dim': dim if dim != None and dim != [] else [0],
'keep_dim': keep_dim, 'keep_dim': keep_dim,
'reduce_all': True if dim == None or dim == [] else False 'reduce_all': True if dim == None or dim == [] else False
} }
if in_dygraph_mode():
inputs = {'X': [input]}
outs = core.ops.reduce_mean(inputs, attrs)
return outs['Out'][0]
check_variable_and_dtype( check_variable_and_dtype(
input, 'input', ['float32', 'float64', 'int32', 'int64'], 'reduce_mean') input, 'input', ['float32', 'float64', 'int32', 'int64'], 'reduce_mean')
helper = LayerHelper('reduce_mean', **locals()) helper = LayerHelper('reduce_mean', **locals())
...@@ -4333,19 +4335,20 @@ def split(input, num_or_sections, dim=-1, name=None): ...@@ -4333,19 +4335,20 @@ def split(input, num_or_sections, dim=-1, name=None):
# x2.shape [3, 4, 5] # x2.shape [3, 4, 5]
""" """
if in_dygraph_mode(): if in_dygraph_mode():
inputs = {'X': [input]} num = None
attrs = {} attrs = ()
if isinstance(dim, Variable): if isinstance(dim, Variable):
dim = dim.numpy() dim = dim.numpy()
assert dim.shape == (1, assert dim.shape == (1,
), "dim of type Variable should have shape [1]" ), "dim of type Variable should have shape [1]"
dim = dim[0] dim = dim[0]
dim = (len(input.shape) + dim) if dim < 0 else dim dim = (len(input.shape) + dim) if dim < 0 else dim
attrs['axis'] = dim attrs += ('axis', dim)
if isinstance(num_or_sections, int): if isinstance(num_or_sections, int):
num = num_or_sections num = num_or_sections
attrs['num'] = num_or_sections attrs += ('num', num_or_sections)
elif isinstance(num_or_sections, (list, tuple)): elif isinstance(num_or_sections, (list, tuple)):
num = len(num_or_sections) num = len(num_or_sections)
if utils._contain_var(num_or_sections): if utils._contain_var(num_or_sections):
...@@ -4354,14 +4357,12 @@ def split(input, num_or_sections, dim=-1, name=None): ...@@ -4354,14 +4357,12 @@ def split(input, num_or_sections, dim=-1, name=None):
"received %s, which contains Variable." % "received %s, which contains Variable." %
(type(num_or_sections))) (type(num_or_sections)))
else: else:
attrs['sections'] = list(num_or_sections) attrs += ('sections', list(num_or_sections))
else: else:
raise TypeError( raise TypeError(
"The type of 'num_or_sections' in split must be int or list in Dygraph mode, but " "The type of 'num_or_sections' in split must be int or list in Dygraph mode, but "
"received %s." % (type(num_or_sections))) "received %s." % (type(num_or_sections)))
return core.ops.split(input, num, *attrs)
res = core.ops.split(inputs, attrs, {}, {'Out': num})
return res['Out']
if not isinstance(num_or_sections, (int, list, tuple)): if not isinstance(num_or_sections, (int, list, tuple)):
raise TypeError( raise TypeError(
...@@ -4596,9 +4597,8 @@ def matmul(x, y, transpose_x=False, transpose_y=False, alpha=1.0, name=None): ...@@ -4596,9 +4597,8 @@ def matmul(x, y, transpose_x=False, transpose_y=False, alpha=1.0, name=None):
} }
if in_dygraph_mode(): if in_dygraph_mode():
inputs = {'X': [x], 'Y': [y]} return core.ops.matmul(x, y, 'transpose_X', transpose_x, 'transpose_Y',
outs = core.ops.matmul(inputs, attrs) transpose_y, 'alpha', float(alpha))
return outs['Out'][0]
def __check_input(x, y): def __check_input(x, y):
var_names = {'x': x, 'y': y} var_names = {'x': x, 'y': y}
...@@ -4716,20 +4716,15 @@ def topk(input, k, name=None): ...@@ -4716,20 +4716,15 @@ def topk(input, k, name=None):
vk_values, vk_indices = layers.topk(input2, k=vk) #vk_values.shape=[None, 13, k], vk_indices.shape=[None, 13, k] vk_values, vk_indices = layers.topk(input2, k=vk) #vk_values.shape=[None, 13, k], vk_indices.shape=[None, 13, k]
""" """
inputs = {"X": [input]}
attrs = {}
if in_dygraph_mode(): if in_dygraph_mode():
if isinstance(k, Variable): _k = k.numpy().item(0) if isinstance(k, Variable) else k
k = k.numpy() out, indices = core.ops.top_k(input, 'k', _k)
assert k.shape == (1, ), "k of type Variable should have shape [1]" out.stop_gradient = True
k = k[0] indices.stop_gradient = True
attrs = {'k': k} return out, indices
outs = core.ops.top_k(inputs, attrs)
outs['Out'][0].stop_gradient = True
outs['Indices'][0].stop_gradient = True
return outs['Out'][0], outs['Indices'][0]
inputs = {"X": [input]}
attrs = {}
if isinstance(k, Variable): if isinstance(k, Variable):
inputs['K'] = [k] inputs['K'] = [k]
else: else:
...@@ -4965,10 +4960,8 @@ def transpose(x, perm, name=None): ...@@ -4965,10 +4960,8 @@ def transpose(x, perm, name=None):
""" """
if in_dygraph_mode(): if in_dygraph_mode():
attrs = {'axis': perm} out, _ = core.ops.transpose2(x, 'axis', perm)
inputs = {'X': [x]} return out
outs = core.ops.transpose2(inputs, attrs)
return outs['Out'][0]
check_variable_and_dtype( check_variable_and_dtype(
x, 'x', ['float16', 'float32', 'float64', 'int32', 'int64'], x, 'x', ['float16', 'float32', 'float64', 'int32', 'int64'],
...@@ -5413,11 +5406,10 @@ def one_hot(input, depth, allow_out_of_range=False): ...@@ -5413,11 +5406,10 @@ def one_hot(input, depth, allow_out_of_range=False):
assert depth.shape == ( assert depth.shape == (
1, ), "depth of type Variable should have shape [1]" 1, ), "depth of type Variable should have shape [1]"
depth = depth[0] depth = depth[0]
inputs = {'X': [input]} out = core.ops.one_hot(input, 'depth', depth, 'allow_out_of_range',
attrs = {'depth': depth, 'allow_out_of_range': allow_out_of_range} allow_out_of_range)
outs = core.ops.one_hot(inputs, attrs) out.stop_gradient = True
outs['Out'][0].stop_gradient = True return out
return outs['Out'][0]
helper = LayerHelper("one_hot", **locals()) helper = LayerHelper("one_hot", **locals())
one_hot_out = helper.create_variable_for_type_inference(dtype='float32') one_hot_out = helper.create_variable_for_type_inference(dtype='float32')
...@@ -5597,9 +5589,7 @@ def reshape(x, shape, actual_shape=None, act=None, inplace=False, name=None): ...@@ -5597,9 +5589,7 @@ def reshape(x, shape, actual_shape=None, act=None, inplace=False, name=None):
"The type of 'shape' in reshape must be list[int] or tuple(int) in Dygraph mode, but " "The type of 'shape' in reshape must be list[int] or tuple(int) in Dygraph mode, but "
"received %s." % type(shape)) "received %s." % type(shape))
inputs = {'X': [x]} out, _ = core.ops.reshape2(x, 'shape', shape)
outs = core.ops.reshape2(inputs, attrs)
out = outs['Out'][0]
return dygraph_utils._append_activation_in_dygraph(out, act) return dygraph_utils._append_activation_in_dygraph(out, act)
check_variable_and_dtype( check_variable_and_dtype(
...@@ -6274,12 +6264,8 @@ def label_smooth(label, ...@@ -6274,12 +6264,8 @@ def label_smooth(label,
raise ValueError("The value of epsilon must be between 0 and 1.") raise ValueError("The value of epsilon must be between 0 and 1.")
if in_dygraph_mode(): if in_dygraph_mode():
inputs = {"X": [label]} return core.ops.label_smooth(label, prior_dist, 'epsilon',
if prior_dist: float(epsilon))
inputs["PriorDist"] = [prior_dist]
attrs = {"epsilon": float(epsilon)}
outs = core.ops.label_smooth(inputs, attrs)
return outs['Out'][0]
helper = LayerHelper("label_smooth", **locals()) helper = LayerHelper("label_smooth", **locals())
label.stop_gradient = True label.stop_gradient = True
...@@ -7854,11 +7840,10 @@ def log(x, name=None): ...@@ -7854,11 +7840,10 @@ def log(x, name=None):
res_val, = exe.run(fluid.default_main_program(), feed={'x':x_i}, fetch_list=[res]) res_val, = exe.run(fluid.default_main_program(), feed={'x':x_i}, fetch_list=[res])
print(res_val) # [[0.], [0.6931472]] print(res_val) # [[0.], [0.6931472]]
""" """
inputs = {'X': [x]}
if in_dygraph_mode(): if in_dygraph_mode():
outs = core.ops.log(inputs) return core.ops.log(x)
return outs['Out'][0]
inputs = {'X': [x]}
helper = LayerHelper('log', **locals()) helper = LayerHelper('log', **locals())
dtype = helper.input_dtype(input_param_name='x') dtype = helper.input_dtype(input_param_name='x')
out = helper.create_variable_for_type_inference(dtype) out = helper.create_variable_for_type_inference(dtype)
...@@ -7894,11 +7879,10 @@ def relu(x, name=None): ...@@ -7894,11 +7879,10 @@ def relu(x, name=None):
# [[0. 0. ] # [[0. 0. ]
# [1. 2.6]] # [1. 2.6]]
""" """
inputs = {'X': [x]}
if in_dygraph_mode(): if in_dygraph_mode():
outs = core.ops.relu(inputs) return core.ops.relu(x)
return outs['Out'][0]
inputs = {'X': [x]}
helper = LayerHelper('relu', **locals()) helper = LayerHelper('relu', **locals())
dtype = helper.input_dtype(input_param_name='x') dtype = helper.input_dtype(input_param_name='x')
out = helper.create_variable_for_type_inference(dtype) out = helper.create_variable_for_type_inference(dtype)
...@@ -8480,6 +8464,13 @@ def pad2d(input, ...@@ -8480,6 +8464,13 @@ def pad2d(input,
result = fluid.layers.pad2d(input=data, paddings=[1, 2, 3, 4], result = fluid.layers.pad2d(input=data, paddings=[1, 2, 3, 4],
mode='reflect') mode='reflect')
""" """
if in_dygraph_mode():
_paddings = paddings.numpy().tolist() if isinstance(
paddings, Variable) else paddings
return core.ops.pad2d(input, 'mode', mode, 'pad_value', pad_value,
'data_format', data_format, 'paddings', _paddings)
attrs = {'mode': mode, 'pad_value': pad_value, 'data_format': data_format} attrs = {'mode': mode, 'pad_value': pad_value, 'data_format': data_format}
inputs = {'X': [input]} inputs = {'X': [input]}
if isinstance(paddings, Variable): if isinstance(paddings, Variable):
...@@ -8488,10 +8479,6 @@ def pad2d(input, ...@@ -8488,10 +8479,6 @@ def pad2d(input,
else: else:
attrs['paddings'] = paddings attrs['paddings'] = paddings
if in_dygraph_mode():
outs = core.ops.pad2d(inputs, attrs)
return outs['Out'][0]
helper = LayerHelper('pad2d', **locals()) helper = LayerHelper('pad2d', **locals())
assert mode in ['reflect', 'edge', 'constant' assert mode in ['reflect', 'edge', 'constant'
...@@ -8927,12 +8914,11 @@ def leaky_relu(x, alpha=0.02, name=None): ...@@ -8927,12 +8914,11 @@ def leaky_relu(x, alpha=0.02, name=None):
res_val, = exe.run(fluid.default_main_program(), feed={'x':x_i}, fetch_list=[res]) res_val, = exe.run(fluid.default_main_program(), feed={'x':x_i}, fetch_list=[res])
print(res_val) # [[-0.1, 2], [3, -0.4]] print(res_val) # [[-0.1, 2], [3, -0.4]]
""" """
inputs = {'X': [x]}
attrs = {'alpha': alpha}
if in_dygraph_mode(): if in_dygraph_mode():
outs = core.ops.leaky_relu(inputs, attrs) return core.ops.leaky_relu(x, 'alpha', alpha)
return outs['Out'][0]
inputs = {'X': [x]}
attrs = {'alpha': alpha}
helper = LayerHelper('leaky_relu', **locals()) helper = LayerHelper('leaky_relu', **locals())
out = helper.create_variable_for_type_inference(dtype=x.dtype) out = helper.create_variable_for_type_inference(dtype=x.dtype)
helper.append_op( helper.append_op(
...@@ -9351,24 +9337,21 @@ def expand(x, expand_times, name=None): ...@@ -9351,24 +9337,21 @@ def expand(x, expand_times, name=None):
expanded_2 = fluid.layers.expand(data_2, expand_times=expand_times) expanded_2 = fluid.layers.expand(data_2, expand_times=expand_times)
# the shape of expanded_2 is [48, 56]. # the shape of expanded_2 is [48, 56].
""" """
inputs = {"X": [x]}
attrs = {}
if in_dygraph_mode(): if in_dygraph_mode():
if isinstance(expand_times, (list, tuple)): if isinstance(expand_times, (list, tuple)):
if utils._contain_var(expand_times): if utils._contain_var(expand_times):
raise TypeError( raise TypeError(
"The type of 'expand_times' in expand must be list[int] or tuple(int) in Dygraph mode, but " "The type of 'expand_times' in expand must be list[int] or tuple(int) in Dygraph mode, but "
"received %s, which contains Variable." % type(shape)) "received %s, which contains Variable." % type(shape))
attrs['expand_times'] = expand_times
else: else:
raise TypeError( raise TypeError(
"The type of 'expand_times' in expand must be list[int] or tuple(int) in Dygraph mode, but " "The type of 'expand_times' in expand must be list[int] or tuple(int) in Dygraph mode, but "
"received %s." % type(shape)) "received %s." % type(shape))
outs = core.ops.expand(inputs, attrs) return core.ops.expand(x, 'expand_times', expand_times)
return outs['Out'][0]
inputs = {"X": [x]}
attrs = {}
check_variable_and_dtype( check_variable_and_dtype(
x, 'x', ['bool', 'float32', 'float64', 'int32', 'int64'], 'expand') x, 'x', ['bool', 'float32', 'float64', 'int32', 'int64'], 'expand')
check_type(expand_times, 'expand_times', (list, tuple, Variable), 'expand') check_type(expand_times, 'expand_times', (list, tuple, Variable), 'expand')
...@@ -9908,8 +9891,6 @@ def slice(input, axes, starts, ends): ...@@ -9908,8 +9891,6 @@ def slice(input, axes, starts, ends):
""" """
if in_dygraph_mode(): if in_dygraph_mode():
infer_flags = list(1 for i in range(len(axes))) infer_flags = list(1 for i in range(len(axes)))
inputs = {'Input': [input]}
if isinstance(starts, (list, tuple)): if isinstance(starts, (list, tuple)):
if utils._contain_var(starts): if utils._contain_var(starts):
raise TypeError( raise TypeError(
...@@ -9930,14 +9911,8 @@ def slice(input, axes, starts, ends): ...@@ -9930,14 +9911,8 @@ def slice(input, axes, starts, ends):
"The type of 'ends' in slice must be list[int] or tuple(int) in Dygraph mode, but " "The type of 'ends' in slice must be list[int] or tuple(int) in Dygraph mode, but "
"received %s." % type(shape)) "received %s." % type(shape))
attrs = { return core.ops.slice(input, 'axes', axes, 'starts', starts, 'ends',
'axes': axes, ends, 'infer_flags', infer_flags)
'starts': starts,
'ends': ends,
'infer_flags': infer_flags
}
outs = core.ops.slice(inputs, attrs)
return outs['Out'][0]
if not isinstance(starts, (list, tuple, Variable)): if not isinstance(starts, (list, tuple, Variable)):
raise ValueError( raise ValueError(
...@@ -10392,6 +10367,14 @@ def scale(x, scale=1.0, bias=0.0, bias_after_scale=True, act=None, name=None): ...@@ -10392,6 +10367,14 @@ def scale(x, scale=1.0, bias=0.0, bias_after_scale=True, act=None, name=None):
print(res) # [array([[ 3., 5., 7.], [ 9., 11., 13.]], dtype=float32)] print(res) # [array([[ 3., 5., 7.], [ 9., 11., 13.]], dtype=float32)]
""" """
if in_dygraph_mode():
_scale = scale.numpy().item(0) if isinstance(scale, Variable) else scale
out = core.ops.scale(x, 'scale',
float(_scale), 'bias',
float(bias), 'bias_after_scale', bias_after_scale)
return dygraph_utils._append_activation_in_dygraph(out)
inputs = {'X': [x]} inputs = {'X': [x]}
attrs = { attrs = {
'bias': float(bias), 'bias': float(bias),
...@@ -10401,11 +10384,6 @@ def scale(x, scale=1.0, bias=0.0, bias_after_scale=True, act=None, name=None): ...@@ -10401,11 +10384,6 @@ def scale(x, scale=1.0, bias=0.0, bias_after_scale=True, act=None, name=None):
inputs['ScaleTensor'] = [scale] inputs['ScaleTensor'] = [scale]
else: else:
attrs['scale'] = float(scale) attrs['scale'] = float(scale)
if in_dygraph_mode():
outs = core.ops.scale(inputs, attrs)
return dygraph_utils._append_activation_in_dygraph(outs['Out'][0])
helper = LayerHelper('scale', **locals()) helper = LayerHelper('scale', **locals())
if name is None: if name is None:
out = helper.create_variable_for_type_inference(dtype=x.dtype) out = helper.create_variable_for_type_inference(dtype=x.dtype)
...@@ -11369,9 +11347,7 @@ def mean(x, name=None): ...@@ -11369,9 +11347,7 @@ def mean(x, name=None):
mean = fluid.layers.mean(input) mean = fluid.layers.mean(input)
""" """
if in_dygraph_mode(): if in_dygraph_mode():
inputs = {"X": [x]} return core.ops.mean(x)
outs = core.ops.mean(inputs)
return outs['Out'][0]
helper = LayerHelper("mean", **locals()) helper = LayerHelper("mean", **locals())
check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'], 'mean') check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'], 'mean')
...@@ -11453,12 +11429,12 @@ def mul(x, y, x_num_col_dims=1, y_num_col_dims=1, name=None): ...@@ -11453,12 +11429,12 @@ def mul(x, y, x_num_col_dims=1, y_num_col_dims=1, name=None):
""" """
inputs = {"X": [x], "Y": [y]}
attrs = {"x_num_col_dims": x_num_col_dims, "y_num_col_dims": y_num_col_dims}
if in_dygraph_mode(): if in_dygraph_mode():
outs = core.ops.mul(inputs, attrs) return core.ops.mul(x, y, 'x_num_col_dims', x_num_col_dims,
return outs['Out'][0] 'y_num_col_dims', y_num_col_dims)
inputs = {"X": [x], "Y": [y]}
attrs = {"x_num_col_dims": x_num_col_dims, "y_num_col_dims": y_num_col_dims}
helper = LayerHelper("mul", **locals()) helper = LayerHelper("mul", **locals())
check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'], 'mul') check_variable_and_dtype(x, 'x', ['float16', 'float32', 'float64'], 'mul')
check_variable_and_dtype(y, 'y', ['float16', 'float32', 'float64'], 'mul') check_variable_and_dtype(y, 'y', ['float16', 'float32', 'float64'], 'mul')
......
...@@ -255,15 +255,12 @@ def concat(input, axis=0, name=None): ...@@ -255,15 +255,12 @@ def concat(input, axis=0, name=None):
""" """
if in_dygraph_mode(): if in_dygraph_mode():
inputs = {'X': input}
if isinstance(axis, Variable): if isinstance(axis, Variable):
axis = axis.numpy() axis = axis.numpy()
assert axis.shape == ( assert axis.shape == (
1, ), "axis of type Variable should have shape [1]" 1, ), "axis of type Variable should have shape [1]"
axis = axis[0] axis = axis[0]
attrs = {'axis': axis} return core.ops.concat(input, 'axis', axis)
outs = core.ops.concat(inputs, attrs)
return outs['Out'][0]
if not isinstance(input, list): if not isinstance(input, list):
warnings.warn( warnings.warn(
...@@ -586,12 +583,13 @@ def fill_constant(shape, dtype, value, force_cpu=False, out=None): ...@@ -586,12 +583,13 @@ def fill_constant(shape, dtype, value, force_cpu=False, out=None):
shape)) shape))
else: else:
shape = list(shape.numpy().astype(int)) shape = list(shape.numpy().astype(int))
attrs['shape'] = shape dtype = convert_np_dtype_to_dtype_(dtype)
if out is None: if out is None:
out = _varbase_creator(dtype=dtype) out = _varbase_creator(dtype=dtype)
attrs['dtype'] = out.dtype core.ops.fill_constant(out, 'value',
outputs = {'Out': [out]} float(value), 'force_cpu', force_cpu, 'dtype',
outs = core.ops.fill_constant({}, attrs, outputs) dtype, 'str_value', attrs['str_value'], 'shape',
shape)
out.stop_gradient = True out.stop_gradient = True
return out return out
......
...@@ -889,16 +889,11 @@ class SGDOptimizer(Optimizer): ...@@ -889,16 +889,11 @@ class SGDOptimizer(Optimizer):
@no_grad @no_grad
def _append_optimize_op(self, block, param_and_grad): def _append_optimize_op(self, block, param_and_grad):
lr = self._create_param_lr(param_and_grad)
if framework.in_dygraph_mode(): if framework.in_dygraph_mode():
inputs = { core.ops.sgd(param_and_grad[0], lr, param_and_grad[1],
"Param": [param_and_grad[0]], param_and_grad[0])
"Grad": [param_and_grad[1]], return None
"LearningRate": [self._create_param_lr(param_and_grad)]
}
attrs = {}
outputs = {'ParamOut': [param_and_grad[0]]}
outs = core.ops.sgd(inputs, attrs, outputs)
return outs['ParamOut'][0]
assert isinstance(block, framework.Block) assert isinstance(block, framework.Block)
# create the optimize op # create the optimize op
...@@ -907,7 +902,7 @@ class SGDOptimizer(Optimizer): ...@@ -907,7 +902,7 @@ class SGDOptimizer(Optimizer):
inputs={ inputs={
"Param": param_and_grad[0], "Param": param_and_grad[0],
"Grad": param_and_grad[1], "Grad": param_and_grad[1],
"LearningRate": self._create_param_lr(param_and_grad) "LearningRate": lr
}, },
outputs={"ParamOut": param_and_grad[0]}, outputs={"ParamOut": param_and_grad[0]},
stop_gradient=True) stop_gradient=True)
...@@ -1009,24 +1004,27 @@ class MomentumOptimizer(Optimizer): ...@@ -1009,24 +1004,27 @@ class MomentumOptimizer(Optimizer):
velocity_acc = self._get_accumulator(self._velocity_acc_str, velocity_acc = self._get_accumulator(self._velocity_acc_str,
param_and_grad[0]) param_and_grad[0])
attrs = {"mu": self._momentum, "use_nesterov": self._use_nesterov} lr = self._create_param_lr(param_and_grad)
if framework.in_dygraph_mode():
_, _ = core.ops.momentum(param_and_grad[0], param_and_grad[1],
velocity_acc, lr, param_and_grad[0],
velocity_acc, 'mu', self._momentum,
'use_nesterov', self._use_nesterov)
return None
attrs = {"mu": self._momentum, "use_nesterov": self._use_nesterov}
inputs = { inputs = {
"Param": [param_and_grad[0]], "Param": [param_and_grad[0]],
"Grad": [param_and_grad[1]], "Grad": [param_and_grad[1]],
"Velocity": [velocity_acc], "Velocity": [velocity_acc],
"LearningRate": [self._create_param_lr(param_and_grad)] "LearningRate": [lr]
} }
outputs = { outputs = {
"ParamOut": [param_and_grad[0]], "ParamOut": [param_and_grad[0]],
"VelocityOut": [velocity_acc] "VelocityOut": [velocity_acc]
} }
if framework.in_dygraph_mode():
core.ops.momentum(inputs, attrs, outputs)
return None
# create the momentum optimize op # create the momentum optimize op
momentum_op = block.append_op( momentum_op = block.append_op(
type=self.type, type=self.type,
...@@ -1849,12 +1847,27 @@ class AdamOptimizer(Optimizer): ...@@ -1849,12 +1847,27 @@ class AdamOptimizer(Optimizer):
param_and_grad[0]) param_and_grad[0])
beta2_pow_acc = self._get_accumulator(self._beta2_pow_acc_str, beta2_pow_acc = self._get_accumulator(self._beta2_pow_acc_str,
param_and_grad[0]) param_and_grad[0])
lr = self._create_param_lr(param_and_grad)
# create the adam optimize op # create the adam optimize op
if framework.in_dygraph_mode():
_beta1 = self._beta1 if not isinstance(
self._beta1, Variable) else self._beta1.numpy().item(0)
_beta2 = self._beta2 if not isinstance(
self._beta2, Variable) else self._beta2.numpy().item(0)
_, _, _, _, _ = core.ops.adam(
param_and_grad[0], param_and_grad[1], lr, moment1, moment2,
beta1_pow_acc, beta2_pow_acc, param_and_grad[0], moment1,
moment2, beta1_pow_acc, beta2_pow_acc, 'epsilon', self._epsilon,
'lazy_mode', self._lazy_mode, 'min_row_size_to_use_multithread',
1000, 'beta1', _beta1, 'beta2', _beta2)
return None
inputs = { inputs = {
"Param": [param_and_grad[0]], "Param": [param_and_grad[0]],
"Grad": [param_and_grad[1]], "Grad": [param_and_grad[1]],
"LearningRate": [self._create_param_lr(param_and_grad)], "LearningRate": [lr],
"Moment1": [moment1], "Moment1": [moment1],
"Moment2": [moment2], "Moment2": [moment2],
"Beta1Pow": [beta1_pow_acc], "Beta1Pow": [beta1_pow_acc],
...@@ -1882,10 +1895,6 @@ class AdamOptimizer(Optimizer): ...@@ -1882,10 +1895,6 @@ class AdamOptimizer(Optimizer):
else: else:
attrs['beta2'] = self._beta2 attrs['beta2'] = self._beta2
if framework.in_dygraph_mode():
core.ops.adam(inputs, attrs, outputs)
return None
adam_op = block.append_op( adam_op = block.append_op(
type=self.type, type=self.type,
inputs=inputs, inputs=inputs,
......
...@@ -54,7 +54,7 @@ def _create_regularization_of_grad(param, grad, regularization=None): ...@@ -54,7 +54,7 @@ def _create_regularization_of_grad(param, grad, regularization=None):
inputs = {"X": [grad, regularization_term]} inputs = {"X": [grad, regularization_term]}
outputs = {"Out": [new_grad]} outputs = {"Out": [new_grad]}
if in_dygraph_mode(): if in_dygraph_mode():
core.ops.sum(inputs, {}, outputs) new_grad = core.ops.sum([grad, regularization_term])
else: else:
grad.block.append_op(type='sum', inputs=inputs, outputs=outputs) grad.block.append_op(type='sum', inputs=inputs, outputs=outputs)
...@@ -183,8 +183,7 @@ class L2DecayRegularizer(WeightDecayRegularizer): ...@@ -183,8 +183,7 @@ class L2DecayRegularizer(WeightDecayRegularizer):
attrs = {"scale": self._regularization_coeff} attrs = {"scale": self._regularization_coeff}
if framework.in_dygraph_mode(): if framework.in_dygraph_mode():
outs = core.ops.scale(inputs, attrs) return core.ops.scale(param, "scale", self._regularization_coeff)
return outs['Out'][0]
else: else:
decay = block.create_var( decay = block.create_var(
dtype=param.dtype, shape=param.shape, lod_level=param.lod_level) dtype=param.dtype, shape=param.shape, lod_level=param.lod_level)
......
...@@ -112,9 +112,9 @@ class InstanceNorm(fluid.dygraph.Layer): ...@@ -112,9 +112,9 @@ class InstanceNorm(fluid.dygraph.Layer):
def forward(self, input): def forward(self, input):
if fluid.in_dygraph_mode(): if fluid.in_dygraph_mode():
inputs = {'X': [input], 'Scale': [self.scale], 'Bias': [self.bias]} out, _, _ = fluid.core.ops.instance_norm(
attrs = {'epsilon': self.epsilon} input, self.scale, self.bias, 'epsilon', self.epsilon)
return fluid.core.ops.instance_norm(inputs, attrs)['Y'][0] return out
else: else:
return fluid.layers.instance_norm( return fluid.layers.instance_norm(
input, input,
......
...@@ -28,8 +28,7 @@ class TestTracedLayer(fluid.dygraph.Layer): ...@@ -28,8 +28,7 @@ class TestTracedLayer(fluid.dygraph.Layer):
super(TestTracedLayer, self).__init__(name_scope) super(TestTracedLayer, self).__init__(name_scope)
def forward(self, input): def forward(self, input):
inputs = {'X': [input] if isinstance(input, fluid.Variable) else input} return core.ops.relu(input)
return core.ops.relu(inputs)['Out'][0]
class TestVariable(unittest.TestCase): class TestVariable(unittest.TestCase):
...@@ -47,9 +46,7 @@ class TestVariable(unittest.TestCase): ...@@ -47,9 +46,7 @@ class TestVariable(unittest.TestCase):
x.stop_gradient = False x.stop_gradient = False
res1 = layers.elementwise_add(x, y) res1 = layers.elementwise_add(x, y)
res2 = core.ops.elementwise_add(x, y)
inputs = {'X': [x], 'Y': [y]}
res2 = core.ops.elementwise_add(inputs)['Out'][0]
self.assertTrue(np.array_equal(res1.numpy(), res2.numpy())) self.assertTrue(np.array_equal(res1.numpy(), res2.numpy()))
...@@ -61,9 +58,7 @@ class TestVariable(unittest.TestCase): ...@@ -61,9 +58,7 @@ class TestVariable(unittest.TestCase):
y = fluid.dygraph.to_variable(b) y = fluid.dygraph.to_variable(b)
res1 = layers.elementwise_mul(x, y) res1 = layers.elementwise_mul(x, y)
res2 = core.ops.elementwise_mul(x, y)
inputs = {'X': [x], 'Y': [y]}
res2 = core.ops.elementwise_mul(inputs)['Out'][0]
self.assertTrue(np.array_equal(res1.numpy(), res2.numpy())) self.assertTrue(np.array_equal(res1.numpy(), res2.numpy()))
...@@ -73,9 +68,7 @@ class TestVariable(unittest.TestCase): ...@@ -73,9 +68,7 @@ class TestVariable(unittest.TestCase):
x = fluid.dygraph.to_variable(a) x = fluid.dygraph.to_variable(a)
res1 = layers.relu(x) res1 = layers.relu(x)
res2 = core.ops.relu(x)
inputs = {'X': [x]}
res2 = core.ops.relu(inputs)['Out'][0]
self.assertTrue(np.array_equal(res1.numpy(), res2.numpy())) self.assertTrue(np.array_equal(res1.numpy(), res2.numpy()))
...@@ -88,8 +81,7 @@ class TestVariable(unittest.TestCase): ...@@ -88,8 +81,7 @@ class TestVariable(unittest.TestCase):
x.stop_gradient = False x.stop_gradient = False
y.stop_gradient = False y.stop_gradient = False
inputs = {'X': [x], 'Y': [y]} loss = core.ops.elementwise_mul(x, y)
loss = core.ops.elementwise_mul(inputs)['Out'][0]
loss.backward() loss.backward()
x_grad = x.gradient() x_grad = x.gradient()
...@@ -104,7 +96,7 @@ class TestVariable(unittest.TestCase): ...@@ -104,7 +96,7 @@ class TestVariable(unittest.TestCase):
a = np.random.uniform(-1, 1, self.shape).astype(self.dtype) a = np.random.uniform(-1, 1, self.shape).astype(self.dtype)
x = fluid.dygraph.to_variable(a) x = fluid.dygraph.to_variable(a)
res_dygraph, static_layer = TracedLayer.trace( res_dygraph, static_layer = TracedLayer.trace(
layer, inputs=[x]) # dygraph out layer, inputs=x) # dygraph out
res_static_graph = static_layer([x])[0] res_static_graph = static_layer([x])[0]
self.assertTrue( self.assertTrue(
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册