Skip to content

arwinder-jaspal/robot-multi-floor-navigation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

robot-multi-floor-navigation

This repository is for Jackal UGV elevator navigation. Demo can be found here

Goal

In this simultion, we will be using the Clearpath Jackal tranverse between 2 floors (floor 0 and floor 1) using an elevator. Few barrier were placed in the world for the UGV to navigate. The simulation world can be found here.

Fig.1 - Simulated Environment

Scenario Simulated

  1. Navigate from point 1:(4.0, -5.0, 0.5) to point 2:(3.0,-0.5,0.5)
  2. Enter the lift at level 0 (point 2:(3.0,-0.5,0.5) to point 3:(0.0,-0.5,0.5))
  3. Send the lift from level 0 to level 1
  4. Exit lift at level 1 to point 4:(3.0,-0.5,3.2)
  5. Switch Map to level 1 and localize robot
  6. Navigate from point 5:(3.0,-0.5,3.2) to point 6:(4.0,5.0,3.2

Installation

Dependencies Installation

For ROS Melodic:

$ sudo apt-get install ros-melodic-jackal-*

For ROS Noetic:

$ sudo apt-get install ros-noetic-jackal-*

ROS Workspace Setup (Neotic)

Change the ROS distro to Melodic if needed. The steps are the same

  1. Create a ROS Workspace (for example catkin_ws)
$ source /opt/ros/noetic/setup.bash 
$ mkdir -p ~/catkin_ws/src
$ cd ~/catkin_ws/
$ catkin_make$ sou

$ cd ~/catkin_ws/src
$ git clone [email protected]:arwinder-jaspal/robot-multi-floor-navigation.git
  1. Clone Additional Reposity
$ cd ~/catkin_ws/src
$ git clone [email protected]:jackal/jackal_simulator.git
$ git clone [email protected]:jackal/jackal_desktop.git
$ git clone git clone https://<username>@bitbucket.org/swaroophs/jackal_elevator.git
  1. Build the Workspace
$ cd ~/catkin_ws
$ catkin_make

Mapping

For Mapping, we will use the gmapping package from ROS.

  1. To launch the package:
$ source ~/catkin_ws/devel/setup,bash
$ roslaunch multi_floor_nav mapping.launch

This will launch RViz and Gazebo for mapping.

To begin mapping, use the Interaction Marker on RViz alt text

Fig.1 - Rviz For Mapping With Interactive Marker

  1. Once, map is generated, on a new terminal run the map_saver node from map_server package to write the map to file.
$ source ~/catkin_ws/devel/setup.bash
$ rosrun map_server map_saver -f <map_filename>.yaml

This will save 2 files (1 .pgm file and 1 .yaml) to the current directory

This will by default generate the map for floor 0. To map for floor 1, edit the z_pos param in the mapping launch file and repeat steps 1 and 2.

$ cd ~/catkin_ws/src/robot-multi-floor-navigation/multi_floor_nav/launch
$ nano mapping.launch

The map files are already generated for this repo

Navigation

  1. To run the simulation 2 terminals is needed
  • 1 terminal to launch the nodes
  • 1 terminal to start the simulation
  1. Build the workspace
$ cd ~/catkin_ws
$ catkin_make
  1. Source both the terminal
source ~/catkin_ws/devel/setup.bash
  1. Launch the navigation nodes on the first terminal
$ roslaunch multi_floor_nav nav.launch

This will launch the few nodes:

  • gazebo: for visualization
  • map_server: 2 map server will be launch(one for each map file) to load laser maps
  • amcl: for robot localization
  • move_base: for planning
  • rviz: for visualization
  • change_map_node: for handle map switching operations
  • multi_floor_nav_node: node with a state machine to handle map switching, sending of move_base goals and odom goals, and controlling the elevator
  1. On the second terminal, we will send the signal to start the state machine on multi_floor_nav_node. To do so, run the following command ONCE:
$ rostopic pub /start std_msgs/Empty "{}"

This will start the state machine on multi_floor_nav_node. The purpose for this topic is to allow enough time on slower machines to load visualization tools such as Gazebo.

Demo

Elevator.Navigation.mp4

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published