Skip to content

Latest commit

 

History

History
576 lines (433 loc) · 28.9 KB

trainer.md

File metadata and controls

576 lines (433 loc) · 28.9 KB

PaddleNLP Trainer API

PaddleNLP提供了Trainer训练API,针对训练过程的通用训练配置做了封装,比如:

  • 优化器、学习率调度等训练配置
  • 多卡,混合精度,梯度累积等功能
  • checkpoint断点,断点重启(数据集,随机数恢复)
  • 日志显示,loss可视化展示等

用户输入模型,数据集,就可以使用Trainer API高效快速的实现预训练、微调等任务。

Trainer基本使用方法介绍

下面是用户使用 Trainer API进行finetune任务的简单示例,这里以中文情感分类数据集chnsenticorp为例。 更详细的使用可以参考CLUE Trainer版本。

  1. 导入需要用到的头文件。
    • 主要是模型、Tokenizer
    • 还有Trainer组件
      • 其中Trainer是训练主要入口,用户传入模型,数据集,即可进行训练
      • TrainingArguments 包含了用户需要的大部分训练参数。
      • PdArgumentParser 是用户输出参数的工具
from functools import partial
import paddle
from paddlenlp.datasets import load_dataset
from paddlenlp.transformers import AutoModelForSequenceClassification, AutoTokenizer
from paddlenlp.trainer import Trainer, TrainingArguments, PdArgumentParser
  1. 设置好用户参数
    • PdArgumentParser 可以接受多个类似TrainingArguments的参数。用户可以自定义所需要的ModelArguments, DataArguments为 tuple 传入 PdArgumentParser即可。
    • 这些参数都是通过python xxx.py --dataset xx --max_seq_length xx的方式传入。TrainingArguments的所有可配置参数见后文。
from dataclasses import dataclass
@dataclass
class DataArguments:
    dataset: str = field(
        default=None,
        metadata={"help": "The name of the dataset to use."})

    max_seq_length: int = field(
        default=128,
        metadata={"help": "The maximum total input sequence length after tokenization."})

parser = PdArgumentParser(TrainingArguments, DataArguments)
(training_args, data_args) = parser.parse_args_into_dataclasses()
  1. 加载模型,tokenizer, 数据集
    • 注意,这里的数据集,需要输出的是一个dict。dict中的key,需要和模型的输入名称对应。
    • 这里的,labels如果模型没有使用到,我们还需要额外定义criterion,计算最后的loss损失。
train_dataset = load_dataset("chnsenticorp", splits=["train"])
model = AutoModelForSequenceClassification.from_pretrained("ernie-3.0-medium-zh", num_classes=len(train_dataset.label_list))
tokenizer = AutoTokenizer.from_pretrained("ernie-3.0-medium-zh")

def convert_example(example, tokenizer):
    encoded_inputs = tokenizer(text=example["text"], max_seq_len=128, pad_to_max_seq_len=True)
    encoded_inputs["labels"] = int(example["label"])
    return encoded_inputs

train_dataset = train_dataset.map(partial(convert_example, tokenizer=tokenizer))
  1. 构造Trainer实例,进行模型训练。
    • 这里传入model,criterion,args,train_dataset,tokenizer这些训练需要的组件,构建了实例化的trainer
    • 使用trainer.train()接口开始训练过程。训练完成后,可以保存模型,保存一些日志。
trainer = Trainer(
    model=model,
    criterion=paddle.nn.loss.CrossEntropyLoss(),
    args=training_args,
    train_dataset=train_dataset if training_args.do_train else None,
    tokenizer=tokenizer)

if training_args.do_train:
    train_result = trainer.train()
    metrics = train_result.metrics
    trainer.save_model()
    trainer.log_metrics("train", metrics)
    trainer.save_state()

预训练的使用方式可以参考ERNIE-1.0 Trainer版本。

Trainer 实例化参数介绍

Trainer 是一个简单,但功能完整的 Paddle训练和评估模块,并针对 PaddleNLP 模型进行了优化。

