imitation_planner:
  _target_: src.planners.SCRP_betop.BeTopImitationPlanner
  _convert_: "all"

  replan_interval: 1

  planner:
    _target_: src.models.SCRP_betop.planning_model.PlanningModel
    _convert_: "all"

    # dim: 128
    # state_channel: 6
    # polygon_channel: 6
    # history_channel: 9
    # history_steps: 21
    # future_steps: 80
    # encoder_depth: 4
    # drop_path: 0.0
    # num_heads: 8
    # num_modes: 6
    # state_dropout: 0.0
    # use_ego_history: false
    # state_attn_encoder: true
    # joint_pred: false
    # rel_pred: false 
    # occ_pred: true
    # conti_plan: true
    # multi_pred: true
    # traj_step: 30

    dim: 128
    state_channel: 6
    polygon_channel: 6
    history_channel: 9
    history_steps: 21
    future_steps: 80
    encoder_depth: 4
    drop_path: 0.0
    num_heads: 8
    num_modes: 6
    state_dropout: 0.0
    use_ego_history: false
    state_attn_encoder: true
    joint_pred: false
    rel_pred: false 
    traj_step: 30
    marginal_mode: 1      # <--- 必须改为 1，解决所有维度和 loc_1 问题
    conti_plan: true      # <--- 保持 true，以使用 NewContigencyDecoder
    occ_pred: true       # <--- 关闭 Occupancy
    multi_pred: true      # <--- 开启 Multi-agent 预测，适配 agent_predictor


    feature_builder:
      _target_: src.feature_builders.nuplan_feature_builder.NuplanFeatureBuilder
      _convert_: "all"
      radius: 100
      history_horizon: 2
      future_horizon: 8
      sample_interval: 0.1
      max_agents: 32
    # PDM prior inputs:
    planner:
      _target_: src.planners.pdm_planner.pdm_closed_planner.PDMClosedPlanner
      _convert_: 'all'

      # parameters for output trajectory
      trajectory_sampling:
        _target_: nuplan.planning.simulation.trajectory.trajectory_sampling.TrajectorySampling
        _convert_: 'all'
        num_poses: 80 # target future poses
        interval_length: 0.1 # interval of samples [s]

      # parameters for proposals
      proposal_sampling:
        _target_: nuplan.planning.simulation.trajectory.trajectory_sampling.TrajectorySampling
        _convert_: 'all'
        num_poses: 40 # target future poses
        interval_length: 0.1 # interval of samples [s]

      idm_policies:
        _target_: src.planners.pdm_planner.proposal.batch_idm_policy.BatchIDMPolicy
        _convert_: 'all'
        speed_limit_fraction: [0.2,0.4,0.6,0.8,1.0] # Target velocity as fractions of current speed-limit
        fallback_target_velocity: 15.0 # Desired fallback velocity in free traffic [m/s]
        min_gap_to_lead_agent: 1.0 # Minimum relative distance to lead vehicle [m]
        headway_time: 1.5 # Desired time headway. The minimum possible time to the vehicle in front [s]
        accel_max: 1.5 # Maximum acceleration [m/s^2]
        decel_max: 3.0 # Maximum deceleration (positive value) [m/s^2]
      
      lateral_offsets: [-1.0, 1.0] # Signed offsets from centerline (or null) [m]
      map_radius: 50 # Radius to consider around ego [m]

  planner_ckpt: