meta_data:
  exp_name: "mad_mpe"
  script_path: "run_scripts/generate.py"
  num_workers: 1
  job_name: "{dataset}/{model}_dseed_{dataset_seed}_h_{horizon}"

variables:
  seed: [100]
  horizon: [8]
  returns_scale: [500]
  dataset: ["simple_spread-medium-replay"]
  condition_guidance_w: [1.2]

constants:
  use_seed_dataset: True
  dataset_seed: 2000
  
  env_type: "mpe"
  n_agents: 3
  use_action: True
  discrete_action: False
  residual_attn: True
  decentralized_execution: False
  use_zero_padding: False
  pred_future_padding: True
  use_ddim_sample: False
  n_ddim_steps: 15

  # model
  model: "models.SharedConvAttentionDeconv"
  diffusion: "models.GaussianDiffusion"
  share_inv: True
  history_horizon: 0
  n_diffusion_steps: 200
  action_weight: 10
  loss_weights: null
  loss_discount: 1
  dim_mults: [1, 4, 8]
  returns_condition: True
  predict_epsilon: True
  calc_energy: False
  dim: 128
  hidden_dim: 256
  condition_dropout: 0.25
  condition_guidance_w: 1.2
  train_only_inv: False
  clip_denoised: True
  test_ret: 0.9
  renderer: "utils.MPERenderer"

  # dataset
  loader: "datasets.SequenceDataset"
  normalizer: "CDFNormalizer"
  max_n_episodes: 200000
  preprocess_fns: []
  use_padding: True
  discount: 0.99
  max_path_length: 25
  termination_penalty: 0.0

  # Transition model
  use_dynamic_model: True
  share_dynamic: True
  joint_dynmic: False
  use_reward_model: True
  use_value_model: True
  joint_reward: True

  # Repaint
  num_resample: 1
  jump_denoising_step: 1

### For Generation ####
  load_checkpoint_path: ""

  generate_path: ""
  generate_batch_size: 256
  num_generate_epoch: 1000
  generate_episode_nums: 1000

  accept_threshold: 0.03
