data:
  train_files: /home/chengpengzhou/hhw/rft_data/faithful_dataset/train.json  # 替换为你的数据集路径
  val_files: /home/chengpengzhou/hhw/rft_data/faithful_dataset/test.json  # 空验证集文件（空数组），配合 val_freq: -1 使用，不会实际进行验证
  prompt_key: prompt_str
  answer_key: answer_str
  image_key: images
  video_key: videos
  image_dir: null
  video_fps: 2.0
  max_prompt_length: 6144
  max_response_length: 2048
  rollout_batch_size: 256  # equivalent to verl's data.train_batch_size (adjusted: 720 % 120 = 0, 720*5=3600 divisible by micro_batch_size=4)
  mini_rollout_batch_size: null  # equivalent to verl's data.gen_batch_size
  val_batch_size: 1024
  format_prompt: null  # 如果需要自定义 prompt 格式，可以指定 jinja 模板路径
  override_chat_template: null
  shuffle: true
  seed: 1
  min_pixels: 262144
  max_pixels: 4194304
  filter_overlong_prompts: true

algorithm:
  adv_estimator: grpo  # 使用 rank-normalization with anchor rollout
  disable_kl: false
  use_kl_loss: true
  kl_penalty: low_var_kl
  kl_coef: 1.0e-2
  online_filtering: false  # dapo filter groups
  filter_key: overall
  filter_low: 0.01
  filter_high: 0.99

worker:
  actor:
    global_batch_size: 128  # equivalent to verl's actor.ppo_mini_batch_size 
    micro_batch_size_per_device_for_update: 2  # equivalent to verl's actor.ppo_micro_batch_size_per_gpu
    micro_batch_size_per_device_for_experience: 4  # equivalent to verl's rollout.log_prob_micro_batch_size_per_gpu
    max_grad_norm: 1.0
    padding_free: true
    dynamic_batching: true
    ulysses_size: 1
    model:
      model_path: /data/cpz/hhw/experiments/faithful_sft_3ep
      enable_gradient_checkpointing: true
      trust_remote_code: false
      freeze_vision_tower: false
    optim:
      lr: 1.0e-6
      weight_decay: 1.0e-2
      strategy: adamw  # {adamw, adamw_bf16}
      lr_warmup_ratio: 0.0
    fsdp:
      enable_full_shard: true
      enable_cpu_offload: false
      enable_rank0_init: true
    offload:
      offload_params: true  # true: more CPU memory; false: more GPU memory
      offload_optimizer: true  # true: more CPU memory; false: more GPU memory

  rollout:
    n: 8  # GRPO 需要 n > 1
    temperature: 1.0
    top_p: 1.0
    limit_images: 0
    gpu_memory_utilization: 0.8
    enforce_eager: false
    enable_chunked_prefill: false
    tensor_parallel_size: 2
    max_model_len: 8192
    disable_tqdm: false
    val_override_config:
      temperature: 0.6
      top_p: 0.95
      n: 1

  ref:
    fsdp:
      enable_full_shard: true
      enable_cpu_offload: true  # true: more CPU memory; false: more GPU memory
      enable_rank0_init: true
    offload:
      offload_params: false

  reward:
    reward_function: ./examples/reward_function/faithful_grpo.py:compute_score
    compute_embeddings: true  # rollout 阶段计算 embedding（仅用于越界惩罚）

    # overall = action_match + embedding_penalty
    # embedding_penalty 是负项，只在异常时生效，不参与加权
    reward_function_kwargs:
      # ===== 主奖励 =====
      action_match_weight: 1.0        # 主信号，唯一真正决定排序结构的奖励

      # ===== 动作相关 =====
      use_continuous_reward: true      # 使用固定底分模式：R = 0.3 + 0.7 × r_arg
      click_threshold: 140.0
      click_tau: 70.0
      use_action_type_weight: false

      # ===== Embedding 越界惩罚（极简版）=====
      use_embedding_reward: false      # 是否启用 embedding 惩罚（guard rail）

      # 只用 input-action 相似度（I-A）
      emb_tau: 0.40                   # 越界阈值（一次定死即可）
      emb_lam: 0.08                   # 最大惩罚幅度（负值，加到总分中）
      full_match_thresh: 0.85         # full_match 阈值（>= 此值时关闭 embedding 惩罚）


      
trainer:
  total_epochs: 3
  max_steps: null
  project_name: easy_r1
  experiment_name: faithful_grpo
  logger: ["file"]
  nnodes: 1
  n_gpus_per_node: 8
  max_try_make_batch: 20  # -1 means no limit
  val_freq: 10  # -1 to disable validation
  val_before_train: false
  val_only: false
  val_generations_to_log: 3
  save_freq: 10  # 每2个epoch保存一次checkpoint
  save_limit: 2  # -1表示不限制保存的checkpoint数量
  save_model_only: false
  save_checkpoint_path: null # /data/cpz/hhw/experiments/grpo  # checkpoint保存路径
  load_checkpoint_path: null
  find_last_checkpoint: true

