"""
configs.py

Defines per-dataset configuration (kwargs) for each dataset in Open-X Embodiment.

Configuration adopts the following structure:
    image_obs_keys:
        primary: primary external RGB
        secondary: secondary external RGB
        wrist: wrist RGB

    depth_obs_keys:
        primary: primary external depth
        secondary: secondary external depth
        wrist: wrist depth

    # Always 8-dim =>> changes based on `StateEncoding`
    state_obs_keys:
        StateEncoding.POS_EULER:    EEF XYZ (3) + Roll-Pitch-Yaw (3) + <PAD> (1) + Gripper Open/Close (1)
        StateEncoding.POS_QUAT:     EEF XYZ (3) + Quaternion (4) + Gripper Open/Close (1)
        StateEncoding.JOINT:        Joint Angles (7, <PAD> if fewer) + Gripper Open/Close (1)

    state_encoding: Type of `StateEncoding`
    action_encoding: Type of action encoding (e.g., EEF Position vs. Joint Position)
"""

from enum import IntEnum

from model.data_provider.rlds.oxe.utils.droid_utils import zero_action_filter


# Defines Proprioceptive State Encoding Schemes
class StateEncoding(IntEnum):
    # fmt: off
    NONE = -1               # No Proprioceptive State
    POS_EULER = 1           # EEF XYZ (3) + Roll-Pitch-Yaw (3) + <PAD> (1) + Gripper Open/Close (1)
    POS_QUAT = 2            # EEF XYZ (3) + Quaternion (4) + Gripper Open/Close (1)
    JOINT = 3               # Joint Angles (7, <PAD> if fewer) + Gripper Open/Close (1)
    JOINT_BIMANUAL = 4      # Joint Angles (2 x [ Joint Angles (6) + Gripper Open/Close (1) ])
    # fmt: on


# Defines Action Encoding Schemes
class ActionEncoding(IntEnum):
    # fmt: off
    EEF_POS = 1             # EEF Delta XYZ (3) + Roll-Pitch-Yaw (3) + Gripper Open/Close (1)
    JOINT_POS = 2           # Joint Delta Position (7) + Gripper Open/Close (1)
    JOINT_POS_BIMANUAL = 3  # Joint Delta Position (2 x [ Joint Delta Position (6) + Gripper Open/Close (1) ])
    EEF_R6 = 4              # EEF Delta XYZ (3) + R6 (6) + Gripper Open/Close (1)
    DEXTEROUS = 5           # 22 dim dexterous action for dexart
    EEF_POSE = 6           # EEF Delta XYZ (3) + Quaternion (4) + Gripper Open/Close (1)
    BIMANUAL_EEF_POSE = 7  # EEF Delta XYZ (2 x [ XYZ (3) + Quaternion (4) ] + Gripper Open/Close (1))
    # fmt: on


