Browse Source

DROPOUTDOMASK

tags/v1.3.0
lianghao24@hisilicon.com lianghao 3 years ago
parent
commit
c07ec5a2fc
5 changed files with 117 additions and 1 deletions
  1. +2
    -0
      ge/common/types.cc
  2. +1
    -1
      ge/graph/passes/link_gen_mask_nodes_pass.cc
  3. +2
    -0
      inc/framework/common/types.h
  4. +1
    -0
      tests/ut/ge/CMakeLists.txt
  5. +111
    -0
      tests/ut/ge/graph/passes/link_gen_mask_nodes_pass_unittest.cc

+ 2
- 0
ge/common/types.cc View File

@@ -90,6 +90,8 @@ REGISTER_OPTYPE_DEFINE(DEPCONVOLUTION, "ConvolutionDepthwise");
REGISTER_OPTYPE_DEFINE(DROPOUT, "Dropout"); REGISTER_OPTYPE_DEFINE(DROPOUT, "Dropout");
REGISTER_OPTYPE_DEFINE(DROPOUTGENMASK, "DropOutGenMask"); REGISTER_OPTYPE_DEFINE(DROPOUTGENMASK, "DropOutGenMask");
REGISTER_OPTYPE_DEFINE(DROPOUTDOMASK, "DropOutDoMask"); REGISTER_OPTYPE_DEFINE(DROPOUTDOMASK, "DropOutDoMask");
REGISTER_OPTYPE_DEFINE(DROPOUTDOMASKV3, "DropOutDoMaskV3");
REGISTER_OPTYPE_DEFINE(DROPOUTDOMASKV3D, "DropOutDoMaskV3D");
REGISTER_OPTYPE_DEFINE(CONCAT, "Concat"); REGISTER_OPTYPE_DEFINE(CONCAT, "Concat");
REGISTER_OPTYPE_DEFINE(ROIPOOLING, "ROIPooling"); REGISTER_OPTYPE_DEFINE(ROIPOOLING, "ROIPooling");
REGISTER_OPTYPE_DEFINE(PROPOSAL, "Proposal"); REGISTER_OPTYPE_DEFINE(PROPOSAL, "Proposal");


+ 1
- 1
ge/graph/passes/link_gen_mask_nodes_pass.cc View File

