Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

control changes + spawn zone update for svg #41

Merged
merged 4 commits into from
Jul 28, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion examples/simulate_with_svg_map.py
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,9 @@ def main():
"""Simulate a random policy with a map defined in SVG format."""
logger.info("Simulating a random policy with the map.")

svg_file = "maps/svg_maps/02_simple_maps.svg"
#svg_file = "maps/svg_maps/02_simple_maps.svg"
#svg_file = "maps/svg_maps/03_mid_object.svg"
svg_file = "maps/svg_maps/04_small_mid_object.svg"

logger.info("Converting SVG map to MapDefinition object.")
logger.info(f"SVG file: {svg_file}")
Expand Down
129 changes: 129 additions & 0 deletions maps/svg_maps/03_mid_object.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
129 changes: 129 additions & 0 deletions maps/svg_maps/04_small_mid_object.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
63 changes: 37 additions & 26 deletions robot_sf/nav/svg_map_parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ def _get_svg_info(self):
"""
Extracts path and rectangle information from an SVG file.

It is important that the SVG file uses absolute coordinates for the paths.

This method finds all 'path' and 'rect' elements in the SVG file and extracts their
coordinates, labels, and ids. The information is stored in the 'path_info' and 'rect_info'
attributes of the SvgMapConverter instance.
Expand Down Expand Up @@ -162,13 +164,33 @@ def _info_to_mapdefintion(self) -> MapDefinition:
ped_crowded_zones: List[Rect] = []
ped_routes: List[GlobalRoute] = []

for rect in self.rect_info:
if rect.label == 'robot_spawn_zone':
robot_spawn_zones.append(rect.get_zone())
elif rect.label == 'ped_spawn_zone':
ped_spawn_zones.append(rect.get_zone())
elif rect.label == 'robot_goal_zone':
robot_goal_zones.append(rect.get_zone())
elif rect.label == 'bound':
bounds.append(rect.get_zone())
elif rect.label == 'ped_goal_zone':
ped_goal_zones.append(rect.get_zone())
elif rect.label == 'obstacle':
obstacles.append(obstacle_from_svgrectangle(rect))
elif rect.label == 'ped_crowded_zone':
ped_crowded_zones.append(rect.get_zone())
else:
logger.error(
f"Unknown label <{rect.label}> in id <{rect.id_}>"
)

for path in self.path_info:

# check the label of the path
if path.label == 'obstacle':
# Convert the coordinates to a list of vertices
vertices = path.coordinates.tolist()

# Check if the first and last vertices are the same
if not np.array_equal(vertices[0], vertices[-1]):
logger.warning(
Expand All @@ -183,18 +205,27 @@ def _info_to_mapdefintion(self) -> MapDefinition:
# Append the obstacle to the list
obstacles.append(Obstacle(vertices))

elif path.label == 'ped_route':
elif 'ped_route' in path.label:
# Convert the coordinates to a list of vertices
vertices = path.coordinates.tolist()

# ped_routes have a label of the form 'ped_route_<spawn>_<goal>'
numbers = re.findall(r'\d+', path.label)
if numbers:
spawn = int(numbers[0])
goal = int(numbers[1])
else:
spawn = 0
goal = 0

# Append the obstacle to the list
ped_routes.append(
GlobalRoute(
spawn_id=0, # TODO: What is this? value is arbitrary
goal_id=0, # TODO: What is this? value is arbitrary
spawn_id=spawn,
goal_id=goal,
waypoints=vertices,
spawn_zone=(vertices[0], 0, 0), # TODO
goal_zone=(vertices[-1], 0, 0) # TODO
spawn_zone=ped_spawn_zones[spawn] if ped_spawn_zones else (vertices[0],0,0),
goal_zone=ped_goal_zones[goal] if ped_goal_zones else (vertices[-1],0,0)
))

elif path.label == 'robot_route':
Expand Down Expand Up @@ -225,26 +256,6 @@ def _info_to_mapdefintion(self) -> MapDefinition:
f"Unknown label <{path.label}> in id <{path.id}>"
)

for rect in self.rect_info:
if rect.label == 'robot_spawn_zone':
robot_spawn_zones.append(rect.get_zone())
elif rect.label == 'ped_spawn_zone':
ped_spawn_zones.append(rect.get_zone())
elif rect.label == 'robot_goal_zone':
robot_goal_zones.append(rect.get_zone())
elif rect.label == 'bound':
bounds.append(rect.get_zone())
elif rect.label == 'ped_goal_zone':
ped_goal_zones.append(rect.get_zone())
elif rect.label == 'obstacle':
obstacles.append(obstacle_from_svgrectangle(rect))
elif rect.label == 'ped_crowded_zone':
ped_crowded_zones.append(rect.get_zone())
else:
logger.error(
f"Unknown label <{rect.label}> in id <{rect.id_}>"
)



if not obstacles:
Expand Down
Loading
Loading