defaults:
  - _self_
  - task: lift

pipeline_name: dbc_robomimic_image

# env
env_type: ph
env_name: ${task.env_name}
abs_action: false
dataset_path: libs/robomimic/datasets/${env_name}/${env_type}/image.hdf5
mode: train
max_episode_steps: 400
render_obs_key: 'agentview_image'
shape_meta:
  action:
    shape:
    - 7
  obs:
    agentview_image:
      shape:
      - 3
      - 84
      - 84
      type: rgb
    robot0_eef_pos:
      shape:
      - 3
      type: low_dim
    robot0_eef_quat:
      shape:
      - 4
      type: low_dim
    robot0_eye_in_hand_image:
      shape:
      - 3
      - 84
      - 84
      type: rgb
    robot0_gripper_qpos:
      shape:
      - 2
      type: low_dim
action_dim: 7
obs_steps: 2
action_steps: 1

# obs_encoder
rgb_model: resnet18
resize_shape: null
crop_shape:
  - 76
  - 76
random_crop: true
use_group_norm: true
use_seq: true

# train
device: cuda:0
seed: 0
gradient_steps: 200000
batch_size: 64
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
temperature: 1.0
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: 20
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_image
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