@@ -93,7 +93,7 @@ bool LinkGenMaskNodesPass::AreAllInputsConst(const NodePtr &node) const {
void LinkGenMaskNodesPass::GetAllGenMaskNodes(ComputeGraphPtr graph, vector<NodePtr> &gen_mask_nodes) const { void LinkGenMaskNodesPass::GetAllGenMaskNodes(ComputeGraphPtr graph, vector<NodePtr> &gen_mask_nodes) const {
set<NodePtr> nodes_set; set<NodePtr> nodes_set;
for (const NodePtr &node : graph->GetDirectNode()) { for (const NodePtr &node : graph->GetDirectNode()) {
if (node->GetType() != DROPOUTDOMASK) {
if (node->GetType() != DROPOUTDOMASK && node->GetType() != DROPOUTDOMASKV3 && node->GetType() != DROPOUTDOMASKV3D) {
continue; continue;
} }




+ 2
- 0
inc/framework/common/types.h View File

@@ -130,6 +130,8 @@ REGISTER_OPTYPE_DECLARE(REFORMAT, "ReFormat");
REGISTER_OPTYPE_DECLARE(DEPCONVOLUTION, "ConvolutionDepthwise"); REGISTER_OPTYPE_DECLARE(DEPCONVOLUTION, "ConvolutionDepthwise");
REGISTER_OPTYPE_DECLARE(DROPOUT, "Dropout"); REGISTER_OPTYPE_DECLARE(DROPOUT, "Dropout");
REGISTER_OPTYPE_DECLARE(DROPOUTDOMASK, "DropOutDoMask"); REGISTER_OPTYPE_DECLARE(DROPOUTDOMASK, "DropOutDoMask");
REGISTER_OPTYPE_DECLARE(DROPOUTDOMASKV3, "DropOutDoMaskV3");
REGISTER_OPTYPE_DECLARE(DROPOUTDOMASKV3D, "DropOutDoMaskV3D");
REGISTER_OPTYPE_DECLARE(DROPOUTGENMASK, "DropOutGenMask"); REGISTER_OPTYPE_DECLARE(DROPOUTGENMASK, "DropOutGenMask");
REGISTER_OPTYPE_DECLARE(CONCAT, "Concat"); REGISTER_OPTYPE_DECLARE(CONCAT, "Concat");
REGISTER_OPTYPE_DECLARE(ROIPOOLING, "ROIPooling"); REGISTER_OPTYPE_DECLARE(ROIPOOLING, "ROIPooling");


+ 1
- 0
tests/ut/ge/CMakeLists.txt View File

@@ -694,6 +694,7 @@ set(PASS_TEST_FILES
"graph/passes/infershape_pass_unittest.cc" "graph/passes/infershape_pass_unittest.cc"
"graph/passes/multi_batch_clone_pass_unittest.cc" "graph/passes/multi_batch_clone_pass_unittest.cc"
"graph/passes/replace_with_empty_const_pass_unittest.cc" "graph/passes/replace_with_empty_const_pass_unittest.cc"
"graph/passes/link_gen_mask_nodes_pass_unittest.cc"
"graph/passes/transpose_transdata_pass_unittest.cc" "graph/passes/transpose_transdata_pass_unittest.cc"
) )




+ 111
- 0
tests/ut/ge/graph/passes/link_gen_mask_nodes_pass_unittest.cc View File

@@ -0,0 +1,111 @@
/**
* Copyright 2019-2020 Huawei Technologies Co., Ltd
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

#include "graph/passes/link_gen_mask_nodes_pass.h"


#include <gtest/gtest.h>
#include <set>
#include <string>

#include "graph_builder_utils.h"

namespace ge {
class UtestLinkGenMaskNodesPass : public testing::Test {
protected:
void SetUp() {}
void TearDown() {}
};

namespace {
/*
* do_mask1 do_mask2 do_mask3 do_mask4 do_mask5 do_mask6
* \| \ / |/ |/ \ / |/ \| \ / |/
* \ \ / | | \ / | | \ / |
* \ genmask1 | | genmask2 | | genmask3 |
* \ | | | | | | | | | | /
* ----------------------const1 and const2--------------------------
*/
ut::GraphBuilder Graph1Builder() {
ut::GraphBuilder builder = ut::GraphBuilder("g1");
auto const1 = builder.AddNode("const1", "Const", 0, 1);
auto const2 = builder.AddNode("const2", "Const", 0, 1);
auto gen_mask1 = builder.AddNode("gen_mask1", "DropOutGenMask", 2, 1);
auto gen_mask2 = builder.AddNode("gen_mask2", "DropOutGenMaskV3", 2, 1);
auto gen_mask3 = builder.AddNode("gen_mask3", "DropOutGenMaskV3D", 2, 1);
auto do_mask1 = builder.AddNode("do_mask1", "DropOutDoMask", 3, 1);
auto do_mask2 = builder.AddNode("do_mask2", "DropOutDoMask", 3, 1);
auto do_mask3 = builder.AddNode("do_mask3", "DropOutDoMask", 3, 1);
auto do_mask4 = builder.AddNode("do_mask4", "DropOutDoMask", 3, 1);
auto do_mask5 = builder.AddNode("do_mask5", "DropOutDoMask", 3, 1);
auto do_mask6 = builder.AddNode("do_mask6", "DropOutDoMask", 3, 1);
gen_mask1->GetOpDesc()->SetOpEngineName("DNN_HCCL");
gen_mask2->GetOpDesc()->SetOpEngineName("DNN_HCCL");
gen_mask3->GetOpDesc()->SetOpEngineName("DNN_HCCL");

builder.AddDataEdge(const1, 0, gen_mask1, 0);
builder.AddDataEdge(const1, 0, gen_mask2, 0);
builder.AddDataEdge(const1, 0, gen_mask3, 0);
builder.AddDataEdge(const1, 0, do_mask1, 0);
builder.AddDataEdge(const1, 0, do_mask2, 0);
builder.AddDataEdge(const1, 0, do_mask3, 0);
builder.AddDataEdge(const1, 0, do_mask4, 0);
builder.AddDataEdge(const1, 0, do_mask5, 0);
builder.AddDataEdge(const1, 0, do_mask6, 0);
builder.AddDataEdge(gen_mask1, 0, do_mask1, 1);
builder.AddDataEdge(gen_mask1, 0, do_mask2, 1);
builder.AddDataEdge(gen_mask2, 0, do_mask3, 1);
builder.AddDataEdge(gen_mask2, 0, do_mask4, 1);
builder.AddDataEdge(gen_mask3, 0, do_mask5, 1);
builder.AddDataEdge(gen_mask3, 0, do_mask6, 1);
builder.AddDataEdge(const2, 0, gen_mask1, 1);
builder.AddDataEdge(const2, 0, gen_mask2, 1);
builder.AddDataEdge(const2, 0, gen_mask3, 1);
builder.AddDataEdge(const2, 0, do_mask1, 2);
builder.AddDataEdge(const2, 0, do_mask2, 2);
builder.AddDataEdge(const2, 0, do_mask3, 2);
builder.AddDataEdge(const2, 0, do_mask4, 2);
builder.AddDataEdge(const2, 0, do_mask5, 2);
builder.AddDataEdge(const2, 0, do_mask6, 2);
return builder;
}
} // namespace


TEST_F(UtestLinkGenMaskNodesPass, link_gen_mask_nodes_pass_success) {
auto builder = Graph1Builder();
auto graph = builder.GetGraph();
std::map<std::string, int> stream_max_parallel_num;
stream_max_parallel_num["DNN_HCCL"] = 1;
LinkGenMaskNodesPass link_pass(stream_max_parallel_num);
Status ret = link_pass.Run(graph);
EXPECT_EQ(ret, SUCCESS);

auto gen_mask2 = graph->FindNode("gen_mask2");
EXPECT_NE(gen_mask2, nullptr);

auto in_ctrl_nodes = gen_mask2->GetInControlNodes();
EXPECT_EQ(in_ctrl_nodes.size(), 1);
auto in_ctrl_node = in_ctrl_nodes.at(0);
EXPECT_EQ(in_ctrl_node->GetName(), "gen_mask3");

auto out_ctrl_nodes = gen_mask2->GetOutControlNodes();
EXPECT_EQ(out_ctrl_nodes.size(), 1);
auto out_ctrl_node = out_ctrl_nodes.at(0);
EXPECT_EQ(out_ctrl_node->GetName(), "gen_mask1");
}
} // namespace ge

Loading…
Cancel
Save