|
| 1 | +#!/usr/bin/env bash |
| 2 | + |
| 3 | +set -xeuo pipefail |
| 4 | + |
| 5 | +project_name='DAPO' |
| 6 | +exp_name='DAPO-mimo-7b-rl-megatron' |
| 7 | + |
| 8 | +adv_estimator=grpo |
| 9 | + |
| 10 | +use_kl_in_reward=False |
| 11 | +kl_coef=0.0 |
| 12 | +use_kl_loss=False |
| 13 | +kl_loss_coef=0.0 |
| 14 | + |
| 15 | +clip_ratio_low=0.2 |
| 16 | +clip_ratio_high=0.28 |
| 17 | + |
| 18 | +max_prompt_length=$((1024 * 2)) |
| 19 | +max_response_length=$((1024 * 8)) |
| 20 | +enable_overlong_buffer=True |
| 21 | +overlong_buffer_len=$((1024 * 4)) |
| 22 | +overlong_penalty_factor=1.0 |
| 23 | + |
| 24 | +loss_agg_mode="token-mean" |
| 25 | + |
| 26 | +train_prompt_bsz=128 |
| 27 | +n_resp_per_prompt=16 |
| 28 | +train_prompt_mini_bsz=32 |
| 29 | + |
| 30 | +# Ray |
| 31 | +# RAY_ADDRESS=${RAY_ADDRESS:-"http://localhost:8265"} |
| 32 | +# WORKING_DIR=${WORKING_DIR:-"${PWD}"} |
| 33 | +# RUNTIME_ENV=${RUNTIME_ENV:-"${WORKING_DIR}/examples/mtp_trainer/runtime_env.yaml"} |
| 34 | +NNODES=${NNODES:-16} |
| 35 | +NGPUS_PER_NODE=${NGPUS_PER_NODE:-8} |
| 36 | +# Paths |
| 37 | +RAY_DATA_HOME=${RAY_DATA_HOME:-"${HOME}/verl"} |
| 38 | +# very important! please modify the max_position_embeddings in config.json to 32768 after downloading from huggingface |
| 39 | +MODEL_PATH=${MODEL_PATH:-"${RAY_DATA_HOME}/models/MiMo-7B-RL"} |
| 40 | +CKPTS_DIR=${CKPTS_DIR:-"${RAY_DATA_HOME}/ckpts/${project_name}/${exp_name}"} |
| 41 | +TRAIN_FILE=${TRAIN_FILE:-"${RAY_DATA_HOME}/data/dapo-math-17k.parquet"} |
| 42 | +TEST_FILE=${TEST_FILE:-"${RAY_DATA_HOME}/data/aime-2024.parquet"} |
| 43 | + |
| 44 | +# Algorithm |
| 45 | +temperature=1.0 |
| 46 | +top_p=1.0 |
| 47 | +top_k=-1 # 0 for HF rollout, -1 for vLLM rollout |
| 48 | +val_top_p=0.7 |
| 49 | + |
| 50 | +# Performance Related Parameter |
| 51 | +use_dynamic_bsz=True |
| 52 | +actor_ppo_max_token_len=$(((max_prompt_length + max_response_length) * 2)) |
| 53 | +infer_ppo_max_token_len=$(((max_prompt_length + max_response_length) * 3)) |
| 54 | +offload=True |
| 55 | +gen_tp=4 |
| 56 | +train_tp=2 |
| 57 | +train_pp=2 |
| 58 | +train_cp=2 |
| 59 | + |
| 60 | +common_params=( |
| 61 | +actor_rollout_ref.model.mtp.enable=True |
| 62 | +actor_rollout_ref.model.mtp.enable_train=True |
| 63 | +actor_rollout_ref.model.mtp.mtp_loss_scaling_factor=0.1 |
| 64 | +actor_rollout_ref.model.mtp.detach_encoder=True |
| 65 | +) |
| 66 | + |
| 67 | +python -m verl.trainer.main_ppo \ |
| 68 | + --config-path=config \ |
| 69 | + --config-name='ppo_megatron_trainer.yaml' \ |
| 70 | + data.train_files="${TRAIN_FILE}" \ |
| 71 | + data.val_files="${TEST_FILE}" \ |
| 72 | + data.prompt_key=prompt \ |
| 73 | + data.truncation='left' \ |
| 74 | + data.max_prompt_length=${max_prompt_length} \ |
| 75 | + data.max_response_length=${max_response_length} \ |
| 76 | + data.train_batch_size=${train_prompt_bsz} \ |
| 77 | + actor_rollout_ref.rollout.n=${n_resp_per_prompt} \ |
| 78 | + algorithm.adv_estimator=${adv_estimator} \ |
| 79 | + algorithm.use_kl_in_reward=${use_kl_in_reward} \ |
| 80 | + algorithm.kl_ctrl.kl_coef=${kl_coef} \ |
| 81 | + actor_rollout_ref.actor.use_kl_loss=${use_kl_loss} \ |
| 82 | + actor_rollout_ref.actor.kl_loss_coef=${kl_loss_coef} \ |
| 83 | + actor_rollout_ref.actor.clip_ratio_low=${clip_ratio_low} \ |
| 84 | + actor_rollout_ref.actor.clip_ratio_high=${clip_ratio_high} \ |
| 85 | + actor_rollout_ref.actor.clip_ratio_c=10.0 \ |
| 86 | + actor_rollout_ref.actor.ppo_micro_batch_size_per_gpu=2 \ |
| 87 | + actor_rollout_ref.ref.log_prob_micro_batch_size_per_gpu=4 \ |
| 88 | + actor_rollout_ref.rollout.log_prob_micro_batch_size_per_gpu=4 \ |
| 89 | + actor_rollout_ref.model.path="${MODEL_PATH}" \ |
| 90 | + actor_rollout_ref.actor.optim.lr=1e-6 \ |
| 91 | + actor_rollout_ref.actor.optim.lr_warmup_steps=10 \ |
| 92 | + actor_rollout_ref.actor.optim.weight_decay=0.1 \ |
| 93 | + actor_rollout_ref.actor.ppo_mini_batch_size=${train_prompt_mini_bsz} \ |
| 94 | + actor_rollout_ref.actor.megatron.param_offload=${offload} \ |
| 95 | + actor_rollout_ref.actor.megatron.optimizer_offload=${offload} \ |
| 96 | + actor_rollout_ref.actor.megatron.grad_offload=${offload} \ |
| 97 | + actor_rollout_ref.actor.megatron.pipeline_model_parallel_size=${train_pp} \ |
| 98 | + actor_rollout_ref.actor.megatron.tensor_model_parallel_size=${train_tp} \ |
| 99 | + actor_rollout_ref.actor.megatron.context_parallel_size=${train_cp} \ |
| 100 | + actor_rollout_ref.actor.entropy_coeff=0 \ |
| 101 | + actor_rollout_ref.actor.optim.clip_grad=1.0 \ |
| 102 | + actor_rollout_ref.actor.loss_agg_mode=${loss_agg_mode} \ |
| 103 | + actor_rollout_ref.rollout.gpu_memory_utilization=0.80 \ |
| 104 | + actor_rollout_ref.rollout.tensor_model_parallel_size=${gen_tp} \ |
| 105 | + actor_rollout_ref.rollout.enable_chunked_prefill=True \ |
| 106 | + actor_rollout_ref.rollout.max_num_batched_tokens=$((max_prompt_length + max_response_length)) \ |
| 107 | + actor_rollout_ref.rollout.temperature=${temperature} \ |
| 108 | + actor_rollout_ref.rollout.top_p=${top_p} \ |
| 109 | + actor_rollout_ref.rollout.top_k=${top_k} \ |
| 110 | + actor_rollout_ref.rollout.val_kwargs.temperature=${temperature} \ |
| 111 | + actor_rollout_ref.rollout.val_kwargs.top_p=${val_top_p} \ |
| 112 | + actor_rollout_ref.rollout.val_kwargs.top_k=${top_k} \ |
| 113 | + actor_rollout_ref.rollout.val_kwargs.do_sample=True \ |
| 114 | + actor_rollout_ref.rollout.val_kwargs.n=1 \ |
| 115 | + actor_rollout_ref.rollout.name=sglang \ |
| 116 | + actor_rollout_ref.ref.megatron.pipeline_model_parallel_size=${train_pp} \ |
| 117 | + actor_rollout_ref.ref.megatron.tensor_model_parallel_size=${train_tp} \ |
| 118 | + actor_rollout_ref.ref.megatron.context_parallel_size=${train_cp} \ |
| 119 | + actor_rollout_ref.ref.megatron.param_offload=${offload} \ |
| 120 | + reward_model.reward_manager=dapo \ |
| 121 | + +reward_model.reward_kwargs.overlong_buffer_cfg.enable=${enable_overlong_buffer} \ |
| 122 | + +reward_model.reward_kwargs.overlong_buffer_cfg.len=${overlong_buffer_len} \ |
| 123 | + +reward_model.reward_kwargs.overlong_buffer_cfg.penalty_factor=${overlong_penalty_factor} \ |
| 124 | + +reward_model.reward_kwargs.overlong_buffer_cfg.log=False \ |
| 125 | + +reward_model.reward_kwargs.max_resp_len=${max_response_length} \ |
| 126 | + trainer.logger='["console","tensorboard"]' \ |
| 127 | + trainer.project_name="${project_name}" \ |
| 128 | + trainer.experiment_name="${exp_name}" \ |
| 129 | + trainer.n_gpus_per_node="${NGPUS_PER_NODE}" \ |
| 130 | + trainer.nnodes="${NNODES}" \ |
| 131 | + trainer.val_before_train=False \ |
| 132 | + trainer.test_freq=10 \ |
| 133 | + trainer.save_freq=-1 \ |
| 134 | + trainer.total_epochs=10 \ |
| 135 | + trainer.resume_mode=auto \ |
| 136 | + trainer.log_val_generations=10 \ |
| 137 | + actor_rollout_ref.rollout.disable_log_stats=False \ |
| 138 | + actor_rollout_ref.rollout.prometheus.enable=True \ |
| 139 | + actor_rollout_ref.rollout.prometheus.port=44398 \ |
| 140 | + actor_rollout_ref.model.trust_remote_code=True \ |
| 141 | + data.trust_remote_code=True \ |
| 142 | + trainer.total_training_steps=400 \ |
| 143 | + actor_rollout_ref.actor.megatron.use_mbridge=True \ |
| 144 | + "${common_params[@]}" |
0 commit comments