参数model([`PretrainedModel`]  `paddle.nn.Layer`可选):
        用于训练评估或预测的模型。
        [`Trainer`] 对PaddleNLP的 [`PretrainedModel`] 一起使用进行了优化你仍然可以使用
        您自己的模型定义为`paddle.nn.Layer`只要它们的工作方式与 PaddleNLP 模型相同。

        ([`PretrainedModel`] or `paddle.nn.Layer`, *optional*):
        The model to train, evaluate or use for predictions.
    criterion (`paddle.nn.Layer`*可选*):
        model可能只输出中间结果loggit如果想对模型的输出做更多的计算可以添加criterion层The model may only output the loggit, if you want do more computation for the output of model,
        you can add the criterion Layer.

    args([`TrainingArguments`],可选):
        训练时需要用到的参数将默认使用 [`TrainingArguments`] 初始化`output_dir` 设置为当前目录中名为 *tmp_trainer* 的目录如果未提供)。

        ([`TrainingArguments`], *optional*):
        The arguments to tweak for training. Will default to a basic instance of [`TrainingArguments`] with the
        `output_dir` set to a directory named *tmp_trainer* in the current directory if not provided.

    data_collator`DataCollator`可选):
        用于将 `train_dataset`  `eval_dataset` 的数据组合为batch的函数如果没有提供 `tokenizer`则默认为 [`default_data_collator`], 否则为
        [`DataCollatorWithPadding`]。

         (`DataCollator`, *optional*):
        The function to use to form a batch from a list of elements of `train_dataset` or `eval_dataset`. Will
        default to [`default_data_collator`] if no `tokenizer` is provided, an instance of
        [`DataCollatorWithPadding`] otherwise.


    train_dataset`paddle.io.Dataset`  `paddle.io.IterableDataset`可选):
        用于训练的数据集如果是 `datasets.Dataset`那么
        `model.forward()` 不需要的输入字段会被自动删除。

        (`paddle.io.Dataset` or `paddle.io.IterableDataset`, *optional*):
        The dataset to use for training. If it is an `datasets.Dataset`, columns not accepted by the
        `model.forward()` method are automatically removed.

    eval_dataset`paddle.io.Dataset`  `Dict[str, paddle.io.Dataset]`可选):
        用于评估的数据集如果是 `datasets.Dataset`那么
        `model.forward()` 不需要的输入字段会被自动删除如果它是一个字典则将对字典中每个数据集进行评估并将字典中的键添加到评估指标名称前The dataset to use for evaluation. If it is a [`~datasets.Dataset`], columns not accepted by the
        `model.forward()` method are automatically removed. If it is a dictionary, it will evaluate on each
        dataset prepending the dictionary key to the metric name.

    tokenizer([`PretrainedTokenizer`],可选):
        用于数据预处理的tokenizer如果传入将用于自动Pad输入
        batch输入的最大长度它随模型保存可以重新运行中断的训练过程。

         ([`PretrainedTokenizer`], *optional*):
        The tokenizer used to preprocess the data. If provided, will be used to automatically pad the inputs the
        maximum length when batching inputs, and it will be saved along the model to make it easier to rerun an
        interrupted training or reuse the fine-tuned model.

    compute_metrics (`Callable[[EvalPrediction], Dict]`, 可选):
        用于评估的计算指标的函数必须采用 [`EvalPrediction`] 并返回
        dict形式的metrics结果。

        (`Callable[[EvalPrediction], Dict]`, *optional*):
        The function that will be used to compute metrics at evaluation. Must take a [`EvalPrediction`] and return
        a dictionary string to metric values.

    callbacks (List of [`TrainerCallback`],*可选*):
        用于自定义训练call列表函数将这些函数会被添加到默认回调函数列表如果要删除使用的回调函数请使用 [`Trainer.remove_callback`] 方法A list of callbacks to customize the training loop. Will add those to the list of default callbacks.
        If you want to remove one of the default callbacks used, use the [`Trainer.remove_callback`] method.

    optimizers (`Tuple[paddle.optimizer.Optimizer, paddle.optimizer.lr.LRScheduler]`, 可选):
        一个tuple, 包含要使用Optimizer和LRScheduler将默认为模型上的 [`AdamW`] 实例
        和LinearDecayWithWarmup。

        (`Tuple[paddle.optimizer.Optimizer, paddle.optimizer.lr.LRScheduler]`, *optional*)
        A tuple containing the optimizer and the scheduler to use. Will default to an instance of [`AdamW`] on your model
        and a scheduler  [`LinearDecayWithWarmup`].

    preprocess_logits_for_metrics (`Callable[[paddle.Tensor, paddle.Tensor], paddle.Tensor]`, 可选)):
        一个函数, 在每次评估之前对logits进行预处理。

        (`Callable[[paddle.Tensor, paddle.Tensor], paddle.Tensor]`, *optional*)
        A function that preprocess the logits right before caching them at each evaluation step. Must take two
        tensors, the logits and the labels, and return the logits once processed as desired. The modifications made
        by this function will be reflected in the predictions received by `compute_metrics`.

TrainingArguments 参数介绍

  --output_dir
                        保存模型输出和中间checkpoints的输出目录。(`str`, 必须, 默认为 `None`)

                        The output directory where the model predictions and
                        checkpoints will be written. (default: None)

  --overwrite_output_dir
                        如果 `True`覆盖输出目录的内容如果 `output_dir` 指向检查点
                        目录则使用它继续训练。(`bool`, 可选, 默认为 `False`)

                        Overwrite the content of the output directory. Use
                        this to continue training if output_dir points to a
                        checkpoint directory. (default: False)

  --do_train
                        是否进行训练任务`Trainer`不直接使用此参数而是提供给用户
                        的训练/评估脚本使用。(`bool`, 可选, 默认为 `False`)

                        Whether to run training. (default: False)

  --do_eval
                        是否进行评估任务同上。(`bool`, 可选, 默认为 `False`)

                        Whether to run eval on the dev set. (default: False)

  --do_predict
                        是否进行预测任务同上。(`bool`, 可选, 默认为 `False`)

                        Whether to run predictions on the test set. (default:False)

  --do_export
                        是否进行模型导出任务同上。(`bool`, 可选, 默认为 `False`)

                        Whether to export infernece model. (default: False)

  --evaluation_strategy {no,steps,epoch}
                        评估策略,(`str`, 可选默认为 `"no"`):
                        训练期间采用的评估策略可能的值为- `"no"`训练期间不进行评估- `"steps"`评估在每个`eval_steps`完成并记录)。
                            - `"epoch"`在每个 epoch 结束时进行评估The evaluation strategy to use. (default: no)

  --prediction_loss_only
                        在执行评估和预测任务时只返回loss的值。(`bool`, 可选, 默认为 `False`)

                        When performing evaluation and predictions, only
                        returns the loss. (default: False)

  --per_device_train_batch_size
                        用于训练的每个 GPU 核心/CPU 的batch大小.(`int`可选默认为 8Batch size per GPU core/CPU for training. (default: 8)

  --per_device_eval_batch_size
                        用于评估的每个 GPU 核心/CPU 的batch大小.(`int`可选默认为 8Batch size per GPU core/CPU for evaluation. (default:8)

  --gradient_accumulation_steps
                        在执行反向更新回传梯度之前累积梯度的更新步骤数`int`可选默认为 1Number of updates steps to accumulate before
                        performing a backward/update pass. (default: 1)

  --eval_accumulation_steps
                        在将结果移动到CPU之前累积输出张量的预测步骤数如果如果未设置则在移动到CPU之前整个预测都会在GPU上累积速度更快需要更多的显存)。
                        (`int`可选默认为 None 不设置Number of predictions steps to accumulate the output tensors for,
                        before moving the results to the CPU. If left unset, the whole predictions are
                        accumulated on GPU before being moved to the CPU (faster butrequires more memory)
                        (default: None)

  --learning_rate
                        优化器的初始学习率, (`float`可选默认为 5e-05The initial learning rate for optimizer. (default: 5e-05)

  --weight_decay
                        除了所有bias和 LayerNorm 权重之外应用于所有层的权重衰减数值。(`float`可选默认为 0.0Weight decay for AdamW if we apply some. (default:
                        0.0)

  --adam_beta1
                        AdamW的优化器的 beta1 超参数。(`float`可选默认为 0.9Beta1 for AdamW optimizer (default: 0.9)

  --adam_beta2
                        AdamW的优化器的 beta2 超参数。(`float`可选默认为 0.999Beta2 for AdamW optimizer (default: 0.999)

  --adam_epsilon
                        AdamW的优化器的 epsilon 超参数。(`float`可选默认为 1e-8)

                        Epsilon for AdamW optimizer. (default: 1e-08)

  --max_grad_norm
                        最大梯度范数用于梯度裁剪)。(`float`可选默认为 1.0Max gradient norm. (default: 1.0)

  --num_train_epochs
                        要执行的训练 epoch 总数如果不是整数将在停止训练
                        之前执行最后一个 epoch 的小数部分百分比)。
                        (`float`, 可选, 默认为 3.0):

                        Total number of training epochs to perform. (default:3.0)

  --max_steps
                        如果设置为正数则表示要执行的训练步骤总数覆盖`num_train_epochs`。(`int`可选默认为 -1If > 0: set total number of training steps to
                        perform.Override num_train_epochs. (default: -1

  --lr_scheduler_type
                        要使用的学习率调度策略。 (`str`, 可选, 默认为 `"linear"`)

                        The scheduler type to use. (default: linear) 支持linear, cosine, constant, constant_with_warmup.

  --warmup_ratio
                        用于从 0  `learning_rate` 的线性warmup的总训练步骤的比例。(`float`可选默认为 0.0Linear warmup over warmup_ratio fraction of total
                        steps. (default: 0.0)

  --warmup_steps
                        用于从 0  `learning_rate` 的线性warmup的步数覆盖warmup_ratio参数。
                        (`int`可选默认为 0Linear warmup over warmup_steps. (default: 0)

  --log_on_each_node
                        在多节点分布式训练中是在每个节点上记录一次还是仅在主节点上记录节点。(`bool`可选默认为`True`When doing a multinode distributed training, whether
                        to log once per node or just once on the main node.
                        (default: True)

  --logging_dir
                        VisualDL日志目录。(`str`可选默认为NoneNone情况下会修改为 *output_dir/runs/**CURRENT_DATETIME_HOSTNAME**

                        VisualDL log dir. (default: None)

  --logging_strategy {no,steps,epoch}
                        (`str`, 可选默认为 `"steps"`)
                        训练期间采用的日志记录策略可能的值为- `"no"`训练期间不进行记录- `"epoch"`记录在每个 epoch 结束时完成- `"steps"`记录是每 `logging_steps` 完成的The logging strategy to use. (default: steps)

  --logging_first_step
                        是否记录和评估第一个 `global_step`。(`bool`可选默认为`False`Log the first global_step (default: False)

  --logging_steps
                        如果 `logging_strategy="steps"`则两个日志之间的更新步骤数。
                        (`int`可选默认为 500Log every X updates steps. (default: 500)

  --save_strategy {no,steps,epoch}
                        (`str`, 可选默认为 `"steps"`)
                        训练期间采用的checkpoint保存策略可能的值为- `"no"`训练期间不保存- `"epoch"`保存在每个 epoch 结束时完成- `"steps"`保存是每`save_steps`完成The checkpoint save strategy to use. (default: steps)

  --save_steps
                        如果 `save_strategy="steps"`则在两个checkpoint保存之间的更新步骤数。
                        (`int`可选默认为 500Save checkpoint every X updates steps. (default: 500)

  --save_total_limit
                        如果设置次参数将限制checkpoint的总数删除旧的checkpoints
                        `输出目录`。(`int`可选Limit the total amount of checkpoints. Deletes the
                        older checkpoints in the output_dir. Default is
                        unlimited checkpoints (default: None)

  --save_on_each_node
                        在做多节点分布式训练时是在每个节点上保存模型和checkpoints还是只在主节点上当不同的节点使用相同的存储时不应激活此功能因为每个节点的文件将以相同的名称保存。(`bool`, 可选, 默认为 `False`)

                        When doing multi-node distributed training, whether to
                        save models and checkpoints on each node, or only on
                        the main one (default: False)

  --no_cuda
                        是否不使用 CUDA即使CUDA环境可用。(`bool`, 可选, 默认为 `False`)
                        Do not use CUDA even when it is available (default:
                        False)
  --seed
                        设置的随机种子为确保多次运行的可复现性。(`int`可选默认为 42Random seed that will be set at the beginning of
                        training. (default: 42)

  --bf16
                        是否使用 bf16 混合精度训练而不是 fp32 训练需要 Ampere 或更高的 NVIDIA
                        显卡架构支持这是实验性质的API以后可能会修改。
                        (`bool`, 可选, 默认为 `False`)

                        Whether to use bf16 (mixed) precision instead of
                        32-bit. Requires Ampere or higher NVIDIA architecture.
                        This is an experimental API and it may change.
                        (default: False)

  --fp16
                        是否使用 fp16 混合精度训练而不是 fp32 训练。
                        (`bool`, 可选, 默认为 `False`)

                        Whether to use fp16 (mixed) precision instead of
                        32-bit (default: False)

  --fp16_opt_level
                        混合精度训练模式可为``O1````O2``模式默认``O1``模式默认O1.
                        O1表示混合精度训练O2表示纯fp16/bf16训练只在fp16或bf16选项开启时候生效.
                        (`str`, 可选, 默认为 `O1`)

                        For fp16: AMP optimization level selected in
                        ['O0', 'O1', and 'O2']. See details at https://www.pad
                        dlepaddle.org.cn/documentation/docs/zh/develop/api/pad
                        dle/amp/auto_cast_cn.html (default: O1)

  --scale_loss
                        fp16/bf16训练时scale_loss的初始值。
                        (`float`可选默认为 32768The value of initial scale_loss for fp16. (default: 32768)

  --sharding
                        是否使用Paddle的Sharding数据并行功能用户的参数支持sharding `stage1`, `stage2` or `stage3`其中`stage2``stage3`可以和`offload`组合使用每个种策略分别为stage1 : optimizer 中的参数切分到不同卡
                            stage2 : optimizer  + gradient 中的参数切分到不同卡
                            stage3 : parameter + gradient + optimizer  中的参数都切分到不同卡
                            offloadoffload parameters to cpu 部分参数存放到cpu中
                         (`str`,  可选, 默认为 `` 不使用sharding)
                         注意当前stage3暂时不可用

                        Whether or not to use Paddle Sharding Data Parallel training (in distributed training
                        only). The base option should be `stage1`, `stage2` or `stage3` and you can add
                        CPU-offload to `stage2` or `stage3` like this: `stage2 offload` or `stage3 offload`.
                        Each stage means:
                            stage1 : optimizer state segmentation
                            stage2 : optimizer state + gradient segmentation
                            stage3 : parameter + gradient + optimizer state segmentation
                            offloadoffload parameters to cpu
                        NOTICEstage3 is temporarily unavaliable.

  --sharding_degree
                        设置sharding的通信组参数表示通信组的大小同一个sharding通信组内的参数进行sharding分布到不同卡上不同sharding通信组之间相当于单纯的数据并行此选项只在sharding选项开启时候生效默认值为-1表示所有训练的卡在同一个通信组内。
                        (`int`, 可选, 默认为 `-1`)

                        Sharding parameter in certain cards group. For example, aussume we use 2 machines each
                        with 8 cards, then set sharding_degree=8, sharding will only communication inside machine.
                        default -1 means sharding parameters between all workers. (`int`, *optional*, defaults to `-1`)

  --recompute
                        是否使用重计算训练可以节省显存重新计算前向过程以获取梯度减少中间变量显存.
                        需要组网支持 recompute默认使用 enable_recompute 关键字作为recompute功能开关。
                        (`bool`, 可选, 默认为 `False`)

                        Recompute the forward pass to calculate gradients. Used for saving memory (default: False)

  --minimum_eval_times
                        最少评估次数如果当前设置的eval_steps评估次数少于minimum_eval_times此选项会覆盖eval_steps参数。
                        (`int`可选默认为 NoneIf under eval_steps, the valid time is less then
                        minimum_eval_times, the config of override eval_steps.
                        (default: None)

  --local_rank
                        分布式训练时设备的本地rank值For distributed training: local_rank (default: -1)

  --dataloader_drop_last
                        是否丢弃最后一个不完整的批次如果数据集的长度不能被批次大小整除)
                        (`bool`可选默认为 FalseDrop the last incomplete batch if it is not divisible
                        by the batch size. (default: False)

  --eval_steps
                        如果 `evaluation_strategy="steps"`则两次评估之间的更新步骤数将默认为相同如果未设置则值为 `logging_steps`。
                        (`int`可选默认为 NoneRun an evaluation every X steps. (default: None)

  --dataloader_num_workers
                        用于数据加载的子进程数0 表示数据将在主进程制造。
                        (`int`可选默认为 0Number of subprocesses to use for data loading. 0 means
                        that the data will be loaded in the main process. (default: 0)

  --past_index
                        If >=0, uses the corresponding part of the output as
                        the past state for next step. (default: -1)

  --run_name
                        An optional descriptor for the run. (default: None)
  --device
                        运行的设备名称支持cpu/gpu, 默认gpu`str`可选默认为 'gpu'select cpu, gpu, xpu devices. (default: gpu)

  --disable_tqdm
                        是否使用tqdm进度条
                        Whether or not to disable the tqdm progress bars.
                        (default: None)

  --remove_unused_columns
                        去除Dataset中不用的字段数据
                        Remove columns not required by the model when using an
                        nlp.Dataset. (default: True)

  --label_names
                        训练数据标签label的名称
                        The list of keys in your dictionary of inputs that
                        correspond to the labels. (default: None)

  --load_best_model_at_end
                        训练结束后是否加载最优模型通常与`metric_for_best_model`配合使用
                        Whether or not to load the best model found during
                        training at the end of training. (default: False)

  --metric_for_best_model
                        最优模型指标`eval_accuarcy`用于比较模型好坏The metric to use to compare two different models.
                        (default: None)

  --greater_is_better
                        `metric_for_best_model`配合使用Whether the `metric_for_best_model` should be
                        maximized or not. (default: None)

  --ignore_data_skip
                        重启训练时候不略过已经训练的数据When resuming training, whether or not to skip the
                        first epochs and batches to get to the same training
                        data. (default: False)

  --optim
                        优化器名称默认为adamw,(`str`, 可选默认为 `adamw`)
                        The optimizer to use. (default: adamw)

  --report_to
                        日志可视化显示默认使用visualdl可视化展示。(可选默认为 None展示所有)
                        The list of integrations to report the results and
                        logs to. (default: None)

  --resume_from_checkpoint
                        是否从断点重启恢复训练,(可选默认为 None)
                        The path to a folder with a valid checkpoint for your
                        model. (default: None)

  --skip_memory_metrics
                       是否跳过内存profiler检测。(可选默认为True跳过Whether or not to skip adding of memory profiler reports
                       to metrics.(default:True)

  --flatten_param_grads
                       是否在优化器中使用flatten_param_grads策略该策略将素有参数摊平后输入Optimizer更新目前该策略仅在NPU设备上生效。(可选默认为FalseWhether use flatten_param_grads method in optimizer,
                       only used on NPU devices.(default:False)