data:
  tokenizer: null
  use_shm: False
  train_files: ~/data/rlhf/gsm8k/train.parquet
  val_files: ~/data/rlhf/gsm8k/test.parquet
  prompt_key: prompt
  reward_fn_key: data_source
  max_prompt_length: 512
  max_response_length: 512
  train_batch_size: 1024
  gen_batch_size: null  # Generation batch size for DAPO (typically 3x train_batch_size)
  val_batch_size: null
  return_raw_input_ids: False  # This should be set to true when the tokenizer between policy and rm differs
  return_raw_chat: False
  return_full_prompt: False
  shuffle: True
  filter_overlong_prompts: False # for large-scale dataset, filtering overlong prompts could be timeconsuming. You cat set the filter_overlong_prompts_workers to use multiprocessing to speed up.
  filter_overlong_prompts_workers: 1
  truncation: error
  image_key: images
  video_key: videos
  auto_repeat: False
  trust_remote_code: False  # main_ppo will check this config to determine whether to use remote code for tokenizer
  num_loader_workers: 8
  force_on_the_fly: False  # If True, the data will be loaded on-the-fly, which is useful for large datasets that cannot fit into memory.
  processor:
    image_max_pixels: 589824 # 768 * 768
    image_min_pixels: 1024 # 32 * 32
    video_max_pixels: 65536 # 256 * 256
    video_min_pixels: 256 # 16 * 16
    video_fps: 2.0
    video_maxlen: 128
  custom_cls:
      path: null
      name: null

