data:
  tokenizer: null
  train_files: ~/data/rlhf/gsm8k/train.parquet
  val_files_testN: ~/data/rlhf/gsm8k/test.parquet
  val_files_testonce: ~/data/rlhf/gsm8k/test.parquet
  prompt_key: prompt
  max_prompt_length: 512
  max_response_length: 512
  train_batch_size: 1024
  val_batch_size: 1312
  return_raw_input_ids: False
  return_raw_chat: False
  granulor:
    enable: False
    alpha: 0.6
    beta: 0.3
  selfrl_tr:
    enable: False
    target_update_lr: 0.1
    alpha: 1.0
    beta: 0.0
    w_variance: 1.0
    consistency_lr_weight: 1.0
    ema_decay: 0.9
    initial_target_difficulty: 0.5
    difficulty_file_path: ''
  gainrl:
    enable: False
    n: 500
    beta: 0.5
    alpha: 2
    adj_max: 1000
    adj_min: 0
    processed_file: ~/processed_data/processed_gsm8k.pt
  save_dir: ''

actor_rollout_ref:
  hybrid_engine: True
  model:
    path: ~/models/deepseek-llm-7b-chat
    eval_path: None
    eval_store_path: None
    external_lib: null
    override_config: { }
    enable_gradient_checkpointing: False
    use_remove_padding: False
  actor:
    algorithm_name: 'grpo'
    beta: 0.01
    positive_scale: 1.0
    negative_scale: 1.0
    scale_method: ''
    beta_method: ''
    beta_start: 0.01
    beta_end: 0.1
    enable_confidence_loss: False
    confidence_target_source: "reward"
    confidence_loss_type: "bce"
    lambda_confidence: 1.0
    confidence_reward_scale_factor: 1.0
    output_dir_of_record: "training_logs/reward_data_bce"
    strategy: fsdp
    ppo_mini_batch_size: 256
    ppo_micro_batch_size: 64
    use_dynamic_bsz: False
    ppo_max_token_len_per_gpu: 16384
    grad_clip: 1.0
    clip_ratio: 0.2
    clip_ratio_low: 0.2
    clip_ratio_high: 0.2
    clip_ratio_c: 3.0
    loss_agg_mode: "token-mean"
    entropy_coeff: 0.0
    use_kl_loss: False
    kl_loss_coef: 0.001
    kl_loss_type: kl
    ppo_epochs: 1
    shuffle: False
    ulysses_sequence_parallel_size: 1
    importance_sampling: "on"
    checkpoint:
      contents: ['model', 'hf_model', 'optimizer', 'extra']
    optim:
      lr: 1e-6
      lr_warmup_steps_ratio: 0.
      min_lr_ratio: null
      warmup_style: constant
      total_training_steps: -1
      type: adamw
    fsdp_config:
      wrap_policy:

        min_num_params: 0
      param_offload: False
      grad_offload: False
      optimizer_offload: False
      fsdp_size: -1
  ref:
    fsdp_config:
      param_offload: False
      wrap_policy:

        min_num_params: 0
      fsdp_size: -1
    log_prob_micro_batch_size: 128
    log_prob_use_dynamic_bsz: ${actor_rollout_ref.actor.use_dynamic_bsz}
    log_prob_max_token_len_per_gpu: ${actor_rollout_ref.actor.ppo_max_token_len_per_gpu}
    ulysses_sequence_parallel_size: ${actor_rollout_ref.actor.ulysses_sequence_parallel_size}
  rollout:
    name: vllm
    temperature: 1.0
    top_k: -1
    top_p: 1
    prompt_length: ${data.max_prompt_length}
    response_length: ${data.max_response_length}

    dtype: bfloat16
    gpu_memory_utilization: 0.5
    ignore_eos: False
    enforce_eager: True
    free_cache_engine: True
    load_format: dummy_dtensor
    tensor_model_parallel_size: 2
    max_num_batched_tokens: 8192
    max_num_seqs: 1024
    log_prob_micro_batch_size: 128
    log_prob_use_dynamic_bsz: ${actor_rollout_ref.actor.use_dynamic_bsz}
    log_prob_max_token_len_per_gpu: ${actor_rollout_ref.actor.ppo_max_token_len_per_gpu}

    do_sample: True

    n: 1
    n_val: 1

