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.
152 lines
5.1 KiB
152 lines
5.1 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.
|
|
*/
|
|
|
|
#ifndef GE_GRAPH_PASSES_FLOW_CTRL_PASS_H_
|
|
#define GE_GRAPH_PASSES_FLOW_CTRL_PASS_H_
|
|
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "common/ge_inner_error_codes.h"
|
|
#include "inc/graph_pass.h"
|
|
|
|
namespace ge {
|
|
///
|
|
/// Add flow control to the computeGraph
|
|
///
|
|
class FlowCtrlPass : public GraphPass {
|
|
public:
|
|
///
|
|
/// Add flow control to the computeGraph.
|
|
/// @param compute_graph graph
|
|
/// @return SUCCESS: do success
|
|
/// NOT_CHANGED : do nothing
|
|
/// Other: failed
|
|
///
|
|
Status Run(ComputeGraphPtr compute_graph) override;
|
|
|
|
private:
|
|
///
|
|
/// Universal insert node to graph.
|
|
/// @param compute_graph graph
|
|
/// @param node_type inserted node type
|
|
/// @param node_name inserted node name
|
|
/// @param input_list input desc list
|
|
/// @param output_list output desc list
|
|
/// @return the inserted node. if insert failed return nullptr.
|
|
///
|
|
NodePtr InsertOp(ComputeGraphPtr &compute_graph, const string &node_type, const string &node_name,
|
|
const std::vector<GeTensorDesc> &input_list, const std::vector<GeTensorDesc> &output_list);
|
|
|
|
///
|
|
/// used for insert assign and assign add node.
|
|
/// include add input desc info.
|
|
/// @param compute_graph graph
|
|
/// @param node_type node type(assign/assignAdd)
|
|
/// @param node_name node name
|
|
/// @param ref_node assign input0
|
|
/// @param value_node assign input1
|
|
/// @return the inserted node. if insert failed return nullptr.
|
|
///
|
|
NodePtr InsertAssignOp(ComputeGraphPtr &compute_graph, const string &node_type, const string &node_name,
|
|
const NodePtr &ref_node, const NodePtr &value_node);
|
|
|
|
///
|
|
/// insert StreamSwitch to graph.
|
|
/// @param compute_graph graph
|
|
/// @param switch_name inserted StreamSwitch node name
|
|
/// @param loop_cond loop condition
|
|
/// @param iter_per_loop iter per loop
|
|
/// @return the inserted node. if insert failed return nullptr.
|
|
///
|
|
NodePtr InsertStreamSwitchOp(ComputeGraphPtr &compute_graph, const string &switch_name, const NodePtr &loop_cond,
|
|
const NodePtr &iter_per_loop);
|
|
|
|
///
|
|
/// check and add variable node to graph.
|
|
/// if the variable is exists, do nothing.
|
|
/// @param compute_graph graph
|
|
/// @param name inserted variable node name
|
|
/// @return the variable node. if insert failed return nullptr.
|
|
///
|
|
NodePtr AddVariableNode(ComputeGraphPtr &compute_graph, const string &name);
|
|
|
|
///
|
|
/// add global step variable node to graph.
|
|
/// if the variable is exists, do nothing.
|
|
/// @param compute_graph graph
|
|
/// @return SUCCESS: do success
|
|
/// Other: failed
|
|
///
|
|
Status AddGlobalStepVariableNode(ComputeGraphPtr &compute_graph);
|
|
|
|
///
|
|
/// create switch true branch for big cycle.
|
|
/// @param compute_graph graph
|
|
/// @param loop_cond_node loop condition node
|
|
/// @param loop_increment_node loop increment node
|
|
/// @param switch_node switch node
|
|
/// @return SUCCESS: do success
|
|
/// Other: failed
|
|
///
|
|
Status CreateIterCtrlTrueBranch(ComputeGraphPtr &compute_graph, const NodePtr &loop_cond_node,
|
|
const NodePtr &loop_increment_node, NodePtr &switch_node);
|
|
|
|
///
|
|
/// create switch false branch for big cycle.
|
|
/// @param compute_graph graph
|
|
/// @param loop_cond_node loop condition node
|
|
/// @param loop_reset_node loop reset node
|
|
/// @param switch_node switch node
|
|
/// @return SUCCESS: do success
|
|
/// Other: failed
|
|
///
|
|
Status CreateIterCtrlFalseBranch(ComputeGraphPtr &compute_graph, const NodePtr &loop_cond_node,
|
|
const NodePtr &loop_reset_node, NodePtr &switch_node);
|
|
|
|
///
|
|
/// add Fp/Bp iterator ctrl nodes(big cycle).
|
|
/// @param compute_graph graph
|
|
/// @param pre_node pre node(netoutput node)
|
|
/// @return SUCCESS: do success
|
|
/// Other: failed
|
|
///
|
|
Status AddFpBpIteratorCtrl(ComputeGraphPtr &compute_graph, NodePtr &pre_node);
|
|
|
|
///
|
|
/// add special iterator ctrl nodes(small cycle).
|
|
/// @param compute_graph graph
|
|
/// @param loop_after_node pre node(iterate node)
|
|
/// @return SUCCESS: do success
|
|
/// Other: failed
|
|
///
|
|
Status AddSpecialNodeIteratorCtrl(ComputeGraphPtr &compute_graph, NodePtr &loop_after_node);
|
|
|
|
///
|
|
/// add special iterator ctrl nodes(small cycle).
|
|
/// @param compute_graph graph
|
|
/// @return true: two or more dataSet exist
|
|
/// false: only one dataSet exist
|
|
///
|
|
bool CheckMultiDataSet(ComputeGraphPtr &compute_graph);
|
|
|
|
NodePtr assign_add_node_in_fpbp_loop_ = nullptr;
|
|
std::vector<NodePtr> active_nodes_in_iter_loop_;
|
|
};
|
|
} // namespace ge
|
|
|
|
#endif // GE_GRAPH_PASSES_FLOW_CTRL_PASS_H_
|