data:
    dataset: "controlseq"
    # category: "bedroom"
    # image_size: 8 #  256
    # image_size: 2 
    image_size: 1
    channels: 3
    logit_transform: false
    uniform_dequantization: false
    gaussian_dequantization: false
    random_flip: true
    rescaled: true
    num_workers: 32
    # scale_coef: 3.5 #
    # scale_coef: 20 # 50.0
    scale_coef: 1
    # maxx = tensor([0.2744, 0.2244, 0.1768]) minn = tensor([-0.2717, -0.2841, -0.2814])

model:
    type: "simple"
    in_channels: 3

    # out_ch: 3
    ch: 128

    # ch_mult: [1, 1, 2, 2, 4, 4]
    # ch_mult: [4, 4]
    # ch_mult: [4, 16]

    num_res_blocks: 2
    # attn_resolutions: [16, ]
    dropout: 0.0
    var_type: fixedsmall
    ema_rate: 0.999
    ema: True
    resamp_with_conv: True

    # subtype: "mlp"
    # subtype: "unet"
    # subtype: "resmlp"

    cond: True
    # cond: False
    
    # diffusion_rep: "link_motion"
    # diffusion_rep: "qpos_motion"
    # diffusion_rep: 'qposqtars_motion'

    # res_blocks: 2
    res_hidden_dim: 1024 #  512
    # separate_encodings ;False

    # ###### New cond settings ######
    # cond_in_dim: 64 # 16 * 4 = 64 (history stack of qpos state)
    # in_channels: 16
    # out_ch: 16
    # ch_mult: [1, 2]
    # # ch_mult: [1]
    # # res_blocks: 2
    # # res_blocks: 3
    # res_blocks: 4
    # subtype:   "unet"
    # ###### New cond settings ######


    ###### New cond settings ######
    diffusion_rep: "qpos_motion"
    cond_in_dim: 64 # 16 * 4 = 64 (history stack of qpos state)
    in_channels: 32
    out_ch: 32
    # ch_mult: [1, 2]
    ch_mult: [2]
    res_blocks: 2
    # res_blocks: 3
    # res_blocks: 4
    attn_resolutions: [1,]
    # attn_resolutions: []
    subtype:   "unet"
    debug: False
    # debug: True
    ###### New cond settings ######

    # ###### New cond settings ######
    # diffusion_rep: "link_motion"
    # cond_in_dim: 96
    # in_channels: 3
    # out_ch: 3
    # ch_mult: [1, 2, 4]
    # res_blocks: 2
    # attn_resolutions: [8,4,2]
    # subtype:   "unet"
    # ###### New cond settings ######


    

diffusion:
    beta_schedule: linear
    beta_start: 0.0001
    beta_end: 0.02
    num_diffusion_timesteps: 1000
    separate_encodings: False
    # separate_encodings: True

training:
    # batch_size: 64
    # batch_size: 1024
    batch_size: 32
    # batch_size: 10240
    n_epochs: 10000
    n_iters: 5000000
    snapshot_freq: 5000
    validation_freq: 2000
    logging_step_interval: 20000

sampling:
    batch_size: 32
    last_only: True
    # ckpt_id: 25000 


invdyn:
    history_length: 4
    future_length: 2

    ###### hand qpos, with mlp #######
    # history_obs_dim: 16
    # future_ref_dim: 16
    # future_act_dim: 16
    # obs_type: 'hand_qpos'
    # model_arch: 'mlp'

    # obs_type: 'link_pos'
    # history_obs_dim: 24
    # future_ref_dim: 24
    # future_act_dim: 16

    # # model_arch: 'mlp'
    # model_arch: 'resmlp'
    # res_blocks: 2
    # res_hidden_dim: 512

    ###### hand qpos and qtars with resmlp #######
    history_obs_dim: 32
    future_ref_dim: 16
    future_act_dim: 16
    obs_type: 'hand_qpos_qtars'
    model_arch: 'resmlp'
    res_blocks: 2
    res_hidden_dim: 512
    ###### hand qpos and qtars with resmlp #######

    w_obj_state_history: False
    action_type: 'absolute'
    mask_out_obj_motion: False

    use_obj_motion_norm_command: False

    use_relative_target: False

    pred_extrin: False

    normalize_input: False
    normalize_output: False

    obj_state_predictor: False

    masked_cond: False
    obj_motion_format: 'ori_motion'
    load_experience_via_mode: False
    rnd_masked_cond: False

    token_mimicking: False
    invdyn_masked_obj_motion_cond: False

    encode_data: False
    train_tokenizer: False

    resume_tokenizer: ''

    mixed_sim_real_experiences: False
    real_experiences_traj_idx_to_file_name: ''
    optimize_via_fingertip_pos: False

    finger_idx: -1
    joint_idx: -1
    wm_history_length: 1
    
    train_obj_motion_pred_model: False
    hist_context_length: 0
    hist_context_finger_idx: -1

    wm_pred_joint_idx: -1

    add_obs_noise_scale: 0.0
    add_action_noise_scale: 0.0

    train_q_value_model: False
    q_value_model_expectile_regression: False
    q_value_model_w_v_model: False

    fingertip_rot_coef: 0.0

    train_finger_pos_tracking_model: False
    finger_pos_tracking_target_finger_idx: 0

    train_inverse_dynamics_model: False
    train_value_network: False

    add_noise_onto_hist_obs: False
    hist_obs_nosie_scale: 0.02

    train_residual_wm: False
    prev_wm_ckpt: ''

    w_hand_root_ornt: False
    add_nearing_neighbour: False

    add_nearing_finger: False
    wm_as_invdyn_prediction: False

    stack_wm_history: False
    multi_joint_single_wm: False
    multi_finger_single_wm: False
    single_hand_wm: False
    multi_joint_single_shared_wm: False

    load_pretrained_wm_ckpt: ''

    delta_action_scale: 1/24
    # eval_use_test_set: False

    use_sepearate_test_data: False
    seperate_test_data_fn: ''

    fullhand_wobjstate_wm: False
    wm_hist_length_in_delta_action: -1

    pred_nearing_joint: False


optim:
    weight_decay: 0.000
    optimizer: "Adam"
    lr: 0.00002
    beta1: 0.9
    amsgrad: false
    eps: 0.00000001