critic:
  strategy: fsdp
  optim:
    lr: 1e-5
    lr_warmup_steps_ratio: 0.
    min_lr_ratio: null
    warmup_style: constant
    total_training_steps: -1
  model:
    path: ~/models/deepseek-llm-7b-chat
    tokenizer_path: ${actor_rollout_ref.model.path}
    override_config: { }
    external_lib: ${actor_rollout_ref.model.external_lib}
    enable_gradient_checkpointing: False
    use_remove_padding: False
    fsdp_config:
      param_offload: False
      grad_offload: False
      optimizer_offload: False
      wrap_policy:

        min_num_params: 0
      fsdp_size: -1
  ppo_mini_batch_size: ${actor_rollout_ref.actor.ppo_mini_batch_size}
  ppo_micro_batch_size: 64
  forward_micro_batch_size: ${critic.ppo_micro_batch_size}
  use_dynamic_bsz: ${actor_rollout_ref.actor.use_dynamic_bsz}
  ppo_max_token_len_per_gpu: 32768
  forward_max_token_len_per_gpu: ${critic.ppo_max_token_len_per_gpu}
  ulysses_sequence_parallel_size: 1
  ppo_epochs: ${actor_rollout_ref.actor.ppo_epochs}
  shuffle: ${actor_rollout_ref.actor.shuffle}
  grad_clip: 1.0
  cliprange_value: 0.5

reward_model:
  enable: False
  strategy: fsdp
  model:
    input_tokenizer: ${actor_rollout_ref.model.path}
    path: ~/models/FsfairX-LLaMA3-RM-v0.1
    external_lib: ${actor_rollout_ref.model.external_lib}
    use_remove_padding: False
    fsdp_config:
      min_num_params: 0
      param_offload: False
  micro_batch_size: 64
  max_length: null
  ulysses_sequence_parallel_size: 1
  use_dynamic_bsz: ${critic.use_dynamic_bsz}
  forward_max_token_len_per_gpu: ${critic.forward_max_token_len_per_gpu}

algorithm:
  gamma: 1.0
  lam: 1.0
  adv_estimator: gae
  kl_penalty: kl
  kl_ctrl:
    type: fixed
    kl_coef: 0.001
  plot_dist: False
  plot_fig_type: "prob_stat"
  samples_retemp: False
  retemp_method: "prob_threshold"
  reject_samples_retemp_value: 1.1
  chosen_samples_retemp_value: 0.9
  prob_threshold: 0.9
  above_threshold_retemp_value: 1.1
  below_threshold_retemp_value: 0.9
  samples_reweight: False
  reweight_method: "negative_sigmoid"
  reweight_k: 5.0
  reweight_tau: 0.4
  neg_adv_weight: 0.8
  seperate_updating: False
  seperate_prob: 0.5
  seperate_portion: 0.5
  use_kl_in_reward: False

trainer:
  total_epochs: 30
  total_training_steps: null
  project_name: verl_examples
  experiment_name: gsm8k
  logger: [ 'console', 'wandb' ]
  nnodes: 1
  n_gpus_per_node: 8
  save_freq: -1
  test_freq: -1
  math_test_freq: -1
  total_steps: -1
  critic_warmup: 0
  default_hdfs_dir: ~/experiments/gsm8k/ppo/${trainer.experiment_name}
  default_local_dir: checkpoints/${trainer.project_name}/${trainer.experiment_name}
  resume_mode: auto
  del_local_ckpt_after_load: False
  remove_previous_ckpt_in_save: False
  val_before_train: True
