@torch.jit.script
def compute_reward(
    franka_grasp_pos: torch.Tensor, 
    drawer_grasp_pos: torch.Tensor, 
    cabinet_dof_pos: torch.Tensor, 
    cabinet_dof_vel: torch.Tensor
) -> Tuple[torch.Tensor, Dict[str, torch.Tensor]]:
    # Temperature parameters for reward shaping
    distance_temp: float = 0.1   # Adjusted for sharper decay
    progress_temp: float = 1.0   # For door angle progress
    time_penalty_temp: float = 0.1  # Increased to encourage faster completion

    # Distance between the Franka hand and the drawer handle
    distance = torch.norm(franka_grasp_pos - drawer_grasp_pos, dim=-1)
    distance_reward = torch.exp(-distance / distance_temp)

    # Progress reward based on the cabinet door's opening angle
    door_angle = cabinet_dof_pos[:, 3]  # Assuming the 4th DOF is the cabinet door
    progress_reward = torch.clamp(door_angle, min=0.0, max=1.0)  # Normalize to [0, 1]
    progress_reward = torch.exp(progress_reward / progress_temp)

    # Time penalty to encourage faster task completion
    time_penalty = torch.ones_like(door_angle) * time_penalty_temp

    # Total reward is a weighted sum of the components
    total_reward = distance_reward + progress_reward - time_penalty

    # Individual reward components for debugging
    reward_dict = {
        "distance_reward": distance_reward,
        "progress_reward": progress_reward,
        "time_penalty": time_penalty
    }

    return total_reward, reward_dict
