from environments.kitchen import reward_utils
from environments.kitchen.kitchen_base import KitchenSingleTaskEnv


class KitchenHingeCabinetCloseEnvV0(KitchenSingleTaskEnv):
    TASK_NAME = "hinge cabinet-close"
    BONUS_THRESH = 0.3

    @classmethod
    def _compute_reward(cls, obs_dict, dists):
        in_place = reward_utils.tolerance(
            dists["goal"],
            bounds=(0, cls.BONUS_THRESH),
            margin=abs(dists["goal_init"] - cls.BONUS_THRESH),
            sigmoid="long_tail",
        )

        handle_reach_radius = 0.07
        reach = reward_utils.tolerance(
            dists["hand"],
            bounds=(0, handle_reach_radius),
            margin=abs(dists["hand_init"] - handle_reach_radius),
            sigmoid="gaussian",
        )

        gripper_opened = float(dists["gripper"] > 0.5)
        reach = reward_utils.hamacher_product(reach, gripper_opened)

        # TODO: grasping attempt

        reward = reward_utils.hamacher_product(reach, in_place)
        if dists["goal"] < cls.BONUS_THRESH:
            reward = 1.
        return reward
