parent
6d51265781
commit
c07ec5a2fc
@ -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…
Reference in new issue