|
@@ -2,6 +2,7 @@
|
|
|
Copied and adapted from https://github.com/mila-iqia/babyai.
|
|
|
Levels described in the Baby AI ICLR 2019 submission, with different instructions than those in other files.
|
|
|
"""
|
|
|
+from typing import Optional
|
|
|
|
|
|
from minigrid.envs.babyai.core.roomgrid_level import RoomGridLevel
|
|
|
from minigrid.envs.babyai.core.verifier import (
|
|
@@ -55,8 +56,12 @@ class FindObjS5(RoomGridLevel):
|
|
|
This level requires potentially exhaustive exploration
|
|
|
"""
|
|
|
|
|
|
- def __init__(self, room_size=5, **kwargs):
|
|
|
- super().__init__(room_size=room_size, max_steps=20 * room_size**2, **kwargs)
|
|
|
+ def __init__(self, room_size=5, max_steps: Optional[int] = None, **kwargs):
|
|
|
+
|
|
|
+ if max_steps is None:
|
|
|
+ max_steps = 20 * room_size**2
|
|
|
+
|
|
|
+ super().__init__(room_size=room_size, max_steps=max_steps, **kwargs)
|
|
|
|
|
|
def gen_mission(self):
|
|
|
# Add a random object to a random room
|
|
@@ -75,14 +80,21 @@ class KeyCorridor(RoomGridLevel):
|
|
|
random room.
|
|
|
"""
|
|
|
|
|
|
- def __init__(self, num_rows=3, obj_type="ball", room_size=6, **kwargs):
|
|
|
+ def __init__(
|
|
|
+ self,
|
|
|
+ num_rows=3,
|
|
|
+ obj_type="ball",
|
|
|
+ room_size=6,
|
|
|
+ max_steps: Optional[int] = None,
|
|
|
+ **kwargs
|
|
|
+ ):
|
|
|
self.obj_type = obj_type
|
|
|
|
|
|
+ if max_steps is None:
|
|
|
+ max_steps = 30 * room_size**2
|
|
|
+
|
|
|
super().__init__(
|
|
|
- room_size=room_size,
|
|
|
- num_rows=num_rows,
|
|
|
- max_steps=30 * room_size**2,
|
|
|
- **kwargs
|
|
|
+ room_size=room_size, num_rows=num_rows, max_steps=max_steps, **kwargs
|
|
|
)
|
|
|
|
|
|
def gen_mission(self):
|
|
@@ -130,16 +142,17 @@ class MoveTwoAcross(RoomGridLevel):
|
|
|
instructions.
|
|
|
"""
|
|
|
|
|
|
- def __init__(self, room_size, objs_per_room, **kwargs):
|
|
|
+ def __init__(
|
|
|
+ self, room_size, objs_per_room, max_steps: Optional[int] = None, **kwargs
|
|
|
+ ):
|
|
|
assert objs_per_room <= 9
|
|
|
self.objs_per_room = objs_per_room
|
|
|
|
|
|
+ if max_steps is None:
|
|
|
+ max_steps = 16 * room_size**2
|
|
|
+
|
|
|
super().__init__(
|
|
|
- num_rows=1,
|
|
|
- num_cols=2,
|
|
|
- room_size=room_size,
|
|
|
- max_steps=16 * room_size**2,
|
|
|
- **kwargs
|
|
|
+ num_rows=1, num_cols=2, room_size=room_size, max_steps=max_steps, **kwargs
|
|
|
)
|
|
|
|
|
|
def gen_mission(self):
|