Skip to content

PPO训练‐基于一个基模型

Joyce94 edited this page Aug 26, 2023 · 3 revisions

训练

进入script/ppo目录

选择一个lora适配器

运行bash run_ppo_co.sh进行训练 run_ppo_co.sh内容如下


sft_model_path=chinese_alpaca_path
reward_lora_path=rm_lora_path
peft_path=output_dir_rlhf
dataset_dir=/root/LLM-RLHF-Tuning/sft_data
extra_dataset_dir=/root/LLaMA-Tuning/pt_data
lora_trainable="q_proj,v_proj,k_proj,o_proj,gate_proj,down_proj,up_proj"    
output_dir=output_dir_rlhf


accelerate launch --config_file default_config.yaml run_ppo_with_peft.py \
    --model_type llama \
    --template "chinese_llama2_alpaca" \
    --use_co_model True \
    --sft_model_path ${sft_model_path} \
    --reward_lora_path ${reward_lora_path} \
    --dataset_dir ${dataset_dir} \
    --extra_dataset_dir ${extra_dataset_dir} \
    --per_device_train_batch_size 1 \
    --per_device_mini_train_batch_size 1 \
    --gradient_accumulation_steps 8 \
    --do_train \
    --num_train_epochs 1 \
    --seed 512 \
    --lr_scheduler_type cosine \
    --learning_rate 1e-4 \
    --weight_decay 0 \
    --logging_steps 10 \
    --save_steps 10 \
    --dataloader_num_workers 16 \
    --block_size 256 \
    --max_prompt_length 256 \
    --max_response_length 256 \
    --output_dir ${output_dir} \
    --lora_rank 64 \
    --lora_alpha 32 \
    --lora_target ${lora_trainable} \
    --lora_dropout 0.05 \
    --ppo_epochs 1 \
    --gamma 1 \
    --lam 0.95 \
    --kl_penalty_beta 0.02 \
    --kl_penalty_method "abs" \
    --value_clip 0.2 \
    --ratio_clip 0.2 \
    --actor_loss_weight 1 \
    --critic_loss_weight 1 \
    --extra_loss_weight 0.2 \
    --extra_warmup_steps_ratio 0.2 \
    --entropy_beta 1.0 \
    --use_advantage_norm \
    --report_to "wandb" \
    --torch_dtype float16 \
    --fp16
选择两个lora适配器

运行bash run_ppo_co_multi_adapters.sh进行训练 run_ppo_co_multi_adapters.sh内容如下

sft_model_path=chinese_alpaca_path
reward_lora_path=rm_lora_path
actor_peft_path=output_dir_rlhf_actor
critic_peft_path=output_dir_rlhf_critic

dataset_dir=/root/LLM-RLHF-Tuning/sft_data
extra_dataset_dir=/root/LLM-RLHF-Tuning/pt_data
actor_lora_trainable="q_proj,v_proj,k_proj,o_proj,gate_proj,down_proj,up_proj"    
critic_lora_trainable="q_proj,v_proj,k_proj,o_proj,gate_proj,down_proj,up_proj"   

actor_output_dir=output_dir_rlhf_actor_multi
critic_output_dir=output_dir_rlhf_critic_multi

accelerate launch --config_file default_config.yaml run_ppo_with_peft.py \
    --model_type llama \
    --template "chinese_llama2_alpaca" \
    --use_co_model True \
    --use_multi_adapters True \
    --sft_model_path ${sft_model_path} \
    --reward_lora_path ${reward_lora_path} \
    --dataset_dir ${dataset_dir} \
    --extra_dataset_dir ${extra_dataset_dir} \
    --per_device_train_batch_size 1 \
    --per_device_mini_train_batch_size 1 \
    --gradient_accumulation_steps 8 \
    --do_train \
    --num_train_epochs 1 \
    --seed 512 \
    --lr_scheduler_type cosine \
    --learning_rate 1e-4 \
    --weight_decay 0 \
    --logging_steps 1 \
    --save_steps 1 \
    --dataloader_num_workers 16 \
    --block_size 256 \
    --max_prompt_length 256 \
    --max_response_length 256 \
    --output_dir ${actor_output_dir} \
    --critic_output_dir ${critic_output_dir} \
    --lora_rank 64 \
    --lora_alpha 32 \
    --lora_target ${actor_lora_trainable} \
    --lora_dropout 0.05 \
    --critic_lora_rank 64 \
    --critic_lora_alpha 32 \
    --critic_lora_target ${critic_lora_trainable} \
    --critic_lora_dropout 0.05 \
    --ppo_epochs 1 \
    --gamma 1 \
    --lam 0.95 \
    --kl_penalty_beta 0.02 \
    --kl_penalty_method "abs" \
    --value_clip 0.2 \
    --ratio_clip 0.2 \
    --actor_loss_weight 1 \
    --critic_loss_weight 1 \
    --extra_loss_weight 0.2 \
    --extra_warmup_steps_ratio 0.2 \
    --entropy_beta 1.0 \
    --use_advantage_norm \
    --report_to "wandb" \
    --torch_dtype float16 \
    --fp16

参数介绍

  • --model_type: 选择base模型类型,目前只支持llama
  • --template: 选择模型相对应的提示词
  • --use_co_model: 是否只使用一个基模型
  • --use_multi_adapters: 是否使用多个适配器
  • --sft_model_path: sft指令微调合并后的模型地址
  • --reward_lora_path: 训练的奖励模型的lora模型地址
  • --actor_loss_weight: actor模型的loss权重
  • --critic_loss_weight: critic模型的loss权重
  • --extra_loss_weight: pretrain loss权重
  • --entropy_beta: entropy loss权重
  • --extra_warmup_steps_ratio: 对pretrain loss权重系数使用warmup策略

分布式训练

通过accelerate config命令配置

组合deepspeed

ds_config.yaml示例

compute_environment: LOCAL_MACHINE
deepspeed_config:
  gradient_accumulation_steps: 8
  gradient_clipping: 1.0
  offload_optimizer_device: none
  offload_param_device: none
  zero3_init_flag: true
  zero_stage: 2
distributed_type: DEEPSPEED
downcast_bf16: 'no'
machine_rank: 0
main_training_function: main
mixed_precision: fp16
num_machines: 1
num_processes: 2
rdzv_backend: static
same_network: true
tpu_env: []
tpu_use_cluster: false
tpu_use_sudo: false
use_cpu: false

不使用deepspeed

default_config.yaml示例

compute_environment: LOCAL_MACHINE
distributed_type: MULTI_GPU
downcast_bf16: 'no'
gpu_ids: all
machine_rank: 0
main_process_ip: null 
main_process_port: null
main_training_function: main
mixed_precision: 'fp16'
num_machines: 1
num_processes: 2
rdzv_backend: static
same_network: true
tpu_env: []
tpu_use_cluster: false
tpu_use_sudo: false
use_cpu: false