• Stars
    star
    1,180
  • Rank 38,148 (Top 0.8 %)
  • Language
    MATLAB
  • License
    GNU Lesser Genera...
  • Created about 9 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Robotics Toolbox for MATLAB

Build Status Coverage License: LGPL v3 Maintenance GitHub stars

Robotics Toolbox for MATLAB® release 10


For support please use the Google group forum rather than GitHub issues. There are more people participating and you'll likely get a quicker response. Checkout the FAQ before you post a question, it covers common problems that arise with incorrect MATLAB paths.


Synopsis

This toolbox brings robotics specific functionality to MATLAB, exploiting the native capabilities of MATLAB (linear algebra, portability, graphics).

The Toolbox uses a very general method of representing the kinematics and dynamics of serial-link manipulators as MATLAB® objects – robot objects can be created by the user for any serial-link manipulator and a number of examples are provided for well known robots from Kinova, Universal Robotics, Rethink as well as classical robots such as the Puma 560 and the Stanford arm.

The toolbox also supports mobile robots with functions for robot motion models (unicycle, bicycle), path planning algorithms (bug, distance transform, D*, PRM), kinodynamic planning (lattice, RRT), localization (EKF, particle filter), map building (EKF) and simultaneous localization and mapping (EKF), and a Simulink model a of non-holonomic vehicle. The Toolbox also including a detailed Simulink model for a quadrotor flying robot.

Advantages of the Toolbox are that:

  • the code is mature and provides a point of comparison for other implementations of the same algorithms;
  • the routines are generally written in a straightforward manner which allows for easy understanding, perhaps at the expense of computational efficiency. If you feel strongly about computational efficiency then you can always rewrite the function to be more efficient, compile the M-file using the MATLAB compiler, or create a MEX version;
  • since source code is available there is a benefit for understanding and teaching.

This Toolbox dates back to 1993 and significantly predates the Robotics Systems Toolbox® from MathWorks. The former is free, open and not supported, while the latter is a fully supported commercial product.

Code Example

>> mdl_puma560
>> p560
p560 = 

Puma 560 [Unimation]:: 6 axis, RRRRRR, stdDH, fastRNE            
 - viscous friction; params of 8/95;                             
+---+-----------+-----------+-----------+-----------+-----------+
| j |     theta |         d |         a |     alpha |    offset |
+---+-----------+-----------+-----------+-----------+-----------+
|  1|         q1|          0|          0|     1.5708|          0|
|  2|         q2|          0|     0.4318|          0|          0|
|  3|         q3|    0.15005|     0.0203|    -1.5708|          0|
|  4|         q4|     0.4318|          0|     1.5708|          0|
|  5|         q5|          0|          0|    -1.5708|          0|
|  6|         q6|          0|          0|          0|          0|
+---+-----------+-----------+-----------+-----------+-----------+
 
>> p560.fkine([0 0 0 0 0 0])  % forward kinematics
ans = 
         1         0         0    0.4521
         0         1         0     -0.15
         0         0         1    0.4318
         0         0         0         1

We can animate a path

Puma robot animation

mdl_puma560

p = [0.8 0 0];
T = transl(p) * troty(pi/2);
qr(1) = -pi/2;
qqr = p560.ikine6s(T, 'ru');
qrt = jtraj(qr, qqr, 50);

plot_sphere(p, 0.05, 'y');
p560.plot3d(qrt, 'view', ae, 'movie', 'move2ball.gif');

Quadrotor animation

Mobile robot lifting off and hovering over a point following a circular trajectory, while also slowly turning.

>> sl_quadrotor

Quadrotor animation

Mobile robot animation

Car-like mobile robot doing a 3-point turn computed using the Reeds-Shepp planner

Mobile robot particle filter animation

q0 = [0 0 0]'; % initial configuration [x y theta]
qf = [0 0 pi]'; % final configuration
maxcurv = 1/5;   % 5m turning circle
rs = ReedsShepp(q0, qf, maxcurv, 0.05)

% set up a vehicle model for animation
[car.image,~,car.alpha] = imread('car2.png');
car.rotation = 180; % degrees
car.centre = [648; 173]; % pix
car.length = 4.2; % m

% setup the plot
clf; plotvol([-4 8 -6 6])
a = gca;
a.XLimMode = 'manual';
a.YLimMode = 'manual';
set(gcf, 'Color', 'w')
grid on
a = gca;
xyzlabel

% now animate
plot_vehicle(rs.path, 'model', car, 'trail', 'r:', 'movie', '3point.gif');

Particle filter localization animation

Mobile robot localizing from beacons using a particle filter.

