/** * 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_PARTITIONED_CALL_OP_LABEL_PASS_H_ #define GE_GRAPH_PASSES_PARTITIONED_CALL_OP_LABEL_PASS_H_ #include "graph/node.h" #include "graph/label/label_maker.h" /******************************************************************************* +---------------+ | Node | +---------------+ | Node | +---------------+ |PartitionedCall| +---------------+ +---------------+ | Node | +---------------+ +---------------+ | StreamActive | | Node | +---------------+ +---------------+ | f | | Node | +---------------+ +---------------+ | u | |PartitionedCall| +---------------+ +---------------+ | n | | Node | ====> +---------------+ +---------------+ | c | | Node | +---------------+ +---------------+ | Node | +---------------+ +---------------+ | Node | +---------------+ | Node | +---------------+ +---------------+ | f | | Node | +---------------+ +---------------+ | u | +---------------+ | n | +---------------+ | c | +---------------+ *******************************************************************************/ namespace ge { class PartitionedCallLabelMaker : public LabelMaker { public: PartitionedCallLabelMaker(const ComputeGraphPtr &graph, const NodePtr &owner) : LabelMaker(graph, owner) {} ~PartitionedCallLabelMaker() override {} virtual Status Run(uint32_t &label_index); }; } // namespace ge #endif // GE_GRAPH_PASSES_PARTITIONED_CALL_OP_LABEL_PASS_H_