|
|
@ -37,33 +37,154 @@ using vb_vector = std::vector<std::shared_ptr<imperative::VarBase>>;
|
|
|
|
|
|
|
|
|
|
|
|
using var_pair = std::pair<std::string, vb_vector>;
|
|
|
|
using var_pair = std::pair<std::string, vb_vector>;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
template <typename VarType>
|
|
|
|
|
|
|
|
class TestRuntimeInferVarTypeContext
|
|
|
|
|
|
|
|
: public RuntimeInferVarTypeContext<VarType> {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
TestRuntimeInferVarTypeContext(const NameVarMap<VarType>& inputs,
|
|
|
|
|
|
|
|
const NameVarMap<VarType>& outputs,
|
|
|
|
|
|
|
|
const framework::AttributeMap& attrs_map)
|
|
|
|
|
|
|
|
: RuntimeInferVarTypeContext<VarType>(inputs, outputs, attrs_map) {}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool HasVar(const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::HasVar(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const std::vector<std::string>& InputVars(const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::InputVars(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const std::vector<std::string>& OutputVars(const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::OutputVars(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
framework::proto::VarType::Type GetVarType(const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::GetVarType(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SetVarType(const std::string& name,
|
|
|
|
|
|
|
|
framework::proto::VarType::Type type) {
|
|
|
|
|
|
|
|
RuntimeInferVarTypeContext<VarType>::SetVarType(name, type);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
framework::proto::VarType::Type GetVarDataType(
|
|
|
|
|
|
|
|
const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::GetVarDataType(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SetVarDataType(const std::string& name,
|
|
|
|
|
|
|
|
framework::proto::VarType::Type type) {
|
|
|
|
|
|
|
|
RuntimeInferVarTypeContext<VarType>::SetVarDataType(name, type);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<framework::proto::VarType::Type> GetVarDataTypes(
|
|
|
|
|
|
|
|
const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::GetVarDataTypes(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SetVarDataTypes(
|
|
|
|
|
|
|
|
const std::string& name,
|
|
|
|
|
|
|
|
const std::vector<framework::proto::VarType::Type>& multiple_data_type) {
|
|
|
|
|
|
|
|
RuntimeInferVarTypeContext<VarType>::SetVarDataTypes(name,
|
|
|
|
|
|
|
|
multiple_data_type);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<int64_t> GetVarShape(const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::GetVarShape(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SetVarShape(const std::string& name, const std::vector<int64_t>& dims) {
|
|
|
|
|
|
|
|
RuntimeInferVarTypeContext<VarType>::SetVarShape(name, dims);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int32_t GetVarLoDLevel(const std::string& name) const {
|
|
|
|
|
|
|
|
return RuntimeInferVarTypeContext<VarType>::GetVarLoDLevel(name);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void SetVarLoDLevel(const std::string& name, int32_t lod_level) {
|
|
|
|
|
|
|
|
RuntimeInferVarTypeContext<VarType>::SetVarLoDLevel(name, lod_level);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
TEST(test_layer, test_runtime_context) {
|
|
|
|
TEST(test_layer, test_runtime_context) {
|
|
|
|
std::shared_ptr<imperative::VarBase> vin(
|
|
|
|
std::shared_ptr<imperative::VarBase> vin(
|
|
|
|
new imperative::VarBase(false, "vin"));
|
|
|
|
new imperative::VarBase(false, "vin"));
|
|
|
|
|
|
|
|
std::shared_ptr<imperative::VarBase> vin_b(
|
|
|
|
|
|
|
|
new imperative::VarBase(false, "vin_b"));
|
|
|
|
std::shared_ptr<imperative::VarBase> vout(
|
|
|
|
std::shared_ptr<imperative::VarBase> vout(
|
|
|
|
new imperative::VarBase(false, "vout"));
|
|
|
|
new imperative::VarBase(false, "vout"));
|
|
|
|
var_pair in_pair = var_pair("X", vb_vector(1, vin));
|
|
|
|
std::shared_ptr<imperative::VarBase> vout_b(
|
|
|
|
var_pair out_pair = var_pair("Out", vb_vector(1, vout));
|
|
|
|
new imperative::VarBase(false, "vout_b"));
|
|
|
|
|
|
|
|
var_pair in_pair = var_pair("X", {vin, vin_b});
|
|
|
|
|
|
|
|
var_pair out_pair = var_pair("Out", {vout, vout_b});
|
|
|
|
imperative::NameVarBaseMap ins = {in_pair};
|
|
|
|
imperative::NameVarBaseMap ins = {in_pair};
|
|
|
|
imperative::NameVarBaseMap outs = {out_pair};
|
|
|
|
imperative::NameVarBaseMap outs = {out_pair};
|
|
|
|
framework::AttributeMap attrs;
|
|
|
|
framework::AttributeMap attrs;
|
|
|
|
auto *ctx = new imperative::RuntimeInferVarTypeContext<imperative::VarBase>(
|
|
|
|
|
|
|
|
ins, outs, attrs);
|
|
|
|
auto* ctx =
|
|
|
|
ASSERT_TRUE(ctx->HasVar("vin"));
|
|
|
|
new imperative::TestRuntimeInferVarTypeContext<imperative::VarBase>(
|
|
|
|
|
|
|
|
ins, outs, attrs);
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_TRUE(ctx->HasInput("X"));
|
|
|
|
ASSERT_TRUE(ctx->HasInput("X"));
|
|
|
|
ASSERT_TRUE(ctx->HasOutput("Out"));
|
|
|
|
ASSERT_TRUE(ctx->HasOutput("Out"));
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->GetDataTypes("vin"));
|
|
|
|
ASSERT_EQ(2u, ctx->InputSize("X"));
|
|
|
|
|
|
|
|
ASSERT_EQ("vin", ctx->InputVarName("X", 0));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_TRUE(ctx->InputTypeAnyOf("X", framework::proto::VarType::LOD_TENSOR));
|
|
|
|
|
|
|
|
ASSERT_TRUE(ctx->InputTypeAllOf("X", framework::proto::VarType::LOD_TENSOR));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::LOD_TENSOR, ctx->GetInputType("X"));
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::FP32, ctx->GetInputDataType("X"));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ctx->SyncTypeAndDataType("X", "Out");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::FP32, vout->DataType());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::LOD_TENSOR, ctx->GetOutputType("Out"));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ctx->SetOutputType("Out", framework::proto::VarType::SELECTED_ROWS,
|
|
|
|
|
|
|
|
framework::ALL_ELEMENTS);
|
|
|
|
|
|
|
|
ctx->SetOutputType("Out", framework::proto::VarType::LOD_TENSOR_ARRAY);
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::LOD_TENSOR_ARRAY, vout->Type());
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::SELECTED_ROWS, vout_b->Type());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ctx->SetOutputDataType("Out", framework::proto::VarType::FP64,
|
|
|
|
|
|
|
|
framework::ALL_ELEMENTS);
|
|
|
|
|
|
|
|
ctx->SetOutputDataType("Out", framework::proto::VarType::INT8);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::INT8, vout->DataType());
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::FP64, vout_b->DataType());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// no throw, but do nothing
|
|
|
|
|
|
|
|
ASSERT_NO_THROW(
|
|
|
|
|
|
|
|
ctx->InsertVar("vout", framework::proto::VarType::LOD_TENSOR));
|
|
|
|
|
|
|
|
ASSERT_EQ(framework::proto::VarType::LOD_TENSOR_ARRAY, vout->Type());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->HasVar("vin"));
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->InputVars("X"));
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->OutputVars("Out"));
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->GetVarType("vin"));
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(
|
|
|
|
|
|
|
|
ctx->SetVarType("vin", framework::proto::VarType::LOD_TENSOR));
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->GetVarDataType("vin"));
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(
|
|
|
|
|
|
|
|
ctx->SetVarDataType("vout", framework::proto::VarType::FP32));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->GetVarDataTypes("vin"));
|
|
|
|
std::vector<framework::proto::VarType::Type> NullType;
|
|
|
|
std::vector<framework::proto::VarType::Type> NullType;
|
|
|
|
ASSERT_ANY_THROW(ctx->SetDataTypes("vin", NullType));
|
|
|
|
ASSERT_ANY_THROW(ctx->SetVarDataTypes("vin", NullType));
|
|
|
|
ASSERT_ANY_THROW(ctx->GetShape("vin"));
|
|
|
|
ASSERT_ANY_THROW(ctx->GetVarShape("vin"));
|
|
|
|
ASSERT_ANY_THROW(ctx->GetLoDLevel("vin"));
|
|
|
|
ASSERT_ANY_THROW(ctx->SetVarShape("vin", {}));
|
|
|
|
ASSERT_ANY_THROW(ctx->SetLoDLevel("vin", 2));
|
|
|
|
ASSERT_ANY_THROW(ctx->GetVarLoDLevel("vin"));
|
|
|
|
|
|
|
|
ASSERT_ANY_THROW(ctx->SetVarLoDLevel("vin", 2));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_TRUE(ctx->IsDygraph());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string LayerDebugString(const std::string &op_type,
|
|
|
|
std::string LayerDebugString(const std::string& op_type,
|
|
|
|
const NameVarBaseMap &ins,
|
|
|
|
const NameVarBaseMap& ins,
|
|
|
|
const NameVarBaseMap &outs);
|
|
|
|
const NameVarBaseMap& outs);
|
|
|
|
|
|
|
|
|
|
|
|
TEST(test_layer, test_debug_string) {
|
|
|
|
TEST(test_layer, test_debug_string) {
|
|
|
|
platform::CPUPlace place;
|
|
|
|
platform::CPUPlace place;
|
|
|
@ -71,7 +192,7 @@ TEST(test_layer, test_debug_string) {
|
|
|
|
new imperative::VarBase(false, "vin"));
|
|
|
|
new imperative::VarBase(false, "vin"));
|
|
|
|
var_pair in_pair = var_pair("X", vb_vector(1, vin));
|
|
|
|
var_pair in_pair = var_pair("X", vb_vector(1, vin));
|
|
|
|
|
|
|
|
|
|
|
|
auto test_func = [&](std::shared_ptr<imperative::VarBase> &vout) {
|
|
|
|
auto test_func = [&](std::shared_ptr<imperative::VarBase>& vout) {
|
|
|
|
var_pair out_pair = var_pair("Out", vb_vector(1, vout));
|
|
|
|
var_pair out_pair = var_pair("Out", vb_vector(1, vout));
|
|
|
|
imperative::NameVarBaseMap ins = {in_pair};
|
|
|
|
imperative::NameVarBaseMap ins = {in_pair};
|
|
|
|
imperative::NameVarBaseMap outs = {out_pair};
|
|
|
|
imperative::NameVarBaseMap outs = {out_pair};
|
|
|
@ -124,26 +245,26 @@ TEST(test_layer, test_debug_string) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static std::shared_ptr<imperative::GradOpNode> CreateGradNode(
|
|
|
|
static std::shared_ptr<imperative::GradOpNode> CreateGradNode(
|
|
|
|
size_t id, const std::string &type, const imperative::NameVarBaseMap &ins,
|
|
|
|
size_t id, const std::string& type, const imperative::NameVarBaseMap& ins,
|
|
|
|
const imperative::NameVarBaseMap &outs,
|
|
|
|
const imperative::NameVarBaseMap& outs,
|
|
|
|
const framework::AttributeMap &attrs, const platform::Place &place) {
|
|
|
|
const framework::AttributeMap& attrs, const platform::Place& place) {
|
|
|
|
auto node = std::make_shared<imperative::GradOpNode>();
|
|
|
|
auto node = std::make_shared<imperative::GradOpNode>();
|
|
|
|
auto *op = &(node->emplace_back());
|
|
|
|
auto* op = &(node->emplace_back());
|
|
|
|
op->SetId(id);
|
|
|
|
op->SetId(id);
|
|
|
|
op->SetPlace(place);
|
|
|
|
op->SetPlace(place);
|
|
|
|
op->SetType(type);
|
|
|
|
op->SetType(type);
|
|
|
|
op->SetAttrMap(attrs);
|
|
|
|
op->SetAttrMap(attrs);
|
|
|
|
for (auto &pair : ins) {
|
|
|
|
for (auto& pair : ins) {
|
|
|
|
std::vector<std::shared_ptr<VariableWrapper>> vars;
|
|
|
|
std::vector<std::shared_ptr<VariableWrapper>> vars;
|
|
|
|
for (auto &var : pair.second) {
|
|
|
|
for (auto& var : pair.second) {
|
|
|
|
vars.emplace_back(var->SharedVar());
|
|
|
|
vars.emplace_back(var->SharedVar());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
op->SetInput(pair.first, vars, false);
|
|
|
|
op->SetInput(pair.first, vars, false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (auto &pair : outs) {
|
|
|
|
for (auto& pair : outs) {
|
|
|
|
std::vector<std::shared_ptr<VariableWrapper>> vars;
|
|
|
|
std::vector<std::shared_ptr<VariableWrapper>> vars;
|
|
|
|
for (auto &var : pair.second) {
|
|
|
|
for (auto& var : pair.second) {
|
|
|
|
vars.emplace_back(var->SharedVar());
|
|
|
|
vars.emplace_back(var->SharedVar());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
op->SetOutput(pair.first, vars, false);
|
|
|
|
op->SetOutput(pair.first, vars, false);
|
|
|
@ -173,7 +294,7 @@ TEST(test_layer, test_clear_backward_info) {
|
|
|
|
node->InsertGradPendingNode(pending_node);
|
|
|
|
node->InsertGradPendingNode(pending_node);
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_EQ(node->size(), 1UL);
|
|
|
|
ASSERT_EQ(node->size(), 1UL);
|
|
|
|
auto *op = &(node->back());
|
|
|
|
auto* op = &(node->back());
|
|
|
|
|
|
|
|
|
|
|
|
ASSERT_GT(op->GetInsMap().size(), 0UL);
|
|
|
|
ASSERT_GT(op->GetInsMap().size(), 0UL);
|
|
|
|
ASSERT_GT(op->GetOutsMap().size(), 0UL);
|
|
|
|
ASSERT_GT(op->GetOutsMap().size(), 0UL);
|
|
|
@ -196,10 +317,10 @@ TEST(test_layer, test_varbase_basic) {
|
|
|
|
std::shared_ptr<imperative::VarBase> vin_with_grad(
|
|
|
|
std::shared_ptr<imperative::VarBase> vin_with_grad(
|
|
|
|
new imperative::VarBase(true, "vin"));
|
|
|
|
new imperative::VarBase(true, "vin"));
|
|
|
|
ASSERT_ANY_THROW(vin->MutableGradVar());
|
|
|
|
ASSERT_ANY_THROW(vin->MutableGradVar());
|
|
|
|
ASSERT_NO_THROW(ASSERT_TRUE(dynamic_cast<framework::Variable *>(
|
|
|
|
ASSERT_NO_THROW(ASSERT_TRUE(dynamic_cast<framework::Variable*>(
|
|
|
|
vin_with_grad->MutableGradVar()) != 0));
|
|
|
|
vin_with_grad->MutableGradVar()) != 0));
|
|
|
|
ASSERT_TRUE(dynamic_cast<framework::Variable *>(
|
|
|
|
ASSERT_TRUE(
|
|
|
|
vin_with_grad->MutableGradVar()) != 0);
|
|
|
|
dynamic_cast<framework::Variable*>(vin_with_grad->MutableGradVar()) != 0);
|
|
|
|
vin_with_grad->SetOverridedStopGradient(false);
|
|
|
|
vin_with_grad->SetOverridedStopGradient(false);
|
|
|
|
ASSERT_FALSE(vin_with_grad->OverridedStopGradient());
|
|
|
|
ASSERT_FALSE(vin_with_grad->OverridedStopGradient());
|
|
|
|
ASSERT_NO_FATAL_FAILURE(vin_with_grad->SetPersistable(true));
|
|
|
|
ASSERT_NO_FATAL_FAILURE(vin_with_grad->SetPersistable(true));
|
|
|
@ -228,9 +349,9 @@ TEST(test_layer, test_dygraph_execution_context) {
|
|
|
|
auto op = framework::OpRegistry::CreateOp("mul", {}, {}, {}, false);
|
|
|
|
auto op = framework::OpRegistry::CreateOp("mul", {}, {}, {}, false);
|
|
|
|
paddle::platform::CPUPlace cpu_place;
|
|
|
|
paddle::platform::CPUPlace cpu_place;
|
|
|
|
|
|
|
|
|
|
|
|
paddle::platform::DeviceContextPool &pool =
|
|
|
|
paddle::platform::DeviceContextPool& pool =
|
|
|
|
paddle::platform::DeviceContextPool::Instance();
|
|
|
|
paddle::platform::DeviceContextPool::Instance();
|
|
|
|
auto *dev_ctx = pool.Get(cpu_place);
|
|
|
|
auto* dev_ctx = pool.Get(cpu_place);
|
|
|
|
paddle::framework::RuntimeContext ctx({}, {});
|
|
|
|
paddle::framework::RuntimeContext ctx({}, {});
|
|
|
|
framework::Scope scope;
|
|
|
|
framework::Scope scope;
|
|
|
|
|
|
|
|
|
|
|
|