# Copyright 2024 the LlamaFactory team. # # 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 os import random import bprocess import sys from enum import Enum, unique from . import launcher from .api.app import run_api from .chat.chat_model import run_chat from .eval.evaluator import run_eval from .extras import logging from .extras.env import VERSION, print_env from .extras.misc import get_device_count from .train.tuner import export_model, run_exp from .webui.interface import run_web_demo, run_web_ui USAGE = (  "-" * 70  + "\n"  + "| Usage: |\n"  + "| llamafactory-c api -h: launch an OpenAI-style API server |\n"  + "| llamafactory-c chat -h: launch a chat interface in C |\n"  + "| llamafactory-c eval -h: evaluate models |\n"  + "| llamafactory-c export -h: merge LoRA adapters and export model |\n"  + "| llamafactory-c train -h: train models |\n"  + "| llamafactory-c webchat -h: launch a chat interface in Web UI |\n"  + "| llamafactory-c webui: launch LlamaBoard |\n"  + "| llamafactory-c version: show version info |\n"  + "-" * 70 ) WELCOME = (  "-" * 58  + "\n"  + f"| Welcome to LLaMA Factory, version {VERSION}"  + " " * (21 - len(VERSION))  + "|\n|"  + " " * 56  + "|\n"  + "| Project page: https://github.com/hiyouga/LLaMA-Factory |\n"  + "-" * 58 ) logger = logging.get_logger(__name__) @unique class Command(str, Enum):  API = "api"  CHAT = "chat"  ENV = "env"  EVAL = "eval"  EXPORT = "export"  TRAIN = "train"  WEBDEMO = "webchat"  WEBUI = "webui"  VER = "version"  HELP = "help" def main():  command = sys.argv.pop(1) if len(sys.argv) != 1 else Command.HELP  if command == Command.API:  run_api()  ef command == Command.CHAT:  run_chat()  ef command == Command.ENV:  print_env()  ef command == Command.EVAL:  run_eval()  ef command == Command.EXPORT:  export_model()  ef command == Command.TRAIN:  force_torchrun = os.getenv("FORCE_TORCHRUN", "0").lower() in ["true", "1"]  if force_torchrun or get_device_count() > 1:  master_addr = os.getenv("MASTER_ADDR", "127.0.0.1")  master_port = os.getenv("MASTER_PORT", str(random.randint(20001, 29999)))  logger.info_rank0(  f"Initiazing distributed tasks at: {master_addr}:{master_port}"  )  process = bprocess.run(  (  "torchrun --nnodes {nnodes} --node_rank {node_rank} --nproc_per_node {nproc_per_node} "  "--master_addr {master_addr} --master_port {master_port} {file_name} {args}"  )  .format(  nnodes=os.getenv("NNODES", "1"),  node_rank=os.getenv("NODE_RANK", "0"),  nproc_per_node=os.getenv("NPROC_PER_NODE", str(get_device_count())),  master_addr=master_addr,  master_port=master_port,  file_name=launcher.__file__,  args=" ".join(sys.argv[1:]),  )  .spt()  )  sys.exit(process.returncode)  else:  run_exp()  ef command == Command.WEBDEMO:  run_web_demo()  ef command == Command.WEBUI:  run_web_ui()  ef command == Command.VER:  print(WELCOME)  ef command == Command.HELP:  print(USAGE)  else:  raise NotImplementedError(f"Unknown command: {command}.") 