You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
89 lines
2.6 KiB
89 lines
2.6 KiB
#include "paddle/operators/net_op.h"
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
namespace paddle {
|
|
namespace operators {
|
|
using Scope = framework::Scope;
|
|
using DeviceContext = platform::DeviceContext;
|
|
|
|
static int infer_shape_cnt = 0;
|
|
static int run_cnt = 0;
|
|
|
|
class TestOp : public framework::OperatorBase {
|
|
public:
|
|
using framework::OperatorBase::OperatorBase;
|
|
DEFINE_OP_CLONE_METHOD(TestOp);
|
|
void InferShape(const Scope& scope) const override { ++infer_shape_cnt; }
|
|
void Run(const Scope& scope,
|
|
const platform::DeviceContext& dev_ctx) const override {
|
|
++run_cnt;
|
|
}
|
|
};
|
|
|
|
template <typename T>
|
|
void AssertSameVectorWithoutOrder(const std::vector<T>& expected,
|
|
const std::vector<T>& actual) {
|
|
ASSERT_EQ(expected.size(), actual.size());
|
|
std::unordered_set<T> 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<NetOp>();
|
|
ASSERT_NE(net, nullptr);
|
|
|
|
net->AppendOp(std::unique_ptr<TestOp>(
|
|
new TestOp("test", {{"X", {"x"}}, {"W", {"w1"}}, {"b", {"b1"}}},
|
|
{{"Out", {"y"}}}, {})));
|
|
net->AppendOp(std::unique_ptr<TestOp>(
|
|
new TestOp("test", {{"X", {"y"}}, {"W", {"w2"}}, {"b", {"b2"}}},
|
|
{{"Out", {"z"}}}, {})));
|
|
|
|
net->CompleteAddOp();
|
|
AssertSameVectorWithoutOrder({"x", "w1", "b1", "w2", "b2"},
|
|
net->Inputs(NetOp::kAll));
|
|
AssertSameVectorWithoutOrder({"y", "z"}, net->Outputs(NetOp::kAll));
|
|
|
|
auto final_outs = net->OutputVars(false);
|
|
|
|
ASSERT_EQ(final_outs.size(), 1UL);
|
|
ASSERT_EQ(final_outs[0], "z");
|
|
}
|
|
|
|
TEST(NetOp, insert_op) {
|
|
NetOp net;
|
|
auto op1 = std::unique_ptr<framework::NOP>(
|
|
new framework::NOP("empty", {{"X", {"x"}}, {"W", {"w1"}}, {"b", {"b1"}}},
|
|
{{"Out", {"y"}}}, {}));
|
|
net.AppendOp(*op1);
|
|
net.InsertOp(0, *op1);
|
|
ASSERT_EQ(2UL, net.ops_.size());
|
|
net.InsertOp(2, std::move(op1));
|
|
ASSERT_EQ(3UL, net.ops_.size());
|
|
}
|
|
|
|
TEST(NetOp, Clone) {
|
|
NetOp net;
|
|
net.AppendOp(
|
|
std::unique_ptr<framework::NOP>(new framework::NOP{"empty", {}, {}, {}}));
|
|
net.AppendOp(std::unique_ptr<framework::NOP>(
|
|
new framework::NOP{"empty2", {}, {}, {}}));
|
|
net.CompleteAddOp(true);
|
|
auto new_net_op = net.Clone();
|
|
ASSERT_NE(new_net_op, nullptr);
|
|
ASSERT_TRUE(new_net_op->IsNetOp());
|
|
auto* new_net = static_cast<NetOp*>(new_net_op.get());
|
|
ASSERT_EQ(2UL, new_net->ops_.size());
|
|
ASSERT_EQ(new_net->ops_[0]->Type(), "empty");
|
|
ASSERT_EQ(new_net->ops_[1]->Type(), "empty2");
|
|
}
|
|
|
|
} // namespace operators
|
|
} // namespace paddle
|