Source code for bulletarm.envs.close_loop_envs.close_loop_drawer_opening

import pybullet as pb
import numpy as np

from bulletarm.envs.close_loop_envs.close_loop_env import CloseLoopEnv
from bulletarm.pybullet.utils import transformations
from bulletarm.planners.close_loop_drawer_opening_planner import CloseLoopDrawerOpeningPlanner
from bulletarm.pybullet.equipments.drawer import Drawer

[docs]class CloseLoopDrawerOpeningEnv(CloseLoopEnv): '''Close loop drawer opening task. The robot needs to pull the handle of the drawer to open it. Args: config (dict): Intialization arguments for the env ''' def __init__(self, config): super().__init__(config) self.drawer = Drawer() self.drawer_rot = 0 def initialize(self): super().initialize() self.drawer.initialize((self.workspace[0].mean(), self.workspace[1].mean(), 0), pb.getQuaternionFromEuler((0, 0, 0)), 0.3) def reset(self): self.resetPybulletWorkspace() self.robot.moveTo([self.workspace[0].mean(), self.workspace[1].mean(), 0.2], transformations.quaternion_from_euler(0, 0, 0)) # pos = self._getValidPositions(0.1, 0, [], 1)[0] # pos.append(0) pos = np.array([self.workspace[0].mean(), self.workspace[1].mean(), 0]) self.drawer_rot = np.random.random()*2*np.pi if self.random_orientation else np.random.choice([np.pi/2, 3*np.pi/2]) m = np.array(transformations.euler_matrix(0, 0, self.drawer_rot))[:3, :3] dx = np.random.random() * (0.2 - 0.15) + 0.15 dy = np.random.random() * (0.1 - -0.1) + -0.1 pos = pos + m[:, 0] * dx pos = pos + m[:, 1] * dy self.drawer.reset(pos, transformations.quaternion_from_euler(0, 0, self.drawer_rot)) return self._getObservation() def _checkTermination(self): return self.drawer.isDrawerOpen() def getObjectPoses(self, objects=None): obj_poses = list() drawer_pos, drawer_rot = self.drawer.getPose() drawer_rot = self.convertQuaternionToEuler(drawer_rot) obj_poses.append(drawer_pos + drawer_rot) handle_pos = list(self.drawer.getHandlePosition()) handle_rot = list(self.drawer.getHandleRotation()) handle_rot = self.convertQuaternionToEuler(handle_rot) obj_poses.append(handle_pos + handle_rot) return np.array(obj_poses)
def createCloseLoopDrawerOpeningEnv(config): return CloseLoopDrawerOpeningEnv(config)