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

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 = {} 

19 

20 

21def register_distributed_op(op_name, op_class): 

22 """ 

23 Register a distributed operator implementation. 

24 

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 

30 

31 

32def get_distributed_op(op_name): 

33 """ 

34 Get distributed operator implementation by operator name. 

35 

36 Args: 

37 op_name (str): Name of the operator 

38 

39 Returns: 

40 object: Distributed operator instance or None if not found 

41 """ 

42 return _DISTRIBUTED_OPS.get(op_name, None)