# === Individual Dataset Configs ===
OXE_DATASET_CONFIGS = {
    "fractal20220817_data": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["base_pose_tool_reached", "gripper_closed"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "kuka": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": [
            "clip_function_input/base_pose_tool_reached",
            "gripper_closed",
        ],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "bridge_oxe": {  # Version of Bridge V2 in Open X-Embodiment mixture
        "image_obs_keys": {"primary": "image", "secondary": "image_1", "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "bridge_orig": {  # Original version of Bridge V2 from project website
        "image_obs_keys": {"primary": "image_0", "secondary": "image_1", "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "bridge_dataset": {  # Original version of Bridge V2 from project website
        "image_obs_keys": {"primary": "image_0", "secondary": "image_1", "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "taco_play": {
        "image_obs_keys": {
            "primary": "rgb_static",
            "secondary": None,
            "wrist": "rgb_gripper",
        },
        "depth_obs_keys": {
            "primary": "depth_static",
            "secondary": None,
            "wrist": "depth_gripper",
        },
        "state_obs_keys": ["state_eef", None, "state_gripper"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "jaco_play": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "image_wrist",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state_eef", None, "state_gripper"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "berkeley_cable_routing": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "top_image",
            "wrist": "wrist45_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["robot_state", None],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "roboturk": {
        "image_obs_keys": {"primary": "front_rgb", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": [None, None, None, None, None, None, None, None],
        "state_encoding": StateEncoding.NONE,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "nyu_door_opening_surprising_effectiveness": {
        "image_obs_keys": {"primary": None, "secondary": None, "wrist": "image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": [None, None, None, None, None, None, None, None],
        "state_encoding": StateEncoding.NONE,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "viola": {
        "image_obs_keys": {
            "primary": "agentview_rgb",
            "secondary": None,
            "wrist": "eye_in_hand_rgb",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["joint_states", "gripper_states"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "berkeley_autolab_ur5": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "hand_image",
        },
        "depth_obs_keys": {"primary": "depth", "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "toto": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "language_table": {
        "image_obs_keys": {"primary": "rgb", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["effector_translation", None, None, None, None, None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "columbia_cairlab_pusht_real": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["robot_state", None, None, None, None, None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "stanford_kuka_multimodal_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": "depth_image", "secondary": None, "wrist": None},
        "state_obs_keys": ["ee_position", "ee_orientation", None],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "nyu_rot_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "stanford_hydra_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "austin_buds_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "nyu_franka_play_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "image_additional_view",
            "wrist": None,
        },
        "depth_obs_keys": {
            "primary": "depth",
            "secondary": "depth_additional_view",
            "wrist": None,
        },
        "state_obs_keys": ["eef_state", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "maniskill_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {
            "primary": "depth",
            "secondary": None,
            "wrist": "wrist_depth",
        },
        "state_obs_keys": ["tcp_pose", "gripper_state"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "furniture_bench_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "cmu_franka_exploration_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "highres_image",
            "secondary": None,
            "wrist": None,
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": [None, None, None, None, None, None, None, None],
        "state_encoding": StateEncoding.NONE,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "ucsd_kitchen_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["joint_state", None],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "ucsd_pick_and_place_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "austin_sailor_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "austin_sirius_dataset_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "bc_z": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": [
            "present/xyz",
            "present/axis_angle",
            None,
            "present/sensed_close",
        ],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "utokyo_pr2_opening_fridge_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "utokyo_pr2_tabletop_manipulation_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "utokyo_xarm_pick_and_place_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "image2",
            "wrist": "hand_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["end_effector_pose", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "utokyo_xarm_bimanual_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["pose_r", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "robo_net": {
        "image_obs_keys": {"primary": "image", "secondary": "image1", "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "berkeley_mvp_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": None, "secondary": None, "wrist": "hand_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["pose", "gripper"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.JOINT_POS,
    },
    "berkeley_rpt_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": None, "secondary": None, "wrist": "hand_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["joint_pos", "gripper"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.JOINT_POS,
    },
    "kaist_nonprehensile_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "stanford_mask_vit_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "tokyo_u_lsmo_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "dlr_sara_pour_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "dlr_sara_grid_clamp_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "dlr_edan_shared_control_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "asu_table_top_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "stanford_robocook_converted_externally_to_rlds": {
        "image_obs_keys": {"primary": "image_1", "secondary": "image_2", "wrist": None},
        "depth_obs_keys": {"primary": "depth_1", "secondary": "depth_2", "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "imperialcollege_sawyer_wrist_cam": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": [None, None, None, None, None, None, None, "state"],
        "state_encoding": StateEncoding.NONE,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "iamlab_cmu_pickup_insert_converted_externally_to_rlds": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["joint_state", "gripper_state"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "uiuc_d3field": {
        "image_obs_keys": {"primary": "image_1", "secondary": "image_2", "wrist": None},
        "depth_obs_keys": {"primary": "depth_1", "secondary": "depth_2", "wrist": None},
        "state_obs_keys": [None, None, None, None, None, None, None, None],
        "state_encoding": StateEncoding.NONE,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "utaustin_mutex": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "berkeley_fanuc_manipulation": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "wrist_image",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["joint_state", None, "gripper_state"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "cmu_playing_with_food": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": None,
            "wrist": "finger_vision_1",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "cmu_play_fusion": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "cmu_stretch": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["eef_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "berkeley_gnm_recon": {
        "image_obs_keys": {"primary": None, "secondary": None, "wrist": "image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "berkeley_gnm_cory_hall": {
        "image_obs_keys": {"primary": None, "secondary": None, "wrist": "image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "berkeley_gnm_sac_son": {
        "image_obs_keys": {"primary": None, "secondary": None, "wrist": "image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state", None, None],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "droid": {
        "image_obs_keys": {
            "primary": "exterior_image_1_left",
            "secondary": "exterior_image_2_left",
            "wrist": "wrist_image_left",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["proprio"],
        "state_encoding": StateEncoding.POS_QUAT,
        "action_encoding": ActionEncoding.EEF_POS,
        "aux_kwargs": {
            "dataset_frame_transform_kwargs": {
                "chunk_filter_fn": zero_action_filter,
            },
        },
    },
    "fmb_dataset": {
        "image_obs_keys": {
            "primary": "image_side_1",
            "secondary": "image_side_2",
            "wrist": "image_wrist_1",
        },
        "depth_obs_keys": {
            "primary": "image_side_1_depth",
            "secondary": "image_side_2_depth",
            "wrist": "image_wrist_1_depth",
        },
        "state_obs_keys": ["proprio"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "dobbe": {
        "image_obs_keys": {"primary": "wrist_image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["proprio"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "roboset": {
        "image_obs_keys": {
            "primary": "image_left",
            "secondary": "image_right",
            "wrist": "image_wrist",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["proprio"],
        "state_encoding": StateEncoding.JOINT,
        "action_encoding": ActionEncoding.JOINT_POS,
    },
    "rh20t": {
        "image_obs_keys": {
            "primary": "image_front",
            "secondary": "image_side_right",
            "wrist": "image_wrist",
        },
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["proprio"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    ### T-DROID datasets
    "tdroid_carrot_in_bowl": {  # "put carrot in bowl" task, 50 demos @ 5 Hz control
        "image_obs_keys": {"primary": "static_image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": "static_depth_image", "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "tdroid_pour_corn_in_pot": {  # "pour corn from red bowl into steel pot" task, 50 demos @ 5 Hz control
        "image_obs_keys": {"primary": "static_image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": "static_depth_image", "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "tdroid_flip_pot_upright": {  # "flip pot upright" task, 10 demos @ 5 Hz control
        "image_obs_keys": {"primary": "static_image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": "static_depth_image", "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "tdroid_move_object_onto_plate": {  # "move <object> onto plate" task, 150 demos @ 5 Hz control
        "image_obs_keys": {"primary": "static_image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": "static_depth_image", "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "tdroid_knock_object_over": {  # "knock <object> over" task, 70 demos @ 5 Hz control
        "image_obs_keys": {"primary": "static_image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": "static_depth_image", "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "tdroid_cover_object_with_towel": {  # "cover <object> with towel" task, 45 demos @ 5 Hz control
        "image_obs_keys": {"primary": "static_image", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": "static_depth_image", "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    ### DROID Finetuning datasets
    "droid_wipe": {
        "image_obs_keys": {"primary": "exterior_image_2_left", "secondary": None, "wrist": "wrist_image_left"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["proprio"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    ### LIBERO datasets (modified versions)
    "libero_spatial": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "libero_object": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "libero_goal": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    "libero_10": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
   "libero_90": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
   ### Deformable Datasets
   "fold": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
   "jean": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
   "rope": {
        "image_obs_keys": {"primary": "image", "secondary": None, "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["EEF_state", None, "gripper_state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POS,
    },
    # DexArt datasets
    "bucket_dex_art_dataset": {
        # "image_obs_keys": {"toilet": "toilet_viz", "secondary": None, "wrist": None, "laptop": "laptop_viz", "bucket": "bucket_viz", "faucet": "faucet_viz"},
        "image_obs_keys": {"primary": "bucket_viz", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.DEXTEROUS,
    },
    "faucet_dex_art_dataset": {
        # "image_obs_keys": {"toilet": "toilet_viz", "secondary": None, "wrist": None, "laptop": "laptop_viz", "bucket": "bucket_viz", "faucet": "faucet_viz"},
        "image_obs_keys": {"primary": "faucet_viz", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.DEXTEROUS,
    },
    "laptop_dex_art_dataset": {
        # "image_obs_keys": {"toilet": "toilet_viz", "secondary": None, "wrist": None, "laptop": "laptop_viz", "bucket": "bucket_viz", "faucet": "faucet_viz"},
        "image_obs_keys": {"primary": "laptop_viz", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.DEXTEROUS,
    },
    "toilet_dex_art_dataset": {
        # "image_obs_keys": {"toilet": "toilet_viz", "secondary": None, "wrist": None, "laptop": "laptop_viz", "bucket": "bucket_viz", "faucet": "faucet_viz"},
        "image_obs_keys": {"primary": "toilet_viz", "secondary": None, "wrist": None},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.DEXTEROUS,
    },
    # Colosseum datasets
    "colosseum": {
        "image_obs_keys": {
            "primary": "front_rgb", 
            "secondary": None, 
            "wrist": "wrist_rgb",
            "left": "left_shoulder_rgb",
            "right": "right_shoulder_rgb",
        },
        "depth_obs_keys": {
            "primary": "front_depth", 
            "secondary": None, 
            "wrist": "wrist_depth",
            "left": "left_shoulder_depth",
            "right": "right_shoulder_depth",
        },
        "state_obs_keys": [
            "state",
            "front_camera_extrinsics",
            "wrist_camera_extrinsics",
            "left_shoulder_camera_extrinsics",
            "right_shoulder_camera_extrinsics",
            "front_camera_intrinsics",
            "wrist_camera_intrinsics",
            "left_shoulder_camera_intrinsics",
            "right_shoulder_camera_intrinsics",
        ],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.EEF_POSE,
    },
    ### FurnitureBench Datasets
    "cabinet": {
        "image_obs_keys": {"front": "front_image", "rear": "rear_image", "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POSE,
    },
    "lamp": {
        "image_obs_keys": {"front": "front_image", "rear": "rear_image", "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POSE,
    },
    "one_leg": {
        "image_obs_keys": {"front": "front_image", "rear": "rear_image", "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POSE,
    },
    "round_table": {
        "image_obs_keys": {"front": "front_image", "rear": "rear_image", "wrist": "wrist_image"},
        "depth_obs_keys": {"primary": None, "secondary": None, "wrist": None},
        "state_obs_keys": ["state"],
        "state_encoding": StateEncoding.POS_EULER,
        "action_encoding": ActionEncoding.EEF_POSE,
    },
    ### PerAct2 Datasets
    "bimanual_handover_item": {
        "image_obs_keys": {
            "primary": "front_image", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_image",
            "wrist_left": "wrist_left_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "overhead": "overhead_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "wrist_right": "wrist_right_image",
        },
        "depth_obs_keys": {
            "primary": "front_depth", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_depth",
            "wrist_left": "wrist_left_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "overhead": "overhead_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "wrist_right": "wrist_right_depth",
        },
        "state_obs_keys": [
            "state",
            "over_shoulder_left_camera_extrinsics",
            "wrist_left_camera_extrinsics",
            "front_camera_extrinsics",
            "overhead_camera_extrinsics",
            "over_shoulder_right_camera_extrinsics",
            "wrist_right_camera_extrinsics",
            "over_shoulder_left_camera_intrinsics",
            "wrist_left_camera_intrinsics",
            "front_camera_intrinsics",
            "overhead_camera_intrinsics",
            "over_shoulder_right_camera_intrinsics",
            "wrist_right_camera_intrinsics",
        ],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.BIMANUAL_EEF_POSE,
    },
    "bimanual_lift_ball": {
        "image_obs_keys": {
            "primary": "front_image", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_image",
            "wrist_left": "wrist_left_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "overhead": "overhead_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "wrist_right": "wrist_right_image",
        },
        "depth_obs_keys": {
            "primary": "front_depth", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_depth",
            "wrist_left": "wrist_left_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "overhead": "overhead_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "wrist_right": "wrist_right_depth",
        },
        "state_obs_keys": [
            "state",
            "over_shoulder_left_camera_extrinsics",
            "wrist_left_camera_extrinsics",
            "front_camera_extrinsics",
            "overhead_camera_extrinsics",
            "over_shoulder_right_camera_extrinsics",
            "wrist_right_camera_extrinsics",
            "over_shoulder_left_camera_intrinsics",
            "wrist_left_camera_intrinsics",
            "front_camera_intrinsics",
            "overhead_camera_intrinsics",
            "over_shoulder_right_camera_intrinsics",
            "wrist_right_camera_intrinsics",
        ],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.BIMANUAL_EEF_POSE,
    },
    "bimanual_straighten_rope": {
        "image_obs_keys": {
            "primary": "front_image", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_image",
            "wrist_left": "wrist_left_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "overhead": "overhead_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "wrist_right": "wrist_right_image",
        },
        "depth_obs_keys": {
            "primary": "front_depth", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_depth",
            "wrist_left": "wrist_left_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "overhead": "overhead_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "wrist_right": "wrist_right_depth",
        },
        "state_obs_keys": [
            "state",
            "over_shoulder_left_camera_extrinsics",
            "wrist_left_camera_extrinsics",
            "front_camera_extrinsics",
            "overhead_camera_extrinsics",
            "over_shoulder_right_camera_extrinsics",
            "wrist_right_camera_extrinsics",
            "over_shoulder_left_camera_intrinsics",
            "wrist_left_camera_intrinsics",
            "front_camera_intrinsics",
            "overhead_camera_intrinsics",
            "over_shoulder_right_camera_intrinsics",
            "wrist_right_camera_intrinsics",
        ],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.BIMANUAL_EEF_POSE,
    },
    "bimanual_sweep_to_dustpan": {
        "image_obs_keys": {
            "primary": "front_image", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_image",
            "wrist_left": "wrist_left_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "overhead": "overhead_image",
            "over_shoulder_right": "over_shoulder_right_image",
            "wrist_right": "wrist_right_image",
        },
        "depth_obs_keys": {
            "primary": "front_depth", 
            "secondary": None, 
            "over_shoulder_left": "over_shoulder_left_depth",
            "wrist_left": "wrist_left_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "overhead": "overhead_depth",
            "over_shoulder_right": "over_shoulder_right_depth",
            "wrist_right": "wrist_right_depth",
        },
        "state_obs_keys": [
            "state",
            "over_shoulder_left_camera_extrinsics",
            "wrist_left_camera_extrinsics",
            "front_camera_extrinsics",
            "overhead_camera_extrinsics",
            "over_shoulder_right_camera_extrinsics",
            "wrist_right_camera_extrinsics",
            "over_shoulder_left_camera_intrinsics",
            "wrist_left_camera_intrinsics",
            "front_camera_intrinsics",
            "overhead_camera_intrinsics",
            "over_shoulder_right_camera_intrinsics",
            "wrist_right_camera_intrinsics",
        ],
        "state_encoding": StateEncoding.POS_EULER,  # will not be used
        "action_encoding": ActionEncoding.BIMANUAL_EEF_POSE,
    },
    "2_bowls": {
        "image_obs_keys": {
            "primary": "head_camera_image",
            "wrist": "low_cam_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.POS_EULER,  
        "action_encoding": ActionEncoding.EEF_POS,  
    },
    "3_bowls": {
        "image_obs_keys": {
            "primary": "head_camera_image",
            "wrist": "low_cam_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.POS_EULER,  
        "action_encoding": ActionEncoding.EEF_POS,  
    },
    "4_bowls": {
        "image_obs_keys": {
            "primary": "head_camera_image",
            "wrist": "low_cam_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.POS_EULER,  
        "action_encoding": ActionEncoding.EEF_POS,  
    },
    "wipe": {
        "image_obs_keys": {
            "primary": "head_camera_image",
            "wrist": "low_cam_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.POS_EULER,  
        "action_encoding": ActionEncoding.EEF_POS,  
    },
    # Add more datasets here as needed
    # ALOHA
    "aloha_move_can_pot": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_move_playingcard_away": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_lift_pot": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_click_bell": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_open_laptop": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_place_bread_basket": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_place_container_plate": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_place_mouse_pad": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_grab_roller": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_move_pillbottle_pad": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_place_object_stand": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
    "aloha_pick_dual_bottles": {
        "image_obs_keys": {
            "primary": "image",
            "secondary": "low_cam_image",
            "left_wrist":"left_wrist_image",
            "right_wrist":"right_wrist_image",
        },
        "depth_obs_keys": {
            "primary": None,
            "secondary": None,
            "wrist": None,
        },
        "state_obs_keys": ["state"],  
        "state_encoding": StateEncoding.JOINT_BIMANUAL,  
        "action_encoding": ActionEncoding.JOINT_POS_BIMANUAL,  
    },
}