actor_rollout_ref:
  hybrid_engine: True
  model:
    path: ~/models/deepseek-llm-7b-chat
    use_shm: False
    external_lib: null
    override_config: { }
    enable_gradient_checkpointing: True
    enable_activation_offload: False
    use_remove_padding: False
    lora_rank: 0  # Set to positive value to enable LoRA (e.g., 32)
    lora_alpha: 16  # LoRA scaling factor
    target_modules: all-linear  # all-linear or [q_proj,k_proj,v_proj,o_proj,gate_proj,up_proj,down_proj]
    use_liger: False
    use_fused_kernels: False
    trust_remote_code: False
  actor:
    strategy: fsdp  # [fsdp, fsdp2], This is for backward-compatibility
    ppo_mini_batch_size: 256
    ppo_micro_batch_size: null # will be deprecated, use ppo_micro_batch_size_per_gpu
    ppo_micro_batch_size_per_gpu: null
    use_dynamic_bsz: False
    ppo_max_token_len_per_gpu: 16384 # n * ${data.max_prompt_length} + ${data.max_response_length}
    grad_clip: 1.0
    # pg_losses2 = -advantages * torch.clamp(ratio, 1 - cliprange_low, 1 + cliprange_high)
    clip_ratio: 0.2 # default value if clip_ratio_low and clip_ratio_high are not specified
    clip_ratio_low: 0.2
    clip_ratio_high: 0.2
    clip_ratio_c: 3.0 # lower bound of the value for Dual-clip PPO from https://arxiv.org/pdf/1912.09729
    loss_agg_mode: "token-mean" # / "seq-mean-token-sum" / "seq-mean-token-mean"
    entropy_coeff: 0
    use_kl_loss: False # True for GRPO
    use_torch_compile: True # False to disable torch compile
    kl_loss_coef: 0.001 # for grpo
    kl_loss_type: low_var_kl # for grpo
    use_cpgd_loss: False # for CPGD
    policy_drift_coeff: 0.0 # for CPGD
    ppo_epochs: 1
    shuffle: False
    ulysses_sequence_parallel_size: 1 # sp size
    policy_loss:
      loss_mode: vanilla
    use_fused_kernels: ${actor_rollout_ref.model.use_fused_kernels}
    checkpoint:
      contents: ['model', 'optimizer', 'extra']  # with 'hf_model' you can save whole model as hf format, now only use sharded model checkpoint to save space
      save_contents: ['model', 'optimizer', 'extra']
      load_contents: ['model', 'optimizer', 'extra']
      async_save: False
    optim:
      lr: 1e-6
      lr_warmup_init: 0.0
      lr_warmup_steps: -1 # Prioritized. Negative values mean delegating to lr_warmup_steps_ratio.
      lr_warmup_steps_ratio: 0.  # the total steps will be injected during runtime
      min_lr_ratio: 0.0   # only used with cosine lr scheduler, default to 0.0
      min_lr: 0.0
      lr_decay_steps: null
      lr_decay_style: linear
      weight_decay_incr_style: constant
      lr_wsd_decay_style: exponential
      lr_wsd_decay_steps: null
      use_checkpoint_opt_param_scheduler: False
      num_cycles: 0.5     # only used with cosine lr scheduler, default to 0.5
      warmup_style: constant  # select from constant/cosine
      total_training_steps: -1  # must be override by program
      weight_decay: 0.01
    fsdp_config:
      wrap_policy:
        # transformer_layer_cls_to_wrap: None
        min_num_params: 0
      param_offload: False
      optimizer_offload: False
      offload_policy: False # only for fsdp2, offload param\grad\optimizer during train
      reshard_after_forward: True # only for fsdp2, [True, False, int between 1 and fsdp_size]
      fsdp_size: -1
    # Megatron-specific configuration
    megatron:  # Only used when strategy is megatron
      tensor_model_parallel_size: 2  # Tensor parallelism across GPUs
      pipeline_model_parallel_size: 2  # Pipeline parallelism across stages
      virtual_pipeline_model_parallel_size: null  # Optional: virtual pipeline stages
      sequence_parallel: True  # Enable Megatron's sequence parallelism
      use_distributed_optimizer: True  # Use Megatron's distributed optimizer (ZeRO-1 style)
      param_dtype: "bfloat16"  # Parameter data type
      seed: 1  # Random seed for reproducibility
      context_parallel_size: 1  # Context parallelism (for very long sequences)
      expert_model_parallel_size: 1  # Expert parallelism for MoE models
      expert_tensor_parallel_size: 1  # Expert tensor parallelism for MoE models
      param_offload: False  # Offload parameters to CPU
      grad_offload: False   # Offload gradients to CPU
      optimizer_offload: False  # Offload optimizer states to CPU
      override_transformer_config: {}
      override_ddp_config: {}
      use_dist_checkpointing: False
      dist_checkpointing_path: ""
      use_mbridge: False
  ref:
    strategy: fsdp  # [fsdp, megatron]
    fsdp_config:
      param_offload: False
      reshard_after_forward: True # only for fsdp2, [True, False, int between 1 and fsdp_size]
      wrap_policy:
        # transformer_layer_cls_to_wrap: None
        min_num_params: 0
    use_torch_compile: ${actor_rollout_ref.actor.use_torch_compile}
    use_remove_padding: ${actor_rollout_ref.model.use_remove_padding}
    log_prob_micro_batch_size: null # will be deprecated, use log_prob_micro_batch_size_per_gpu
    log_prob_micro_batch_size_per_gpu: null
    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} # sp size
    use_fused_kernels: ${actor_rollout_ref.model.use_fused_kernels}
    # Megatron-specific configuration
    megatron:  # Only used when strategy is megatron
      tensor_model_parallel_size: 2  # Reference's tensor parallelism
      pipeline_model_parallel_size: 2
      virtual_pipeline_model_parallel_size: null
      sequence_parallel: True
      use_distributed_optimizer: False  # Reference doesn't need optimizer
      use_dist_checkpointing: False
      dist_checkpointing_path: ""
      param_dtype: "bfloat16"
      seed: 1
      context_parallel_size: 1
      expert_model_parallel_size: 1
      expert_tensor_parallel_size: 1
      param_offload: False
      override_transformer_config: ${actor_rollout_ref.actor.megatron.override_transformer_config}
      use_mbridge: ${actor_rollout_ref.actor.megatron.use_mbridge}
  rollout:
    name: vllm
    mode: sync # sync: LLM, async: AsyncLLM
    chat_scheduler: null # async chat scheduler, e.g examples.ppo_trainer.naive_chat_scheduler.NaiveChatCompletionScheduler
    temperature: 1.0
    top_k: -1 # 0 for hf rollout, -1 for vllm rollout
    top_p: 1
    use_fire_sampling: False # https://arxiv.org/abs/2410.21236
    prompt_length: ${data.max_prompt_length}  # not use for opensource
    response_length: ${data.max_response_length}
    trust_remote_code: True
    # for vllm rollout
    dtype: bfloat16 # should align with FSDP
    gpu_memory_utilization: 0.5
    ignore_eos: False
    enforce_eager: True
    free_cache_engine: True
    load_format: dummy_dtensor  # safetensors (for huge model, and set use_shm=True); dummy_dtensor: randomly init model weight
    layered_summon: False # for huge model, layered summon can save memory (prevent OOM) but make it slower
    tensor_model_parallel_size: 2
    max_num_batched_tokens: 8192
    max_model_len: null
    max_num_seqs: 1024
    log_prob_micro_batch_size: null # will be deprecated, use log_prob_micro_batch_size_per_gpu
    log_prob_micro_batch_size_per_gpu: null
    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}
    disable_log_stats: True
    enable_chunked_prefill: True # may get higher throughput when set to True. When activated, Please increase max_num_batched_tokens or decrease max_model_len.
    # for hf rollout
    do_sample: True
    # number of responses (i.e. num sample times)
    n: 1 # > 1 for grpo
    calculate_log_probs: False # support logging rollout prob for debugging purpose
    multi_stage_wake_up: False #
    engine_kwargs: # inference engine parameters
      vllm:
        swap_space: null # null means "use the engine default value" (usually 4 GB), setting it to, e.g., 32 means 32 GB
        disable_mm_preprocessor_cache: null
      sglang:
        attention_backend: null # null means use the engine default value, available options: flashinfer, triton, flashmla
    val_kwargs:
      # sampling parameters for validation
      top_k: -1 # 0 for hf rollout, -1 for vllm rollout
      top_p: 1.0
      temperature: 0
      n: 1
      do_sample: False # default eager for validation
    multi_turn:
      # Set to True for multi-agent generation when trajectories from each round of multi-turn are needed for training.
      use_all_traj: False
      # set to True for multi-turn tool interaction tasks; should set rollout.name to sglang as well
      enable: False
      # null for no limit (default max_length // 3)
      max_assistant_turns: null
      # null for no tool
      tool_config_path: null
      # null for no limit (default max_length // 3)
      max_user_turns: null
      # max parallel call for tools in single turn
      max_parallel_calls: 1
      # max length of tool response
      max_tool_response_length: 256
      # truncate side of tool response: left, middle, right
      tool_response_truncate_side: middle
      # null for no interaction
      interaction_config_path: null
      # null for default callback
      completion_callback: null
      # - When set to True, the model's default chat template is used for multi-turn rollout, which typically matches production behavior.
      # - When set to False, the token ids recorded for training are used instead; unlike the default chat template, these always include the model's full output,
      #   which may contain additional content such as reasoning content. This maintains the consistency between training and rollout, but it will lead to longer prompts.
      use_inference_chat_template: False
      # Tokenization is performed turn by turn and the resulting token ids are concatenated to form the full conversation.
      # To ensure this matches the result of tokenizing the entire conversation at once, a sanity check is run at the end of each multi-turn rollout to compare the two sets of token ids.
      # Some models are known to produce different tokenization results when tokenizing turn by turn vs. all at once. aThis behavior has already been validated for them.
      # To reduce excessive warnings, you can turn off the sanity check for these models if you are using their default chat template:
      # Qwen/QwQ-32B, Qwen/Qwen3-xxB
      # - disable: disable tokenization sanity check
      # - strict: enable strict tokenization sanity check (default)
      # - ignore_strippable: ignore strippable tokens when checking tokenization sanity
      tokenization_sanity_check_mode: strict
      # Format of the multi-turn interaction. Options: hermes, llama3_json, ...
      format: hermes

    agent:
      # Number of agent loop workers
      agent_name: single_turn_agent
      num_workers: 8
      # custom async server configs
      custom_async_server:
        # Path to the custom async server implementation
        path: null
        # Class name of the custom async server class (e.g. AsyncvLLMServer)
        name: null
      rewards_with_env: False

