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

Bad obstacle mapping in the map limits #689

Open
joanvallve opened this issue Apr 17, 2024 · 10 comments
Open

Bad obstacle mapping in the map limits #689

joanvallve opened this issue Apr 17, 2024 · 10 comments

Comments

@joanvallve
Copy link

Required Info:

  • Operating System: Ubuntu 22.04
  • Installation type: binaries
  • ROS Version: Humble
  • Version or commit hash: 2.6.8-1jammy.20240217.104951
  • Laser unit: RPLIDAR A1M8 (turtlebot4 simulated)

Steps to reproduce issue

Launch turtlebot4 simulation in an environment with orthogonal walls starting with zero orientation.

Expected behavior

Map the walls on the map limits properly, like all the other walls.

Actual behavior

It seems that the walls close to the map limits are not properly mapped and often are mapped as free area.

Screenshot from 2024-04-17 13-27-20

Additional information

When simulating the robot starting with a different orientation, the walls are properly mapped. To me it seems like a problem of ray casting related with the lack of unknown cells behind. It would be easily fixed adding some extra rows and cols when resizing the map.

Screenshot from 2024-04-17 13-26-39

@SteveMacenski
Copy link
Owner

How is that map generated? The flat stop of the map really isn’t how lidar data works for the map to have an abrupt end like that. Is this in typical slam operation mode or are you localizing on something else? That map also looks really suspiciously perfect like it’s autogenerated and not from slam

@joanvallve
Copy link
Author

Yes, it is in SLAM with a simulated turtlebot4 initialized with yaw=0.0, not autogenerated or loaded.

@SteveMacenski
Copy link
Owner

Please provide something reproducible

@joanvallve
Copy link
Author

Sorry, do you mean a video or instructions to reproduce the error?

@SteveMacenski
Copy link
Owner

Instructions, maps, simulation files, etc so I can easily reproduce this myself to look into it. Probably a new github repo for it with instructions in the readme about how to launch and test so I can take a look

@joanvallve
Copy link
Author

Is it enough if I record a rosbag or do you want to simulate?

@joanvallve
Copy link
Author

joanvallve commented Apr 24, 2024

Ok so I added a readme to the package I use for this simulation: upc_mrn

There you have the dependencies and an example of how to launch the simulation of the turtlebot4 with slam_toolbox. The pictures I uploaded were taken simulating with world small and with default starting pose or changing the initial orientation, respectively. Tell me if you have any problems with this and if you prefer a rosbag. Thanks

@SteveMacenski
Copy link
Owner

SteveMacenski commented May 3, 2024

Does the robot localize well when in this situation (i.e. doesn't get lost)? What I expect is happening here is not a bug in the core SLAM / sensor matching but in the occupancy grid generation which happens periodically to serve to the user (which isn't used internally).

If the robot doesn't get delocalized or anything, then that is the most likely situation and that happens here: https://github.com/SteveMacenski/slam_toolbox/blob/ros2/lib/karto_sdk/include/karto_sdk/Karto.h#L5893 There's alot going on in that file, but from my glance, you shouldn't need to look at anything but that, Grid and perhaps the Math.h file for how certain validation checks are performed. You can safely not bother yourself with the rest which would be alot to take in. Those objects are pretty straight forward

Given what you see is on the right side of the map, that is at the width maximum value, so there may be an off by 1 error in some validation check if on the grid, we stop raycasting a little early, or round down some bounding box dimension one unit shy. Its hard for me to say which, but let me know if anything in that object or the Grid object sticks out to you.

@yknighthy
Copy link

When building the occupancy grid map, SlamToolBox performs raytracing by first finding the coordination of end points in the grid map. At the 4502 line in Karto.h, the function WorldToGrid does this work by directly returning the rounded value.

inline Vector2<kt_int32s> WorldToGrid(const Vector2<kt_double>& rWorld, kt_bool flipY = false) const
{
  kt_double gridX = (rWorld.GetX() - m_Offset.GetX()) * m_Scale;
  kt_double gridY = 0.0;

  if (flipY == false)
  {
    gridY = (rWorld.GetY() - m_Offset.GetY()) * m_Scale;
  }
  else
  {
    gridY = (m_Size.GetHeight() / m_Scale - rWorld.GetY() + m_Offset.GetY()) * m_Scale;
  }
  return Vector2<kt_int32s>(static_cast<kt_int32s>(math::Round(gridX)), static_cast<kt_int32s>(math::Round(gridY)));
}

However, the above method might push the mapped cell beyond the map boundary if the scan point is currently at the margin.
By judging whether the result of rounding exceeds the current map before returning the coordination, the obstacle missing problem seems to be fixed for me.

inline Vector2<kt_int32s> WorldToGrid(const Vector2<kt_double>& rWorld, kt_bool flipY = false) const
{
  kt_double gridX = (rWorld.GetX() - m_Offset.GetX()) * m_Scale;
  kt_double gridY = 0.0;

  if (flipY == false)
  {
    gridY = (rWorld.GetY() - m_Offset.GetY()) * m_Scale;
  }
  else
  {
    gridY = (m_Size.GetHeight() / m_Scale - rWorld.GetY() + m_Offset.GetY()) * m_Scale;
  }

  kt_int32s gridx = static_cast<kt_int32s>(math::Round(gridX));
  kt_int32s gridy = static_cast<kt_int32s>(math::Round(gridY));
  gridx = (gridx == m_Size.GetWidth()) ? gridx - 1 : gridx;
  gridy = (gridy == m_Size.GetHeight()) ? gridy - 1 : gridy;

  return Vector2<kt_int32s>(gridx, gridy);
}

@SteveMacenski
Copy link
Owner

Please test that a few times to make sure it fully resolves, but that seems sensible to me on first glance and easy enough for me to merge and backport to all the current distributions :-)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants