No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

social_force_window_planner package from social_force_window_planner repo

social_force_window_planner

Package Summary

Tags No category tags.
Version 0.4.7
License MIT
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/robotics-upo/social_force_window_planner.git
VCS Type git
VCS Version ros2
Last Updated 2023-09-19
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

social_force_window_planner

Additional Links

No additional links.

Maintainers

  • Noé Pérez

Authors

  • Noé Pérez
  • Roberto Otero

social_force_window_planner (ROS2 Foxy version)

A local controller based on Dinamic Window Approach (DWA) and Social Force Model (SFM) has been developed to command a differential robot in a socially-compliant way.

This planner projects a set of possible trajectories in a small lookahead time (sim_time parameter). Then, the SFM is employed as a predictor of the future state of the surrounding people along the trajectories.

Besides the basic scoring function to follow the global path, a new social cost has been added. It is based on the concept of the “social work” performed by the robot ($W_{r}$), and the social work provoked by the robot in the surrounding pedestrians ($W_{p}$)

\[W_{social} = W_{r} + \sum W_{p_{i}}\]

With:

  • $W_{r}$ The summatory of the modulus of the robot social force and the robot obstacle force along the trajectory. According to the SFM.
  • $W_{p}$ The summatory of the modulus of the social forces provoked by the robot for each close pedestrian along the trajectory. According to the SFM.

This local planner has been programmed as a Controller plugin under ROS2 distro foxy. So it can be used in the ROS2 nav2 architecture. The possible collisions are checked based on the ROS local costmap and the projected people positions.

Acknowledgment

This publication has been financed by the European Regional Development Fund (FEDER) and by the Ministry of Economy, Knowledge, Business and University, of the Government of Andalucía , within the framework of the FEDER Andalucía 2014-2020 operational program. Specific objective 1.2.3. “Promotion and generation of frontier knowledge and knowledge oriented to the challenges of society, development of emerging technologies” within the framework of the reference research project UPO-1264631. FEDER co-financing percentage 80%

Parameters

An example yaml file with the set of parameters is provided in config/local_planner.yaml

  • Robot Configuration Parameters
    • max_trans_acc. Maximum acceleration in translation (m/s^2).
      • max_rot_acc. Maximum acceleration in rotation (rad/s^2).
      • max_trans_vel. Maximum linear velocity (m/s).
      • min_trans_vel. Minimum linear velocity (m/s).
      • max_rot_vel. Maximum angular velocity (rad/s).
      • min_rot_vel. Minimum angular velocity (rad/s).
      • min_in_place_rot_vel. Angular velocity of rotations in place (rad/s).
  • Goal Tolerance Parameters
    • yaw_goal_tolerance. Tolerance in angular distance (rad) to consider that the goal has been reached.
    • xy_goal_tolerance. Tolerance in euclidean distance (m) to consider that the goal has been reached.
    • wp_tolerance. Distance (m) from the robot to look for the point of the global plan to follow.
  • Forward Simulation Parameters
    • sim_time. Time (seconds) to expand the robot movement and check for collisions. (default: 0.5).
    • sim_granularity. Resolution in meters to split the expanded trayectory and check for collisions (Default: 0.025).
  • Sensor Interface Parameters The sensor interface is in charge of taking the sensory input and update the information of the surrounding social agents in the scene.

    • laser_topic. Topic in which the laser range finder is being published [sensor_msgs/LaserScan].
    • people_topic. Topic in which the people detected are being published [people_msgs/People].
    • odom_topic. Odometry topic [nav_msgs/Odometry].
    • max_obstacle_dist. Maximum distance (m) in which the obstacles are considered for the social force model.
    • naive_goal_time. Lookahead time (secs) to predict an approximate goal for the pedestrians.
    • people_velocity. Average velocity of the pedestrians (m/s).
  • Social Force Model Parameters The weights of the SFM forces for people trajectory computation.
    • sfm_goal_weight. Weight of the attraction force to the goal.
    • sfm_obstacle_weight. Weight of the respulsive force of the obstacles.
    • sfm_people_weight. Weight of the respulsive force of the pedestrians.
  • Trajectory-scoring Function Parameters Cost function for trajectory scoring:
\[C_{traj} = C_{s} * \omega_{s} + C_{cm} * \omega_{cm} + C_{a} * \omega_{a} + C_{v} * \omega_{v} + C_{d} * \omega_{d}\]

With:

  • social_weight $\omega_{s}$. The weight given to the “social-work” term. ($W_{social}$)
  • costmap_weight $\omega_{cm}$. The weight given to the normalized “non-lethal” costmap value.
  • angle_weight $\omega_{a}$. The weight given to the angle difference between the robot heading and the path heading.
  • vel_weight $\omega_{v}$. The weight given to the difference between the linear maximum velocity allowed and the linear velocity evaluated.
  • distance_weight $\omega_{d}$. The weight given to the distance between the final point of the projected robot trajectory and the current local goal.

Dependencies

  • lightsfm (https://github.com/robotics-upo/lightsfm).

  • Packages of ROS2 nav2 (https://navigation.ros.org/index.html).

  • Any sofware providing people detections. It should publish people_msgs/People messages in any topic (/people by default).

TO DO List:

The package is a work in progress used in research prototyping. Pull requests and/or issues are highly encouraged.

  • Improve the approximation to a final goal.
  • Larger sim_time and wp_tolerance gives more “social” freedom to the planner but it presents problems to overcome some corners and narrow passages. We must try to fix this or to find a good balance.
  • Fix the computation of the robot local goal in the path in case the robot moves farther than wp_tolerance distance.
CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged social_force_window_planner at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.