_target_: future_motion.main.FutureMotion

time_step_current: 10
time_step_end: 90
n_video_batch: 3
interactive_challenge: True
inference_cache_map: False
inference_repeat_n: 1
plot_motion: False
dbl_decoding: True
pairwise_joint: True
loss_weight_dbl_decoding: 0.5
agent_0_as_global_ref: True

model:
  _target_: future_motion.models.ac_retro_motion.RetroMotion
  add_context_pos_enc: True
  hidden_dim: 256
  n_decoders: 1
  joint: True
  tf_cfg:
    n_head: 4
    dropout_p: 0.1
    norm_first: True
    bias: True
  local_encoder:
    add_learned_pe: True
    use_point_net: False
    n_layer_mlp: 3
    mlp_cfg:
      end_layer_activation: True
      use_layernorm: False
      use_batchnorm: False
      dropout_p: null
  reduction_decoder:
    n_descriptors: 128
    n_layer_tf_all2all: 4
  latent_context_module:
    n_layer: 6
  motion_decoder:
    n_decoder_layers: 8 
    n_pred: 6
    multi_modal_anchors:
      use_agent_type: False # Opt, test with as well
      mode_emb: none # linear, mlp, add, none
      mode_init: xavier # uniform, xavier
      scale: 5.0
    anchor_self_attn: True
    mlp_head:
      predictions: [pos, cov3] #[pos, cov3] # keywords: pos, cov1/2/3, spd, vel, yaw_bbox # opt. only pos, no cov
      use_agent_type: False
      flatten_conf_head: False
      out_mlp_layernorm: False
      out_mlp_batchnorm: False
      n_step_future: 80
    use_vmap: True
    n_dct_coeffs: 16
    dct_only_for_pos: True
    mlp_reencoder_without_dct: True

train_metric:
  _target_: hptr_modules.models.metrics.nll.NllMetrics
  winner_takes_all: joint_hard1 # none, or (joint) + hard + (1-6), or cmd
  l_pos: nll_exp_power_like # nll_torch, nll_mtr, huber, l2
  p_rand_train_agent: -1 # 0.2
  n_step_add_train_agent: [-1, -1, -1] # -1 to turn off
  focal_gamma_conf: [0.0, 0.0, 0.0] # 0.0 to turn off
  w_conf: [1.0, 1.0, 1.0] # veh, ped, cyc
  w_pos: [1.0, 1.0, 1.0]
  w_yaw: [1.0, 1.0, 1.0]
  w_vel: [1.0, 1.0, 1.0]
  w_spd: [0, 0, 0]
  pairwise_joint: True

train_metric_0:
  _target_: hptr_modules.models.metrics.nll.NllMetrics
  winner_takes_all: hard1 # none, or (joint) + hard + (1-6), or cmd
  l_pos: nll_exp_power_like # nll_torch, nll_mtr, huber, l2
  p_rand_train_agent: -1 # 0.2
  n_step_add_train_agent: [-1, -1, -1] # -1 to turn off
  focal_gamma_conf: [0.0, 0.0, 0.0] # 0.0 to turn off
  w_conf: [1.0, 1.0, 1.0] # veh, ped, cyc
  w_pos: [1.0, 1.0, 1.0]
  w_yaw: [1.0, 1.0, 1.0]
  w_vel: [1.0, 1.0, 1.0]
  w_spd: [0, 0, 0]

waymo_metric:
  _target_: hptr_modules.models.metrics.waymo.WaymoMetrics
  n_max_pred_agent: 8

pre_processing:
  agent_centric:
    _target_: hptr_modules.data_modules.agent_centric.AgentCentricPreProcessing
    mask_invalid: False
    n_target: 8
    n_other: 48
    n_map: 128 # 512
    n_tl: 24
  ac_global:
    _target_: future_motion.data.ac_scene_motion.AgentCentricSceneMotion
    dropout_p_history: 0.15
    use_current_tl: False
    add_ohe: True
    pl_aggr: False
    pose_pe: # xy_dir, mpa_pl, pe_xy_dir, pe_xy_yaw
      agent: xy_dir
      map: mpa_pl
      tl: mpa_pl

post_processing:
  to_dict:
    _target_: hptr_modules.data_modules.post_processing.ToDict
    predictions: ${...model.motion_decoder.mlp_head.predictions}
  get_cov_mat:
    _target_: hptr_modules.data_modules.post_processing.GetCovMat
    rho_clamp: 5.0
    std_min: -1.609
    std_max: 5.0
  waymo:
    _target_: hptr_modules.data_modules.waymo_post_processing.WaymoPostProcessing
    k_pred: 6
    use_ade: True
    score_temperature: -1
    mpa_nms_thresh: [2.5, 1.0, 2.0] # veh, ped, cyc
    mtr_nms_thresh: []
    gt_in_local: True
    use_mpa_multiagent: True
    normalize_across_agents: False


# opt. comment out for "legacy" bash training scripts
post_processing_0:
  to_dict:
    _target_: hptr_modules.data_modules.post_processing.ToDict
    predictions: ${...model.motion_decoder.mlp_head.predictions}
  get_cov_mat:
    _target_: hptr_modules.data_modules.post_processing.GetCovMat
    rho_clamp: 5.0
    std_min: -1.609
    std_max: 5.0
  waymo:
    _target_: hptr_modules.data_modules.waymo_post_processing.WaymoPostProcessing
    k_pred: 6
    use_ade: True
    score_temperature: -1
    mpa_nms_thresh: [2.5, 1.0, 2.0] # veh, ped, cyc
    mtr_nms_thresh: []
    gt_in_local: True
    use_mpa_multiagent: False
    normalize_across_agents: False


optimizer:
  _target_: torch.optim.AdamW
  lr: 2e-4 # 2e-4, 1e-5
lr_scheduler:
  _target_: torch.optim.lr_scheduler.StepLR
  gamma: 0.5
  step_size: 40

sub_womd:
  _target_: hptr_modules.utils.submission.SubWOMD
  activate: False
  method_name: METHOD_NAME
  authors: [NAME1, NAME2]
  affiliation: AFFILIATION
  description: scr_womd
  method_link: METHOD_LINK
  account_name: ACCOUNT_NAME
sub_av2:
  _target_: hptr_modules.utils.submission.SubAV2 
  activate: False
