name: V2XSet/ParCon/S30_Perfect

# root_dir: '/dataset/OPV2V/train'
# validate_dir: '/dataset/OPV2V/validate'

root_dir: '/dataset/V2XSet_W/train'
validate_dir: '/dataset/V2XSet_W/validate'

system: V2X

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

yaml_parser: "load_point_pillar_params"
train_params:
  batch_size: &batch_size 2
  epoches: &epoches 40
  eval_freq: 1
  save_freq: 1
  max_cav: &max_cav 5

fusion:
  core_method: 'IntermediateFusionDataset' # 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.

# preprocess-related
preprocess:
  # options: BasePreprocessor, VoxelPreprocessor, BevPreprocessor, SpVoxelPreprocessor, SptSpVoxelPreprocessor
  core_method: 'SpVoxelPreprocessor'
  args:
    voxel_size: &voxel_size [0.4, 0.4, 4]
    max_points_per_voxel: 32
    max_voxel_train: 32000
    max_voxel_test: 70000
  # lidar range for each individual cav.
  lidar_range: &cav_lidar [-140.8, -38.4, -3, 140.8, 38.4, 1]

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:
    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: 'hwl' # 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

# model related
model:
  core_method: sparse_resnet_concat_transformer
  args:
    voxel_size: *voxel_size
    lidar_range: *cav_lidar
    anchor_number: *achor_num
    max_cav: *max_cav
    compression: 32 # compression rate
    backbone_fix: false
    s_mask_down_rate: 4

    pillar_vfe:
      use_norm: true
      with_distance: false
      use_absolute_xyz: true
      num_filters: [64]
    point_pillar_scatter:
      num_features: 64
    sparse_resnet_backbone:
      layer_nums: [2, 2, 2]
      layer_strides: [1, 2, 2]
      num_filters: [64, 128, 256]

    transformer:
      is_shuffle: false
      encoder: &encoder
        # number of fusion blocks per encoder layer
        num_blocks: 1
        # number of encoder layers
        depth: 3
        use_roi_mask: false
        outter_dim: 256

        feature_fusion: 'concat' # concat, sequence

        # agent-wise attention
        cav_att_config: &cav_att_config
          dim: 64
          heads: 2
          dim_head: 32
          dropout: 0.3
          embed_config:
            is_embed: false
            learnable: false
            embed_type: 'hetero'
            per_degree: 20 # degree
            per_dist: 25 # m

        # spatial-wise attention
        neighborhood_att_config: &neighborhood_att_config
          dim: 64
          heads: 2
          kernel: 7
          dilations: [4, 2]
          mlp_ratio: 3.0
          embed_type: 'normal'
          drop_path: 0.3

        # heteroneity-reflected convolution
        spatial_conv_config: &spatial_conv_config
          dim: 64
          kernel: [3, 3, 3]
          res_flag: [True, True, False]

        # feedforward condition
        feed_forward: &feed_forward
          mlp_dim: 256
          dropout: 0.3
        sttf: &sttf
          voxel_size: *voxel_size
          downsample_rate: 4

      # add decoder later

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

optimizer:
  core_method: AdamW
  lr: 3e-4
  args:
    eps: 1e-10
    weight_decay: 1e-2

lr_scheduler:
    core_method: cosineannealwarm #step, multistep, Exponential and cosineannealwarm support
    epoches: *epoches
    warmup_lr: 2e-4
    warmup_epoches: 10
    lr_min: 2e-5