critic:
  rollout_n: ${actor_rollout_ref.rollout.n}
  strategy: fsdp # [fsdp, fsdp2]
  optim:
    lr: 1e-5
    lr_warmup_init: 0.0
    min_lr: 0.0
    lr_decay_steps: null
    lr_decay_style: linear
    weight_decay_incr_style: constant
    lr_wsd_decay_style: exponential
    lr_wsd_decay_steps: null
    use_checkpoint_opt_param_scheduler: False
    lr_warmup_steps_ratio: 0.  # the total steps will be injected during runtime
    min_lr_ratio: null   # only useful for warmup with cosine
    warmup_style: constant  # select from constant/cosine
    total_training_steps: -1  # must be override by program
    weight_decay: 0.01
  model:
    path: ~/models/deepseek-llm-7b-chat
    use_shm: False
    tokenizer_path: ${actor_rollout_ref.model.path}
    override_config: { }
    external_lib: ${actor_rollout_ref.model.external_lib}
    enable_gradient_checkpointing: True
    enable_activation_offload: False
    use_remove_padding: False
    trust_remote_code: ${actor_rollout_ref.model.trust_remote_code}
    fsdp_config:
      param_offload: False
      optimizer_offload: False
      offload_policy: False # only for fsdp2, offload param\grad\optimizer during train
      reshard_after_forward: True # only for fsdp2, [True, False, int between 1 and fsdp_size]
      wrap_policy:
        # transformer_layer_cls_to_wrap: None
        min_num_params: 0
      fsdp_size: -1
    lora_rank: 0  # Set to positive value to enable LoRA (e.g., 32)
    lora_alpha: 16  # LoRA scaling factor
    target_modules: all-linear  # all-linear or [q_proj,k_proj,v_proj,o_proj,gate_proj,up_proj,down_proj]
  ppo_mini_batch_size: ${actor_rollout_ref.actor.ppo_mini_batch_size}
  ppo_micro_batch_size: null # will be deprecated, use ppo_micro_batch_size_per_gpu
  ppo_micro_batch_size_per_gpu: null
  forward_micro_batch_size: ${critic.ppo_micro_batch_size}
  forward_micro_batch_size_per_gpu: ${critic.ppo_micro_batch_size_per_gpu}
  use_dynamic_bsz: ${actor_rollout_ref.actor.use_dynamic_bsz}
  ppo_max_token_len_per_gpu: 32768 # (${actor_rollout_ref.actor.ppo_max_token_len_per_gpu}) * 2
  forward_max_token_len_per_gpu: ${critic.ppo_max_token_len_per_gpu}
  ulysses_sequence_parallel_size: 1 # sp size
  ppo_epochs: ${actor_rollout_ref.actor.ppo_epochs}
  shuffle: ${actor_rollout_ref.actor.shuffle}
  grad_clip: 1.0
  cliprange_value: 0.5
  loss_agg_mode: ${actor_rollout_ref.actor.loss_agg_mode}
  checkpoint:
    contents: ['model', 'optimizer', 'extra']  # with 'hf_model' you can save whole model as hf format, now only use sharded model checkpoint to save space
    save_contents: ['model', 'optimizer', 'extra']
    load_contents: ['model', 'optimizer', 'extra']
    async_save: False
  # Megatron-specific configuration
  megatron:  # Only used when strategy is megatron
    tensor_model_parallel_size: 2  # Critic's tensor parallelism
    pipeline_model_parallel_size: 2
    virtual_pipeline_model_parallel_size: null
    sequence_parallel: True
    use_distributed_optimizer: True
    param_dtype: "bfloat16"
    seed: 1
    context_parallel_size: 1
    expert_model_parallel_size: 1
    expert_tensor_parallel_size: 1
    param_offload: False
    grad_offload: False
    optimizer_offload: False
    use_dist_checkpointing: False
    dist_checkpointing_path: ""
    override_transformer_config: ${actor_rollout_ref.actor.megatron.override_transformer_config}
    override_ddp_config: ${actor_rollout_ref.actor.megatron.override_ddp_config}
    use_mbridge: ${actor_rollout_ref.actor.megatron.use_mbridge}

