| |
|
| | """This file holding some environment constant for sharing by other files."""
|
| | import os
|
| | import os.path as osp
|
| | import subprocess
|
| | import sys
|
| | from collections import OrderedDict, defaultdict
|
| |
|
| | import numpy as np
|
| | import torch
|
| |
|
| |
|
| | def is_rocm_pytorch() -> bool:
|
| | """Check whether the PyTorch is compiled on ROCm."""
|
| | is_rocm = False
|
| | if TORCH_VERSION != 'parrots':
|
| | try:
|
| | from torch.utils.cpp_extension import ROCM_HOME
|
| | is_rocm = True if ((torch.version.hip is not None) and
|
| | (ROCM_HOME is not None)) else False
|
| | except ImportError:
|
| | pass
|
| | return is_rocm
|
| |
|
| | TORCH_VERSION = torch.__version__
|
| |
|
| | def get_build_config():
|
| | """Obtain the build information of PyTorch or Parrots."""
|
| | if TORCH_VERSION == 'parrots':
|
| | from parrots.config import get_build_info
|
| | return get_build_info()
|
| | else:
|
| | return torch.__config__.show()
|
| |
|
| | try:
|
| | import torch_musa
|
| | IS_MUSA_AVAILABLE = True
|
| | except Exception:
|
| | IS_MUSA_AVAILABLE = False
|
| |
|
| | def is_musa_available() -> bool:
|
| | return IS_MUSA_AVAILABLE
|
| |
|
| | def is_cuda_available() -> bool:
|
| | """Returns True if cuda devices exist."""
|
| | return torch.cuda.is_available()
|
| |
|
| | def _get_cuda_home():
|
| | if TORCH_VERSION == 'parrots':
|
| | from parrots.utils.build_extension import CUDA_HOME
|
| | else:
|
| | if is_rocm_pytorch():
|
| | from torch.utils.cpp_extension import ROCM_HOME
|
| | CUDA_HOME = ROCM_HOME
|
| | else:
|
| | from torch.utils.cpp_extension import CUDA_HOME
|
| | return CUDA_HOME
|
| |
|
| |
|
| | def _get_musa_home():
|
| | return os.environ.get('MUSA_HOME')
|
| |
|
| |
|
| | def collect_env():
|
| | """Collect the information of the running environments.
|
| |
|
| | Returns:
|
| | dict: The environment information. The following fields are contained.
|
| |
|
| | - sys.platform: The variable of ``sys.platform``.
|
| | - Python: Python version.
|
| | - CUDA available: Bool, indicating if CUDA is available.
|
| | - GPU devices: Device type of each GPU.
|
| | - CUDA_HOME (optional): The env var ``CUDA_HOME``.
|
| | - NVCC (optional): NVCC version.
|
| | - GCC: GCC version, "n/a" if GCC is not installed.
|
| | - MSVC: Microsoft Virtual C++ Compiler version, Windows only.
|
| | - PyTorch: PyTorch version.
|
| | - PyTorch compiling details: The output of \
|
| | ``torch.__config__.show()``.
|
| | - TorchVision (optional): TorchVision version.
|
| | - OpenCV (optional): OpenCV version.
|
| | """
|
| | from distutils import errors
|
| |
|
| | env_info = OrderedDict()
|
| | env_info['sys.platform'] = sys.platform
|
| | env_info['Python'] = sys.version.replace('\n', '')
|
| |
|
| | cuda_available = is_cuda_available()
|
| | musa_available = is_musa_available()
|
| | env_info['CUDA available'] = cuda_available
|
| | env_info['MUSA available'] = musa_available
|
| | env_info['numpy_random_seed'] = np.random.get_state()[1][0]
|
| |
|
| | if cuda_available:
|
| | devices = defaultdict(list)
|
| | for k in range(torch.cuda.device_count()):
|
| | devices[torch.cuda.get_device_name(k)].append(str(k))
|
| | for name, device_ids in devices.items():
|
| | env_info['GPU ' + ','.join(device_ids)] = name
|
| |
|
| | CUDA_HOME = _get_cuda_home()
|
| | env_info['CUDA_HOME'] = CUDA_HOME
|
| |
|
| | if CUDA_HOME is not None and osp.isdir(CUDA_HOME):
|
| | if CUDA_HOME == '/opt/rocm':
|
| | try:
|
| | nvcc = osp.join(CUDA_HOME, 'hip/bin/hipcc')
|
| | nvcc = subprocess.check_output(
|
| | f'"{nvcc}" --version', shell=True)
|
| | nvcc = nvcc.decode('utf-8').strip()
|
| | release = nvcc.rfind('HIP version:')
|
| | build = nvcc.rfind('')
|
| | nvcc = nvcc[release:build].strip()
|
| | except subprocess.SubprocessError:
|
| | nvcc = 'Not Available'
|
| | else:
|
| | try:
|
| | nvcc = osp.join(CUDA_HOME, 'bin/nvcc')
|
| | nvcc = subprocess.check_output(f'"{nvcc}" -V', shell=True)
|
| | nvcc = nvcc.decode('utf-8').strip()
|
| | release = nvcc.rfind('Cuda compilation tools')
|
| | build = nvcc.rfind('Build ')
|
| | nvcc = nvcc[release:build].strip()
|
| | except subprocess.SubprocessError:
|
| | nvcc = 'Not Available'
|
| | env_info['NVCC'] = nvcc
|
| | elif musa_available:
|
| | devices = defaultdict(list)
|
| | for k in range(torch.musa.device_count()):
|
| | devices[torch.musa.get_device_name(k)].append(str(k))
|
| | for name, device_ids in devices.items():
|
| | env_info['GPU ' + ','.join(device_ids)] = name
|
| |
|
| | MUSA_HOME = _get_musa_home()
|
| | env_info['MUSA_HOME'] = MUSA_HOME
|
| |
|
| | if MUSA_HOME is not None and osp.isdir(MUSA_HOME):
|
| | try:
|
| | mcc = osp.join(MUSA_HOME, 'bin/mcc')
|
| | subprocess.check_output(f'"{mcc}" -v', shell=True)
|
| | except subprocess.SubprocessError:
|
| | mcc = 'Not Available'
|
| | env_info['mcc'] = mcc
|
| | try:
|
| |
|
| |
|
| |
|
| | import io
|
| | import sysconfig
|
| | cc = sysconfig.get_config_var('CC')
|
| | if cc:
|
| | cc = osp.basename(cc.split()[0])
|
| | cc_info = subprocess.check_output(f'{cc} --version', shell=True)
|
| | env_info['GCC'] = cc_info.decode('utf-8').partition(
|
| | '\n')[0].strip()
|
| | else:
|
| |
|
| |
|
| |
|
| | import locale
|
| | import os
|
| | from distutils.ccompiler import new_compiler
|
| | ccompiler = new_compiler()
|
| | ccompiler.initialize()
|
| | cc = subprocess.check_output(
|
| | f'{ccompiler.cc}', stderr=subprocess.STDOUT, shell=True)
|
| | encoding = os.device_encoding(
|
| | sys.stdout.fileno()) or locale.getpreferredencoding()
|
| | env_info['MSVC'] = cc.decode(encoding).partition('\n')[0].strip()
|
| | env_info['GCC'] = 'n/a'
|
| | except (subprocess.CalledProcessError, errors.DistutilsPlatformError):
|
| | env_info['GCC'] = 'n/a'
|
| | except io.UnsupportedOperation as e:
|
| |
|
| |
|
| |
|
| |
|
| | env_info['MSVC'] = f'n/a, reason: {str(e)}'
|
| |
|
| | env_info['PyTorch'] = torch.__version__
|
| | env_info['PyTorch compiling details'] = get_build_config()
|
| |
|
| | try:
|
| | import torchvision
|
| | env_info['TorchVision'] = torchvision.__version__
|
| | except ModuleNotFoundError:
|
| | pass
|
| |
|
| | try:
|
| | import cv2
|
| | env_info['OpenCV'] = cv2.__version__
|
| | except ImportError:
|
| | pass
|
| |
|
| |
|
| | return env_info
|
| |
|
| | if __name__ == '__main__':
|
| | for name, val in collect_env().items():
|
| | print(f'{name}: {val}') |