name: Fsd_Inter_Dir_ProLate_Base
dair_data_dir: './dataset/DAIR-V2X/cooperative-vehicle-infrastructure'
test_dir: './dataset/DAIR-V2X/cooperative-vehicle-infrastructure/val.json'
validate_dir: './dataset/DAIR-V2X/cooperative-vehicle-infrastructure/val.json'
work_dir: './work_dirs/'

wild_setting:
  async: false
  async_mode: 'sim'
  async_overhead: 100
  seed: 25
  loc_err: false
  xyz_std: 0.2
  ryp_std: 0.2
  data_size: 1.06 # Mb!!
  transmission_speed: 27 # Mbps!!
  backbone_delay: 10 # ms

yaml_parser: "load_second_params"
train_params:
  batch_size: &batch_size 4
  epoches: 35
  eval_freq: 1
  save_freq: 1
  max_cav: &max_cav 2 # dair max agents

dair_params:
  car_only: false
  copy_v_to_x: true

fusion:
  core_method: 'IntermediateFusionDatasetDAIR' # LateFusionDataset, EarlyFusionDataset, IntermediateFusionDataset supported
  args:
    cur_ego_pose_flag: False
      # when the cur_ego_pose_flag is set to True, there is no time gap
      # between  the time when the LiDAR data is captured by connected
      # agents and when the extracted features are received by
      # the ego vehicle, which is equal to implement STCM. When set to False,
      # STCM has to be used.
    proj_first: &proj_first False   # set to whether lidar points to ego car before backbone
    use_single_label: &use_single_label False  # set to use onw label/ projected by cop label to surprised seg

# preprocess-related
preprocess:
  # options: BasePreprocessor, VoxelPreprocessor, BevPreprocessor
  core_method: 'IdentityPreprocessor'
  args:
    voxel_size: &voxel_size [0.1, 0.1, 0.1]
    max_points_per_voxel: 5
    max_voxel_train: 36000
    max_voxel_test: 70000
  # lidar range for each individual cav.
  cav_lidar_range: &cav_lidar [-102.4, -38.4, -3.5, 102.4, 38.4, 1.5]

data_augment:
  - NAME: random_world_flip
    ALONG_AXIS_LIST: [ 'x' ]

  - NAME: random_world_rotation
    WORLD_ROT_ANGLE: [ -0.78539816, 0.78539816 ]

  - NAME: random_world_scaling
    WORLD_SCALE_RANGE: [ 0.95, 1.05 ]

# anchor box related
postprocess:
  core_method: 'VoxelPostprocessor' # VoxelPostprocessor, BevPostprocessor supported
  anchor_args:
    cav_lidar_range: *cav_lidar
    l: 3.9
    w: 1.6
    h: 1.56
    r: [0, 90]
    feature_stride: 4
    num: &achor_num 2
  target_args:
    pos_threshold: 0.6
    neg_threshold: 0.45
    score_threshold: 0.27
  order: 'lwh' # hwl or lwh
  max_num: 100 # maximum number of objects in a single frame. use this number to make sure different frames has the same dimension in the same batch
  nms_thresh: 0.15
  coord_type: right
  use_anchor_box: false
  use_target_label: false

# model related
model:
  core_method: fsd_intermediate
  args:
    batch_size: *batch_size
    seg_voxel_size: *voxel_size
    pre_voxel_size: *voxel_size
    num_classes: &num_classes 1
    lidar_range: *cav_lidar
    anchor_number: *achor_num
    max_cav: *max_cav
    compression: 0 # compression rate
    backbone_fix: false
    detector_cfg: 'opencood/hypes_yaml/detector_cfgs/cppc_dair.py'
    use_single_label: *use_single_label
    proj_first: *proj_first
    fusion_cfg:
      seg_score_th: 0.5
      cluster_topk: 50
      connect_center_dist: 0.6
      # cluster_center cluster_mean or cluster_pts
      two_stage_xyz: cluster_pts
      # cluster_pts_mean cluster_pts_max cluster_feat
      two_stage_feat_mode: cluster_pts_mean

loss:
  core_method: point_pillar_loss
  args:
    cls_weight: 1.0
    reg: 2.0

optimizer:
  core_method: Adam
  lr: 0.001
  args:
    eps: 1e-10
    weight_decay: 1e-4

lr_scheduler:
  core_method: multistep #step, multistep and Exponential support
  gamma: 0.1
  step_size: [20, 30]

