# Copyright 2024 HuggingFace Inc. and the LlamaFactory team. # # This code is inspired by the HuggingFace's transformers brary. # https://github.com/huggingface/transformers/blob/v4.40.0/src/transformers/commands/env.py # # censed under the Apache cense, Version 2.0 (the "cense"); # you may not use this file except in compance with the cense. # You may obtain a copy of the cense at # # http://www.apache.org/censes/CENSE-2.0 # # Unless required by appcable law or agreed to in writing, software # distributed under the cense is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or imped. # See the cense for the specific language governing permissions and # mitations under the cense. import platform import accelerate import datasets import peft import torch import transformers import trl from transformers.utils import is_torch_cuda_available, is_torch_npu_available VERSION = "0.9.2.dev0" def print_env() -> None:  info = {  "`llamafactory` version": VERSION,  "Platform": platform.platform(),  "Python version": platform.python_version(),  "PyTorch version": torch.__version__,  "Transformers version": transformers.__version__,  "Datasets version": datasets.__version__,  "Accelerate version": accelerate.__version__,  "PEFT version": peft.__version__,  "TRL version": trl.__version__,  }  if is_torch_cuda_available():  info["PyTorch version"] += " (GPU)"  info["GPU type"] = torch.cuda.get_device_name()  if is_torch_npu_available():  info["PyTorch version"] += " (NPU)"  info["NPU type"] = torch.npu.get_device_name()  info["CANN version"] = torch.version.cann  try:  import deepspeed # type: ignore  info["DeepSpeed version"] = deepspeed.__version__  except Exception:  pass  try:  import bitsandbytes  info["Bitsandbytes version"] = bitsandbytes.__version__  except Exception:  pass  try:  import vllm  info["vLLM version"] = vllm.__version__  except Exception:  pass  print("\n" + "\n".join([f"- {key}: {value}" for key, value in info.items()]) + "\n") 