defaults:
  - _self_
  - task: lift

pipeline_name: dbc_robomimic_lowdim

# env
env_type: ph
env_name: ${task.env_name}
abs_action: false
dataset_path: libs/robomimic/datasets/${env_name}/${env_type}/low_dim.hdf5
mode: train

# train
device: cuda:0
seed: 0
gradient_steps: 200000
batch_size: 512
horizon: 2
nn: pearce_mlp # or "dit"

available_data_rate: 1.0

diffusion: sde
solver: ${solvers.${diffusion}}
solvers:
  ddpm: null
  edm: euler
  sde: ode_dpmsolver++_2M
  csde: ode_dpmsolver++_2M

sample_steps: 50
diffusion_x: true
extra_sample_steps: 8

# contractivity
lambda_contr: 0.1
loss_type: "jacobian" # or "eigen_max" or "eigen_avg" or "all"

loss_weights:
  jacobian: 0.0
  eigen_max: 0.0
  eigen_avg: 0.0

# optimizer
lr: ${lrs.${nn}}
lrs:
  dit: 5e-4
  pearce_mlp: 1e-3

# eval
model_path: path/to/model
eval_episodes: 10
num_envs: 5
eval_freq: 10000
save_video: false

# log
exp_name: ${env_name}_${nn}_${diffusion}
save_path: logs
project: contractive_diffuser
group: dbc_robomimic_lowdim
wandb_mode: online
log_freq: 1000
save_freq: 100000
log_dir: logs

# hydra
hydra:
  job:
    chdir: false
  run:
    dir: ${log_dir}/${pipeline_name}/${env_name}/hydra/${seed}
  output_subdir: null
