#include "paddle/operators/net_op.h" #include #include "paddle/framework/op_registry.h" #include "paddle/framework/operator.h" namespace paddle { namespace operators { static int infer_shape_cnt = 0; static int run_cnt = 0; class TestOp : public OperatorBase { public: void InferShape(const framework::Scope& scope) const override { ++infer_shape_cnt; } void Run(const framework::Scope& scope, const paddle::platform::DeviceContext& dev_ctx) const override { ++run_cnt; } }; class EmptyOp : public OperatorBase { public: void InferShape(const Scope& scope) const override {} void Run(const Scope& scope, const platform::DeviceContext& dev_ctx) const override {} }; template void AssertSameVectorWithoutOrder(const std::vector& expected, const std::vector& actual) { ASSERT_EQ(expected.size(), actual.size()); std::unordered_set expected_set; for (auto& tmp : expected) { expected_set.insert(tmp); } for (auto& act : actual) { ASSERT_NE(expected_set.end(), expected_set.find(act)); } } TEST(OpKernel, all) { auto net = std::make_shared(); ASSERT_NE(net, nullptr); auto op1 = std::make_shared(); op1->inputs_ = {{"X", {"x"}}, {"W", {"w1"}}, {"b", {"b1"}}}; op1->outputs_ = {{"Out", {"y"}}}; net->AddOp(op1); auto op2 = std::make_shared(); op2->inputs_ = {{"X", {"y"}}, {"W", {"w2"}}, {"b", {"b2"}}}; op2->outputs_ = {{"Out", {"z"}}}; net->AddOp(op2); net->CompleteAddOp(); AssertSameVectorWithoutOrder({"x", "w1", "b1", "w2", "b2"}, net->inputs_.at("__all__")); AssertSameVectorWithoutOrder({"y", "z"}, net->outputs_.at("__all__")); auto tmp_idx_iter = net->attrs_.find("temporary_index"); ASSERT_NE(net->attrs_.end(), tmp_idx_iter); auto& tmp_idx = boost::get>(tmp_idx_iter->second); ASSERT_EQ(1UL, tmp_idx.size()); ASSERT_EQ("y", net->outputs_.at("__all__")[tmp_idx[0]]); Scope scope; platform::CPUDeviceContext dev_ctx; net->InferShape(scope); net->Run(scope, dev_ctx); ASSERT_EQ(2, infer_shape_cnt); ASSERT_EQ(2, run_cnt); ASSERT_THROW(net->AddOp(op2), paddle::platform::EnforceNotMet); } TEST(NetOp, insert_op) { NetOp net; auto op1 = std::make_shared(); op1->inputs_ = {{"X", {"x"}}, {"W", {"w1"}}, {"b", {"b1"}}}; op1->outputs_ = {{"Out", {"y"}}}; net.AddOp(op1); net.InsertOp(0, op1); ASSERT_EQ(2UL, net.ops_.size()); net.InsertOp(2, op1); ASSERT_EQ(3UL, net.ops_.size()); } } // namespace operators } // namespace paddle