* remove fastchat and sharegpt * remove imports * remove more fastchat imports * chore: remove unused functions * feat: remove sharegpt and deprecate from docs * chore: remove unused sharegpt checks * fix: remove sharegpt type from tests * feat: add sharegpt deprecation error * feat: update readme --------- Co-authored-by: NanoCode012 <nano@axolotl.ai>
59 lines
1.5 KiB
Python
59 lines
1.5 KiB
Python
"""
|
|
CLI to run training on a model
|
|
"""
|
|
import logging
|
|
from pathlib import Path
|
|
from typing import Union
|
|
|
|
import fire
|
|
from dotenv import load_dotenv
|
|
from transformers.hf_argparser import HfArgumentParser
|
|
|
|
from axolotl.cli import (
|
|
check_accelerate_default_config,
|
|
check_user_token,
|
|
load_cfg,
|
|
load_datasets,
|
|
load_rl_datasets,
|
|
print_axolotl_text_art,
|
|
)
|
|
from axolotl.common.cli import TrainerCliArgs
|
|
from axolotl.integrations.base import PluginManager
|
|
from axolotl.train import train
|
|
|
|
LOG = logging.getLogger("axolotl.cli.train")
|
|
|
|
|
|
def do_cli(config: Union[Path, str] = Path("examples/"), **kwargs):
|
|
# pylint: disable=duplicate-code
|
|
parsed_cfg = load_cfg(config, **kwargs)
|
|
parser = HfArgumentParser((TrainerCliArgs))
|
|
parsed_cli_args, _ = parser.parse_args_into_dataclasses(
|
|
return_remaining_strings=True
|
|
)
|
|
return do_train(parsed_cfg, parsed_cli_args)
|
|
|
|
|
|
def do_train(cfg, cli_args) -> None:
|
|
print_axolotl_text_art()
|
|
check_accelerate_default_config()
|
|
check_user_token()
|
|
|
|
if cfg.rl: # and cfg.rl != "orpo":
|
|
dataset_meta = load_rl_datasets(cfg=cfg, cli_args=cli_args)
|
|
else:
|
|
dataset_meta = load_datasets(cfg=cfg, cli_args=cli_args)
|
|
|
|
model, tokenizer = train(cfg=cfg, cli_args=cli_args, dataset_meta=dataset_meta)
|
|
plugin_manager = PluginManager.get_instance()
|
|
|
|
del model
|
|
del tokenizer
|
|
|
|
plugin_manager.post_train_unload(cfg)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
load_dotenv()
|
|
fire.Fire(do_cli)
|