Coverage for / home / jenkins / .local / lib / python3.10 / site-packages / hyper_parallel / core / shard / ops / parallel_ops_register.py: 100%
5 statements
« prev ^ index » next coverage.py v7.13.1, created at 2026-05-11 07:26 +0800
« prev ^ index » next coverage.py v7.13.1, created at 2026-05-11 07:26 +0800
1# Copyright 2025 Huawei Technologies Co., Ltd
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14# ============================================================================
15"""
16Parallel layout decorator
17"""
18_DISTRIBUTED_OPS = {}
21def register_distributed_op(op_name, op_class):
22 """
23 Register a distributed operator implementation.
25 Args:
26 op_name (str): Name of the operator
27 op_class (class): Distributed operator implementation class
28 """
29 _DISTRIBUTED_OPS[op_name] = op_class
32def get_distributed_op(op_name):
33 """
34 Get distributed operator implementation by operator name.
36 Args:
37 op_name (str): Name of the operator
39 Returns:
40 object: Distributed operator instance or None if not found
41 """
42 return _DISTRIBUTED_OPS.get(op_name, None)