change net to operator (#2846)
* OperatorBase should not store OpDesc because not All op contains an OpDesc and not all ops create from OpDesc. * Networks do not contain OpDesc and are not created by OpDesc * Do not register Network to OpRegistry. * The network is directly created by the user in Python. Not from registry. * Correctly handle the `inputs` and `outputs` of a Network. * Add CompleteAddOp() methods * Remove `AddOp(OpDesc&)` in net-op. All op are added by OperatorPtr. * Rewrite unit test for truly tested what networks do. * optimise operator_testcblas_new
parent
afa99d9ae6
commit
45ce1649a1
@ -0,0 +1,67 @@
|
|||||||
|
#include <gtest/gtest.h>
|
||||||
|
#include <paddle/framework/net.h>
|
||||||
|
#include <paddle/framework/op_registry.h>
|
||||||
|
#include <paddle/framework/operator.h>
|
||||||
|
|
||||||
|
namespace pd = paddle::framework;
|
||||||
|
|
||||||
|
static int infer_shape_cnt = 0;
|
||||||
|
static int run_cnt = 0;
|
||||||
|
|
||||||
|
class TestOp : public pd::OperatorBase {
|
||||||
|
public:
|
||||||
|
void InferShape(const paddle::framework::ScopePtr& scope) const override {
|
||||||
|
++infer_shape_cnt;
|
||||||
|
}
|
||||||
|
void Run(const paddle::framework::ScopePtr& scope,
|
||||||
|
const paddle::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<paddle::framework::PlainNet>();
|
||||||
|
ASSERT_NE(net, nullptr);
|
||||||
|
|
||||||
|
auto op1 = std::make_shared<TestOp>();
|
||||||
|
op1->inputs_ = {"x", "w1", "b1"};
|
||||||
|
op1->outputs_ = {"y"};
|
||||||
|
net->AddOp(op1);
|
||||||
|
|
||||||
|
auto op2 = std::make_shared<TestOp>();
|
||||||
|
op2->inputs_ = {"y", "w2", "b2"};
|
||||||
|
op2->outputs_ = {"z"};
|
||||||
|
net->AddOp(op2);
|
||||||
|
|
||||||
|
net->CompleteAddOp();
|
||||||
|
AssertSameVectorWithoutOrder({"x", "w1", "b1", "w2", "b2"}, net->inputs_);
|
||||||
|
AssertSameVectorWithoutOrder({"y", "z"}, net->outputs_);
|
||||||
|
auto tmp_idx_iter = net->attrs_.find("temporary_index");
|
||||||
|
ASSERT_NE(net->attrs_.end(), tmp_idx_iter);
|
||||||
|
auto& tmp_idx = boost::get<std::vector<int>>(tmp_idx_iter->second);
|
||||||
|
ASSERT_EQ(1UL, tmp_idx.size());
|
||||||
|
ASSERT_EQ("y", net->outputs_[tmp_idx[0]]);
|
||||||
|
|
||||||
|
auto scope = std::make_shared<pd::Scope>();
|
||||||
|
paddle::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::framework::EnforceNotMet);
|
||||||
|
}
|
Loading…
Reference in new issue