|
|
|
from typing import Callable
|
|
|
|
|
|
|
|
import torch
|
|
|
|
|
|
|
|
TORCH_MAJOR = int(torch.__version__.split('.')[0])
|
|
|
|
TORCH_MINOR = int(torch.__version__.split('.')[1])
|
|
|
|
|
|
|
|
if TORCH_MAJOR == 1 and TORCH_MINOR < 12:
|
|
|
|
META_COMPATIBILITY = False
|
|
|
|
elif TORCH_MAJOR == 1 and TORCH_MINOR == 12:
|
|
|
|
from . import _meta_regist_12
|
|
|
|
META_COMPATIBILITY = True
|
|
|
|
elif TORCH_MAJOR == 1 and TORCH_MINOR == 13:
|
|
|
|
from . import _meta_regist_13
|
|
|
|
META_COMPATIBILITY = True
|
|
|
|
elif TORCH_MAJOR == 2:
|
|
|
|
META_COMPATIBILITY = True
|
|
|
|
|
|
|
|
|
|
|
|
def compatibility(is_backward_compatible: bool = False) -> Callable:
|
|
|
|
"""A decorator to make a function compatible with different versions of PyTorch.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
is_backward_compatible (bool, optional): Whether the function is backward compatible. Defaults to False.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
Callable: The decorated function
|
|
|
|
"""
|
|
|
|
|
|
|
|
def decorator(func):
|
|
|
|
if META_COMPATIBILITY:
|
|
|
|
return func
|
|
|
|
else:
|
|
|
|
if is_backward_compatible:
|
|
|
|
return func
|
|
|
|
else:
|
|
|
|
|
|
|
|
def wrapper(*args, **kwargs):
|
|
|
|
raise RuntimeError(f'Function `{func.__name__}` is not compatible with PyTorch {torch.__version__}')
|
|
|
|
|
|
|
|
return wrapper
|
|
|
|
|
|
|
|
return decorator
|
|
|
|
|
|
|
|
|
|
|
|
def is_compatible_with_meta() -> bool:
|
|
|
|
"""Check the meta compatibility. Normally it should be called before importing some of the `colossalai.fx`
|
|
|
|
modules. If the meta compatibility is not satisfied, the `colossalai.fx` modules will be replaced by its
|
|
|
|
experimental counterparts.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
bool: The meta compatibility
|
|
|
|
"""
|
|
|
|
return META_COMPATIBILITY
|