Mobile robot particle filter animation

V = diag([0.1, 1*pi/180].^2);
veh = Vehicle(V);
veh.add_driver( RandomPath(10) );
map = Map(20, 10);
W = diag([0.1, 1*pi/180].^2);
L = diag([0.1 0.1]);
Q = diag([0.1, 0.1, 1*pi/180]).^2;

pf = ParticleFilter(veh, sensor, Q, L, 1000, 'movie', 'pf.mp4');
pf.run(100);

A fully commented version of this is provided in the LiveScript demos/particlefilt.mlx.

What's new

  • Travis CI is now running on the code base
  • All code related to pose representation has been split out into the Spatial Math Toolbox. This repo is now a dependency.
  • SerialLink class has a twists method which returns a vector of Twist objects, one per joint. This supports the product of exponential formulation for forward kinematics and Jacobians.
  • a prototype URDF parser

Installation

Install from shared MATLAB Drive folder

This will work for MATLAB Online or MATLAB Desktop provided you have MATLAB drive setup.

  1. Click on the appropriate link below and an invitation to share will be emailed to the address associated with your MATLAB account:
  1. Accept the invitation.
  2. A folder named RVC1 or RVC2 will appear in your MATLAB drive folder.
  3. Use the MATLAB file browser and navigate to the folder RVCx/rvctools and double-click the script named startup_rvc.m

Note that this is a combo-installation that includes the Machine Vision Toolbox (MVTB) as well.

Install from github

You need to have a recent version of MATLAB, R2016b or later.

The Robotics Toolbox for MATLAB has dependency on two other GitHub repositories: spatial-math and toolbox-common-matlab.

To install the Toolbox on your computer from github follow these simple instructions.

From the shell:

mkdir rvctools
cd rvctools
git clone https://github.com/petercorke/robotics-toolbox-matlab.git robot
git clone https://github.com/petercorke/spatial-math.git smtb
git clone https://github.com/petercorke/toolbox-common-matlab.git common
make -C robot

The last command builds the MEX files and Java class files. Then, from within MATLAB

>> addpath rvctools/common  %  rvctools is the same folder as above
>> startup_rvc

The second line sets up the MATLAB path appropriately but it's only for the current session. You can either:

  1. Repeat this everytime you start MATLAB
  2. Add the MATLAB commands above to your startup.m file
  3. Once you have run startup_rvc, run pathtool and push the Save button, this will save the path settings for subsequent sessions.

Online resources:

Please email bug reports, comments or code contribtions to me at [email protected]

Contributors

Contributions welcome. There's a user forum at http://tiny.cc/rvcforum

License

This toolbox is released under GNU LGPL.

Other MATLAB toolboxes for robotics

More Repositories

1

robotics-toolbox-python

Robotics Toolbox for Python
Python
1,785
star
2

spatialmath-python

Create, manipulate and convert representations of position and orientation in 2D or 3D using Python
Python
294
star
3

machinevision-toolbox-matlab

Machine Vision Toolbox for MATLAB
MATLAB
194
star
4

spatialmath-matlab

Create, manipulate and convert representations of position and orientation in 2D or 3D using Python
MATLAB
187
star
5

bdsim

Simulate dynamic systems expressed in block diagram form using Python
HTML
154
star
6

RVC3-python

Code examples for Robotics, Vision & Control 3rd edition in Python
Jupyter Notebook
138
star
7

machinevision-toolbox-python

Machine vision toolbox for Python
Jupyter Notebook
109
star
8

RVC3-MATLAB

New toolbox, data and examples for Robotics, Vision & Control: 3rd edition in MATLAB
MATLAB
68
star
9

toolbox-common-matlab

Common code for MATLAB toolboxes for Robotics, Machine Vision
MATLAB
56
star
10

rvc-notation

RVC notation
TeX
19
star
11

ansitable

Quick, easy and pretty display of tabular data or matrices, with optional ANSI color and borders
Python
14
star
12

pgraph-python

Simple graph classes
Python
14
star
13

simple-threads-coder

A simple POSIX threading library for MATLAB Coder
C
9
star
14

help2doc

Convert MATLAB source files to various documentation formats
Python
4
star
15

petercorke.github.io

Static web pages
3
star
16

tkbibtex

Simple python/tk graphical browser/editor for BibTeX files
Shell
2
star
17

pybib

Python class to parse/sort/filter bibtex files
Python
2
star
18

RVC3-test

For testing MATLAB Online access to GH based toolboxes and scripts
MATLAB
2
star
19

plane-catcher

Log aircraft flying low and loud over Brisbane's Western suburbs
Python
1
star