Skip to content

Latest commit

 

History

History
41 lines (23 loc) · 3.27 KB

File metadata and controls

41 lines (23 loc) · 3.27 KB

ABB_MultiBot_Downloader

This repository will be a workground for a number of things to support a multi-robot ABB IRB120 experiment.

This repository will also act as a staging ground for my updated ABB_Drivers package which will enable 2 or more robots to interact in ROS with a single IRC5 controller. Setup instructions for how to setup multiple robots and changes to the ROS-I abb_driver will be included. Demos of code running on the ROS-I trajectory action controller are included for those wishing to not use moveit.

ABB_MultiBot pkg is for multiple robots in ROS through a IRC5 with additional drive modules. See instructions below for setup.

elastic_rod_experiment pkg uses the above package, with visual and F/T packages elsewhere, in combination and does the motion planning and feedback for control over the robot manipulators with the rod.

Lab Start-Up Instructions For Twin ABB IRB120 robots without F/T or Visual Feedback

  1. Ensure that the ethernet connection is made between the ROSmaster computer and the IRC5 controller.

  2. Power on the IRC5 and accompanying additional drive module, wait for start up on the flexpendant.

  3. Turn on the motors by pressing the Motor On button on the IRC5 controller. This is the round white button that may be flashing.

  4. Start the controller connection to the ROSmaster computer,

roslaunch ABB_MultiBot abb_multi_robot_single_controller.launch You should see on the flexpendant 4 connections (a stateServer and motionServer for each robot).

  1. Move the program pointer to the main entry function on the flexpendant.

  2. Release the breaks and enable the robot motors by pressing the play button on the flexpendant. Note: you may stop the robot motion at anytime by pressing the stop button below the play button.

  3. In a separate terminal, execute the ROS node, python, or C++ program. Alternatively, making a new launch file to open the node and open the robot connection would be advantageous for complex launches and additional drivers. An example:

python demo_ROS_multi_robot.py in the demo_multibot_multi_point_motion directory.

Instructions for modification of abb_driver for multiple robots through ethernet connection to an IRC5 with additional drive modules.

general notes: make new copies of each of the global variables stored in the ros_common.sys file for each additional robot and replace them in the copies of the motionServer.mod, stateServer.mod, and motion.mod files, also for each robot.

ABB_MultiBot / multi_robot_single_controller.launch

This launch file will launch the two robots on the workstation computer. Each robot will be in its own namespace and have its own separate topics for publishing and substribing telemetry. Assumes setup of RAPID on IRC5. See drivers folder and instructions on the ABB ROS page.

ABB_MultiBot / Demo / [single, Multi] MultiBot Motion

This includes a python ROS node meant as a quick test of your multirobot abb_driver was currently installed on the IRC5 controller and the launch file is communicating with the controller. This will make the two robots complete a simple trajectory as outlined in the traj.txt file. The single will execute 1 point at a time at a fixed rate. The multi will execute multiple points in one download motion. This acts as a good first tutorial in ROS-I motion planning.