# sample style training script
dataset_path: './data/msg'
device: 0
pp_threshold: 0.3
object_threshold: 0.2

# coefficients for multitasking loss
loss_params:
  pr: 1.0
  obj: 1.0
  tcr: 0.0
  mean: 0.0

eval_split: Test
train_split: Training

output_dir: './exp-results/gdino'
output_file: 'train'
wandb: False

# if resume training from a chkpt
resume: False
resume_path: './path/to/checkpoints/0+.pth'

eval_output_dir: './exp-results/emb_ckpt' # this is specific to trained checkpoints
eval_chkpt: aomsg_s_4.pth #29-step44940+.pth #null for no checkpoint
save_every: True # if save specific results for every video
eval_step: 100

learning_rate: 0.00002 # 5e-5
num_epochs: 30
warmup_epochs: 3
warmup: no # cos

num_workers: 8
train_bs: 32
bs_video: 2
eval_bs: 64 # debug test

log_every: 1
chkpt_every: 3000

detector:
  model: grounding-dino # "grounding-dino", "fasterrcnn", "gt", "fasterrcnnv2"
  num_classes: 18
  freeze: True
  weights: DEFAULT
  pre_saved: True
  result_path: "./exp-results/gdino-direct"

obj_embedder:
  model: "dinov2-base" #"dinov2-small-mean", "dinov2-small-cls", "convnext-tiny-224", #'resnet50', # "dinov2_vits14", "dinov2_vitb14", "dinov2_vitl14", "dinov2_vitg14"
  weights: DEFAULT
  freeze: True
  output_type: mean

place_embedder:
  model: "dinov2-base" #"convnext-tiny", #'resnet50', # "dinov2-small", 
  weights: DEFAULT
  freeze: True
  output_type: feature # mean, cls, feature

associator:
  model: "AoMSG-S-4" # "AoMSG-S-2"
  object_dim: 768 # FYI dinov2-small 384, dinov2-base 768, resnet18 512, resnet50 1024
  place_dim: 768
  output_dim: 1024

# loss terms
pr_loss: mse
obj_loss: bce
pos_weight: 10
pp_weight: 1