reward_model:
  enable: False
  strategy: fsdp
  model:
    input_tokenizer: ${actor_rollout_ref.model.path}  # set this to null if the chat template is identical
    path: ~/models/FsfairX-LLaMA3-RM-v0.1
    use_shm: False
    external_lib: ${actor_rollout_ref.model.external_lib}
    use_remove_padding: False
    use_fused_kernels: ${actor_rollout_ref.model.use_fused_kernels}
    trust_remote_code: False
    fsdp_config:
      wrap_policy:
        min_num_params: 0
      param_offload: False
      reshard_after_forward: True # only for fsdp2, [True, False, int between 1 and fsdp_size]
      fsdp_size: -1
  micro_batch_size: null # will be deprecated, use micro_batch_size_per_gpu
  micro_batch_size_per_gpu: null # set a number
  max_length: null
  ulysses_sequence_parallel_size: 1 # sp size
  use_dynamic_bsz: ${critic.use_dynamic_bsz}
  forward_max_token_len_per_gpu: ${critic.forward_max_token_len_per_gpu}
  reward_manager: naive
  launch_reward_fn_async: False # custom reward function executed async on CPU, during log_prob
  sandbox_fusion:
    url: null # faas url to run code in cloud sandbox
    max_concurrent: 64 # max concurrent requests to sandbox
  # Megatron-specific configuration
  megatron:  # Only used when strategy is megatron
    tensor_model_parallel_size: 2  # Reward model's tensor parallelism
    pipeline_model_parallel_size: 1  # Reward models typically don't need PP
    sequence_parallel: False
    use_distributed_optimizer: False
    param_dtype: "bfloat16"
    seed: 1
    override_transformer_config: ${actor_rollout_ref.actor.megatron.override_transformer_config}
    use_mbridge: ${actor_rollout_ref.actor.megatron.use_mbridge}
  # DAPO-specific overlong buffer configuration
  overlong_buffer:
    enable: False  # Enable overlong sequence buffer
    len: 512       # Buffer length for overlong sequences
    penalty_factor: 1.0  # Penalty factor for overlong sequences
    log: False     # Enable logging of overlong buffer rewards and penalties
