Source code for problems.multi_object_search.domain.state
"""Defines the State for the 2D Multi-Object Search domain;
Origin: Multi-Object Search using Object-Oriented POMDPs (ICRA 2019)
(extensions: action space changes, different sensor model, gridworld instead of
topological graph)
Description: Multi-Object Search in a 2D grid world.
State space:
:math:`S_1 \\times S_2 \\times ... S_n \\times S_r`
where :math:`S_i (1\leq i\leq n)` is the object state, with attribute
"pose" :math:`(x,y)` and Sr is the state of the robot, with attribute
"pose" :math:`(x,y)` and "objects_found" (set).
"""
import pomdp_py
import math
###### States ######
[docs]
class ObjectState(pomdp_py.ObjectState):
def __init__(self, objid, objclass, pose):
if objclass != "obstacle" and objclass != "target":
raise ValueError(
"Only allow object class to beeither 'target' or 'obstacle'.Got %s"
% objclass
)
super().__init__(objclass, {"pose": pose, "id": objid})
def __str__(self):
return "ObjectState(%s,%s)" % (str(self.objclass), str(self.pose))
@property
def pose(self):
return self.attributes["pose"]
@property
def objid(self):
return self.attributes["id"]
[docs]
class RobotState(pomdp_py.ObjectState):
def __init__(self, robot_id, pose, objects_found, camera_direction):
"""Note: camera_direction is None unless the robot is looking at a direction,
in which case camera_direction is the string e.g. look+x, or 'look'"""
super().__init__(
"robot",
{
"id": robot_id,
"pose": pose, # x,y,th
"objects_found": objects_found,
"camera_direction": camera_direction,
},
)
def __str__(self):
return "RobotState(%s,%s|%s)" % (
str(self.objclass),
str(self.pose),
str(self.objects_found),
)
def __repr__(self):
return str(self)
@property
def pose(self):
return self.attributes["pose"]
@property
def robot_pose(self):
return self.attributes["pose"]
@property
def objects_found(self):
return self.attributes["objects_found"]
[docs]
class MosOOState(pomdp_py.OOState):
def __init__(self, object_states):
super().__init__(object_states)
[docs]
def object_pose(self, objid):
return self.object_states[objid]["pose"]
[docs]
def pose(self, objid):
return self.object_pose(objid)
@property
def object_poses(self):
return {
objid: self.object_states[objid]["pose"] for objid in self.object_states
}
def __str__(self):
return "MosOOState%s" % (str(self.object_states))
def __repr__(self):
return str(self)