123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- from gym_minigrid.roomgrid import RoomGrid
- from gym_minigrid.register import register
- class KeyCorridor(RoomGrid):
- """
- A ball is behind a locked door, the key is placed in a
- random room.
- """
- def __init__(
- self,
- num_rows=3,
- obj_type="ball",
- room_size=6,
- seed=None
- ):
- self.obj_type = obj_type
- super().__init__(
- room_size=room_size,
- num_rows=num_rows,
- max_steps=30*room_size**2,
- seed=seed,
- )
- def _gen_grid(self, width, height):
- super()._gen_grid(width, height)
- # Connect the middle column rooms into a hallway
- for j in range(1, self.num_rows):
- self.remove_wall(1, j, 3)
- # Add a locked door on the bottom right
- # Add an object behind the locked door
- room_idx = self._rand_int(0, self.num_rows)
- door, _ = self.add_door(2, room_idx, 2, locked=True)
- obj, _ = self.add_object(2, room_idx, kind=self.obj_type)
- # Add a key in a random room on the left side
- self.add_object(0, self._rand_int(0, self.num_rows), 'key', door.color)
- # Place the agent in the middle
- self.place_agent(1, self.num_rows // 2)
- # Make sure all rooms are accessible
- self.connect_all()
- self.obj = obj
- self.mission = "pick up the %s %s" % (obj.color, obj.type)
- def step(self, action):
- obs, reward, done, info = super().step(action)
- if action == self.actions.pickup:
- if self.carrying and self.carrying == self.obj:
- reward = self._reward()
- done = True
- return obs, reward, done, info
- class KeyCorridorS3R1(KeyCorridor):
- def __init__(self, seed=None):
- super().__init__(
- room_size=3,
- num_rows=1,
- seed=seed
- )
- class KeyCorridorS3R2(KeyCorridor):
- def __init__(self, seed=None):
- super().__init__(
- room_size=3,
- num_rows=2,
- seed=seed
- )
- class KeyCorridorS3R3(KeyCorridor):
- def __init__(self, seed=None):
- super().__init__(
- room_size=3,
- num_rows=3,
- seed=seed
- )
- class KeyCorridorS4R3(KeyCorridor):
- def __init__(self, seed=None):
- super().__init__(
- room_size=4,
- num_rows=3,
- seed=seed
- )
- class KeyCorridorS5R3(KeyCorridor):
- def __init__(self, seed=None):
- super().__init__(
- room_size=5,
- num_rows=3,
- seed=seed
- )
- class KeyCorridorS6R3(KeyCorridor):
- def __init__(self, seed=None):
- super().__init__(
- room_size=6,
- num_rows=3,
- seed=seed
- )
- register(
- id='MiniGrid-KeyCorridorS3R1-v0',
- entry_point='gym_minigrid.envs:KeyCorridorS3R1'
- )
- register(
- id='MiniGrid-KeyCorridorS3R2-v0',
- entry_point='gym_minigrid.envs:KeyCorridorS3R2'
- )
- register(
- id='MiniGrid-KeyCorridorS3R3-v0',
- entry_point='gym_minigrid.envs:KeyCorridorS3R3'
- )
- register(
- id='MiniGrid-KeyCorridorS4R3-v0',
- entry_point='gym_minigrid.envs:KeyCorridorS4R3'
- )
- register(
- id='MiniGrid-KeyCorridorS5R3-v0',
- entry_point='gym_minigrid.envs:KeyCorridorS5R3'
- )
- register(
- id='MiniGrid-KeyCorridorS6R3-v0',
- entry_point='gym_minigrid.envs:KeyCorridorS6R3'
- )
|