unlockpickup.py 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. from gym_minigrid.register import register
  2. from gym_minigrid.roomgrid import RoomGrid
  3. class UnlockPickupEnv(RoomGrid):
  4. """
  5. Unlock a door, then pick up a box in another room
  6. """
  7. def __init__(self, **kwargs):
  8. room_size = 6
  9. super().__init__(
  10. num_rows=1,
  11. num_cols=2,
  12. room_size=room_size,
  13. max_steps=8 * room_size**2,
  14. **kwargs,
  15. )
  16. def _gen_grid(self, width, height):
  17. super()._gen_grid(width, height)
  18. # Add a box to the room on the right
  19. obj, _ = self.add_object(1, 0, kind="box")
  20. # Make sure the two rooms are directly connected by a locked door
  21. door, _ = self.add_door(0, 0, 0, locked=True)
  22. # Add a key to unlock the door
  23. self.add_object(0, 0, "key", door.color)
  24. self.place_agent(0, 0)
  25. self.obj = obj
  26. self.mission = f"pick up the {obj.color} {obj.type}"
  27. def step(self, action):
  28. obs, reward, done, info = super().step(action)
  29. if action == self.actions.pickup:
  30. if self.carrying and self.carrying == self.obj:
  31. reward = self._reward()
  32. done = True
  33. return obs, reward, done, info
  34. register(
  35. id="MiniGrid-UnlockPickup-v0",
  36. entry_point="gym_minigrid.envs.unlockpickup:UnlockPickupEnv",
  37. )