提交 abaad5f4 编写于 作者: M mindspore-ci-bot 提交者: Gitee

!1230 handle the case which the input of summary is depend type

Merge pull request !1230 from Margaret_wangrui/handle-the-case-which-the-input-of-summary-is-depend-type
...@@ -466,7 +466,7 @@ bool KernelGraph::HandleControlDependNode(const AnfNodePtr &node, std::queue<Anf ...@@ -466,7 +466,7 @@ bool KernelGraph::HandleControlDependNode(const AnfNodePtr &node, std::queue<Anf
} }
// set the control depend visited but don't push it into the que // set the control depend visited but don't push it into the que
if (visited_nodes->find(node) != visited_nodes->end()) { if (visited_nodes->find(node) != visited_nodes->end()) {
MS_LOG(EXCEPTION) << "control depend[" << node->DebugString() << "] has been handled before"; return true;
} }
(void)visited_nodes->insert(cnode); (void)visited_nodes->insert(cnode);
// add a 0 depend num to keep the link relations to prepare for finding zero output nodes // add a 0 depend num to keep the link relations to prepare for finding zero output nodes
......
...@@ -68,7 +68,6 @@ void GetSummaryNodes(const KernelGraph *graph, std::unordered_map<std::string, s ...@@ -68,7 +68,6 @@ void GetSummaryNodes(const KernelGraph *graph, std::unordered_map<std::string, s
MS_EXCEPTION_IF_NULL(n); MS_EXCEPTION_IF_NULL(n);
if (IsPrimitiveCNode(n, prim::kPrimScalarSummary) || IsPrimitiveCNode(n, prim::kPrimTensorSummary) || if (IsPrimitiveCNode(n, prim::kPrimScalarSummary) || IsPrimitiveCNode(n, prim::kPrimTensorSummary) ||
IsPrimitiveCNode(n, prim::kPrimImageSummary) || IsPrimitiveCNode(n, prim::kPrimHistogramSummary)) { IsPrimitiveCNode(n, prim::kPrimImageSummary) || IsPrimitiveCNode(n, prim::kPrimHistogramSummary)) {
int index = 0;
auto cnode = n->cast<CNodePtr>(); auto cnode = n->cast<CNodePtr>();
MS_EXCEPTION_IF_NULL(cnode); MS_EXCEPTION_IF_NULL(cnode);
if (cnode->inputs().size() <= kSummaryGetItem) { if (cnode->inputs().size() <= kSummaryGetItem) {
...@@ -76,24 +75,11 @@ void GetSummaryNodes(const KernelGraph *graph, std::unordered_map<std::string, s ...@@ -76,24 +75,11 @@ void GetSummaryNodes(const KernelGraph *graph, std::unordered_map<std::string, s
} }
auto node = cnode->input(kSummaryGetItem); auto node = cnode->input(kSummaryGetItem);
MS_EXCEPTION_IF_NULL(node); MS_EXCEPTION_IF_NULL(node);
if (IsPrimitiveCNode(node, prim::kPrimTupleGetItem)) { auto item_with_index = AnfAlgo::VisitKernelWithReturnType(node, 0);
auto c = node->cast<CNodePtr>(); if (!AnfAlgo::IsRealKernel(item_with_index.first)) {
MS_EXCEPTION_IF_NULL(c); MS_LOG(EXCEPTION) << "Unexpected node:" << item_with_index.first->DebugString();
if (c->inputs().size() != kTupleGetItemInputSize) { }
MS_LOG(EXCEPTION) << "the node tuple_get_item must have 2 inputs!"; (*summary)[n->fullname_with_scope()] = item_with_index;
}
MS_EXCEPTION_IF_NULL(c->input(kInputNodeOutputIndexInTupleGetItem));
auto value_node = c->input(kInputNodeOutputIndexInTupleGetItem)->cast<ValueNodePtr>();
auto value = value_node->value();
MS_EXCEPTION_IF_NULL(value);
Int32ImmPtr int_imm_ptr = value->cast<Int32ImmPtr>();
MS_EXCEPTION_IF_NULL(int_imm_ptr);
index = int_imm_ptr->value();
node = c->input(kRealInputNodeIndexInTupleGetItem);
}
std::pair<AnfNodePtr, int> output_pair(node, index);
// get full name with scope will add scalar or tensor or image summary tag.
(*summary)[n->fullname_with_scope()] = output_pair;
} }
} }
MS_LOG(DEBUG) << "Update summary end size: " << (*summary).size(); MS_LOG(DEBUG) << "Update summary end size: " << (*summary).size();
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册