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.
graphengine/ge/graph/optimize/summary_optimize.cc

113 lines
3.9 KiB

/**
* Copyright 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 <string>
#include <utility>
#include <vector>
#include "graph/optimize/graph_optimize.h"
#include "graph/utils/graph_utils.h"
#include "graph/utils/tensor_utils.h"
#include "omg/omg_inner_types.h"
namespace {
const char *const kSummary = "Summary";
const int kMaxMapSize = 10000;
} // namespace
namespace ge {
Status GraphOptimize::HandleSummaryOp(ComputeGraphPtr &compute_graph) {
GELOGI("[HandleSummaryOp] HandleSummaryOp start!");
if (summary_output_indexes_.size() >= kMaxMapSize) {
GELOGE(FAILED, "Map size out of range.");
return FAILED;
}
if (summary_output_indexes_.find(compute_graph->GetGraphID()) != summary_output_indexes_.end()) {
return SUCCESS;
}
if (compute_graph == nullptr) {
GELOGE(GE_GRAPH_PARAM_NULLPTR, "compute_graph is nullptr.");
return GE_GRAPH_PARAM_NULLPTR;
}
vector<NodePtr> del_nodes;
vector<NodePtr> front_nodes;
vector<uint8_t> out_index;
std::map<string, size_t> summary_output_indexes = {};
size_t output_index = compute_graph->GetGraphOutNodesInfo().size();
for (auto &node_ptr : compute_graph->GetAllNodes()) {
GE_CHECK_NOTNULL(node_ptr);
OpDescPtr op = node_ptr->GetOpDesc();
GE_IF_BOOL_EXEC(op == nullptr, GELOGW("op is nullptr!"); continue);
if (op->GetType() == kSummary) {
compute_graph->SetSummaryFlag(true);
auto in = node_ptr->GetInDataAnchor(0);
if (in == nullptr) {
GELOGE(GE_GRAPH_PARAM_NULLPTR, "in is nullptr.");
return GE_GRAPH_PARAM_NULLPTR;
}
auto peerin = in->GetPeerOutAnchor();
GE_IF_BOOL_EXEC(peerin == nullptr, GELOGE(GE_GRAPH_PARAM_NULLPTR, "peerin is nullptr.");
return GE_GRAPH_PARAM_NULLPTR);
auto ret = GraphUtils::RemoveEdge(peerin, in);
if (ret != SUCCESS) {
return ret;
}
auto front_node = peerin->GetOwnerNode();
front_nodes.emplace_back(front_node);
auto idx = peerin->GetIdx();
out_index.emplace_back(idx);
GELOGI("[GraphOptimize] Summary name: %s, output index: %zu", op->GetName().c_str(), output_index);
summary_output_indexes.emplace(op->GetName(), output_index);
output_index += 1;
del_nodes.emplace_back(node_ptr);
}
}
GE_IF_BOOL_EXEC(!summary_output_indexes.empty(), summary_output_indexes_.insert({compute_graph->GetGraphID(),
summary_output_indexes}));
// add output nodes for summary
std::vector<std::pair<NodePtr, int32_t>> out_nodes_info;
for (size_t i = 0; i < front_nodes.size(); i++) {
out_nodes_info.emplace_back(pair<NodePtr, int32_t>(front_nodes[i], out_index[i]));
}
compute_graph->AppendGraphOutNodesInfo(out_nodes_info);
// delete summary node
for (auto &node_ptr : del_nodes) {
auto ret = GraphUtils::RemoveNodeWithoutRelink(compute_graph, node_ptr);
if (ret != SUCCESS) {
GELOGE(ret, "GraphUtils::RemoveNodeWithoutRelink failed.");
return ret;
}
// update Target list
vector<NodePtr> graph_target = compute_graph->GetGraphTargetNodesInfo();
auto iter = find(graph_target.begin(), graph_target.end(), node_ptr);
if (iter != graph_target.end()) {
GELOGI("Current node %s is as Target, remove it from target vector.", node_ptr->GetName().c_str());
(void)graph_target.erase(iter);
compute_graph->SetGraphTargetNodesInfo(graph_target);
}
}
return SUCCESS;
}
} // namespace ge