Mobile robot simulator
C++ TeX Perl SourcePawn CMake C Other
Latest commit 0a7eb63 Apr 27, 2017 @rtv committed on GitHub Merge pull request #80 from wjwwood/lib_location_and_relocatable
determine the location of the stage library using a generator expression
Permalink
Failed to load latest commit information.
assets assets: replace stall.png with a nice-looking warning icon (old png r… Feb 7, 2017
avonstage all: unify coding style using clang-format Mar 23, 2017
cmake/internal Do not install to lib64, even on x86_64 machines Apr 26, 2017
docsrc docs Dec 30, 2011
examples upgraded wander to search for a suitable ranger instead of hard-coded… Apr 26, 2017
libstage fixing abs ambiguity compiler error Apr 27, 2017
libstageplugin fixed blobfinder area reported by player (issue 41) Apr 26, 2017
replace all: unify coding style using clang-format Mar 23, 2017
tests/worldfile Merge remote branch 'upstream/master' Jun 19, 2010
worlds independent footprint/trail length for each model Apr 26, 2017
.clang-format all: unify coding style using clang-format Mar 23, 2017
.gitignore git: ignore CMakeLists.txt.user created by Qt Creator Feb 7, 2017
.travis.yml travis: change before_install to install directive Mar 22, 2017
AUTHORS.txt docs: add myself to the list of authors Feb 20, 2017
CMakeLists.txt Merge branch 'master' into lib_location_and_relocatable Apr 27, 2017
COPYING.txt Changed extensions Jul 11, 2008
DESCRIPTION.txt Changed extensions Jul 11, 2008
INSTALL.txt preparing version 4.1.0 release Dec 29, 2011
README.md docs: add build status (Travis badge) to README.md Mar 19, 2017
RELEASE.txt ticked version to 4.3.0 to exceed Adrian's release and avoid confusion Apr 27, 2017
config.h.in fixed up merge and changed version to 5.0 Apr 11, 2017
stage-config-version.cmake.in all: strip trailing whitespaces in entire source tree Feb 7, 2017
stage-config.cmake.in determine the location of the stage library using a generator expression Apr 27, 2017
stage.pc.in quote prefix in stage.pc.in Apr 27, 2017
todo.txt testing Nov 5, 2011

README.md

The Stage Simulator

This is the Stage README file, containing an introduction, license and citation information. Stage is a 2(.5)D robotics standalone simulator and can also be used as a C++ library to build your own simulation environment. Up-to-date documentation can be found here.

For release notes see RELEASE.txt For installation notes see INSTALL.txt

Copyright Richard Vaughan and contributors 1998-2011 Part of the Player Project (http://playerstage.org)

Build Status

License

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License version 2 as published by the Free Software Foundation.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

A copy of the license is included with the sourcecode in the file 'COPYING". Copying and redistribution is permitted only under the terms of the license.

Introduction

Stage is a robot simulator. It provides a virtual world populated by mobile robots and sensors, along with various objects for the robots to sense and manipulate.

There are three ways to use Stage:

  1. The "stage" program: a standalone robot simulation program that loads your robot control program from a library that you provide.
  2. The Stage plugin for Player (libstageplugin) - provides a population of virtual robots for the popular Player networked robot interface system.
  3. Write your own simulator: the "libstage" C++ library makes it easy to create, run and customize a Stage simulation from inside your own programs.

Models

Stage provides several sensor and actuator models, including sonar or infrared rangers, scanning laser rangefinder, color-blob tracking, fiducial tracking, bumpers, grippers and mobile robot bases with odometric or global localization.

Design

Stage was designed with multi-agent systems in mind, so it provides fairly simple, computationally cheap models of lots of devices rather than attempting to emulate any device with great fidelity. This design is intended to be useful compromise between conventional high-fidelity robot simulations, the minimal simulations described by Jakobi [4], and the grid-world simulations common in artificial life research [5]. We intend Stage to be just realistic enough to enable users to move controllers between Stage robots and real robots, while still being fast enough to simulate large populations. We also intend Stage to be comprehensible to undergraduate students, yet sophisticated enough for professional reseachers.

Player also contains several useful 'virtual devices'; including some sensor pre-processing or sensor-integration algorithms that help you to rapidly build powerful robot controllers. These are easy to use with Stage.

Citations

If you use Stage in your work, we'd appreciate a citation. At the time of writing, the most suitable reference is either:

  • Richard Vaughan. "Massively Multiple Robot Simulations in Stage", Swarm Intelligence 2(2-4):189-208, 2008. Springer, download PDF

Or, if you are using Player/Stage:

  • Brian Gerkey, Richard T. Vaughan and Andrew Howard. "The Player/Stage Project: Tools for Multi-Robot and Distributed Sensor Systems" Proceedings of the 11th International Conference on Advanced Robotics, pages 317-323, Coimbra, Portugal, June 2003 (ICAR'03), download PDF

Please help us keep track of what's being used out there by correctly naming the Player/Stage components you use. Player used on its own is called "Player". Player and Stage used together are referred to as "the Player/Stage system" or just "Player/Stage". When Stage is used without Player, it's just called "Stage". When the Stage library is used to create your own custom simulator, it's called "libstage" or "the Stage library". When Player is used with its 3D ODE-based simulation backend, Gazebo, it's called Player/Gazebo. Gazebo without Player is just "Gazebo". All this software is part of the "Player Project".

Support

Funding for Stage has been provided in part by:

  • DARPA (USA)
  • NASA (USA)
  • NSERC (Canada)
  • DRDC Suffield (Canada)
  • NSF (USA)
  • Simon Fraser University (Canada)

Names

The names "Player" and "Stage" were inspired by the lines:

All the world's a stage,
And all the men and women merely players

from "As You Like It" by William Shakespeare.

References

[4] Nick Jakobi (1997) "Evolutionary Robotics and the Radical Envelope of Noise Hypothesis", Adaptive Behavior Volume 6, Issue 2. pp.325 - 368.

[5] Stuart Wilson (1985) "Knowledge Growth in an Artificial Animal", Proceedings of the First International Conference on Genetic Agorithms and Their Applications. Hillsdale, New Jersey. pp.16-23.