custom_reward_function:
  path: null
  name: compute_score

algorithm:
  gamma: 1.0
  lam: 1.0
  adv_estimator: gae
  norm_adv_by_std_in_grpo: True
  workflow_type: default
  weight_factor_in_cpgd: STD_weight # for CPGD, ["STD_weight", "clip_filter_like_weight", "naive"]
  use_kl_in_reward: False
  share_reward_in_agent: True
  kl_penalty: kl  # how to estimate kl divergence
  kl_ctrl:
    type: fixed
    kl_coef: 0.001
    horizon: 10000
    target_kl: 0.1
  use_pf_ppo: False
  pf_ppo:
    reweight_method: pow  # ["pow", "max_min", "max_random"]
    weight_pow: 2.0
  # DAPO-specific filter groups configuration
  filter_groups:
    enable: False  # Enable trajectory filtering based on variance
    metric: acc    # Metric used for filtering (acc, seq_final_reward, seq_reward)
    max_num_gen_batches: 10  # Maximum generation batches before giving up

trainer:
  balance_batch: True
  total_epochs: 30
  total_training_steps: null
  project_name: examples
  experiment_name: gsm8k
  logger: [ 'console', 'wandb' ]
  log_val_generations: 0
  rollout_data_dir: null # directory for logging the rollout data, no dump if null
  validation_data_dir: null # directory for logging the validation data, no dump if null
  nnodes: 1
  n_gpus_per_node: 8
  save_freq: -1
  # auto: find the last ckpt to resume. If can't find, start from scratch
  resume_mode: auto # or disable or resume_path if resume_from_path is set
  resume_from_path: null
  val_before_train: True
  test_freq: -1
  critic_warmup: 0
  default_hdfs_dir: null
  del_local_ckpt_after_load: False
  default_local_dir: checkpoints/${trainer.project_name}/${trainer.experiment_name}
  max_actor_ckpt_to_keep: null
  max_critic_ckpt_to_keep: null
  # The timeout for ray worker group to wait for the register center to be ready
  ray_wait_register_center_timeout: 300
  device: cuda

ray_init:
  num_cpus: null # `None` means using all CPUs, which might cause hang if limited in systems like SLURM. Please set to a number allowed then.
  timeline_json_file: null

dag:
  workflow_path: null
  env_enable: False
  environment_path: null
  enable_perf: False
  backend_threshold: 256  # World size threshold for backend selection

hydra:
  run:
    dir: /tmp/
  output_subdir: null

profiler:
  enable: False
  save_path: "./prof_data"  # Storage path for collected data.
  level: "level1"  # Collection level, optional values: level_none, level0, level1, level2.
  with_memory: False  # Whether to enable memory analysis.
  record_shapes: False  # Whether to record tensor shape.
  with_npu: True  # Whether to record Device-side performance data.
  with_cpu: False  # Whether to record Host-side performance data.
  with_module: False  # Whether to record Python call stack information.
  with_stack: False  # Whether to record operator call stack information.
  analysis: True  # Whether to automatically parse the data.
  discrete: False  # True for each task has its own database, False for all tasks in one training step share one database.
  roles: ['generate', 'compute_reward']  # used for discrete mode, optional values: generate, compute_reward, compute_old_log_prob, compute_ref_log_porb, compute_value, compute_advantage, train_critic, train_actor
  all_ranks: False  # Whether to profile all ranks.
  ranks: [0]  # The ranks that will be profiled. [] or [0,1,...]
  profile_steps: [0]  # The steps that will be profiled.
