Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/moveit/moveit_example_apps
Demonstrator applications for using MoveIt with full robotic setups
https://github.com/moveit/moveit_example_apps
Last synced: about 2 months ago
JSON representation
Demonstrator applications for using MoveIt with full robotic setups
- Host: GitHub
- URL: https://github.com/moveit/moveit_example_apps
- Owner: moveit
- License: bsd-3-clause
- Created: 2019-06-26T20:46:08.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-11-12T20:21:55.000Z (about 5 years ago)
- Last Synced: 2024-11-10T00:13:08.346Z (about 2 months ago)
- Language: Python
- Size: 3.01 MB
- Stars: 24
- Watchers: 24
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.rst
- License: LICENSE
Awesome Lists containing this project
README
# moveit_example_apps
This project demonstrates advanced applications for using MoveIt with full robotic setups. For each listed application, there is a tutorial introducing how to replicate and run the application either in simulation or with real robot. If you are interested in the technique details, you can visit [MoveIt Tutorials](https://ros-planning.github.io/moveit_tutorials/) for further information.
## Applications
| Application Name | Documentation | Docker |
| ---------------- | -----------------------| ------------------------------------------ |
| Random Pick | [random_pick_tutorial] | [moveit/moveit_example_apps:random_pick]() |[random_pick_tutorial]: https://roboticsyy.github.io/moveit_example_apps/doc/random_pick/random_pick.html
## Continuous Integration
[![Build Status](https://travis-ci.org/ros-planning/moveit_example_apps.svg?branch=master)](https://travis-ci.org/ros-planning/moveit_example_apps)
## Contributing
There are many diverse application examples of what you can use MoveIt for. Your contribution is encouraged, no matter the application is developed for some usages, competitions or research topics, or to demonstrate the newly developed MoveIt feature.
If you are interested in adding a new MoveIt application in this project, please consider following the below instructions.
### Directory Structure
For each example application, it should contain two parts: example codes and tutorials.
* The example codes of each application should live in its own subdirectory in the `./examples/` directory.
* Under `./examples/` directory, there should be two packages: `` and ``.
* Refer to the example below for how the structure of `./examples/` directory would look like:```
moveit_example_apps/examples/
└── /
├── /
| ├── control/ # Launch and config files of controllers
| ├── gazebo/ # Gazebo launch files
| ├── launch/ # Demo launch files
| ├── rviz/ # Rviz config files
| ├── scripts/ # Python files
| ├── data/ # Custom simulation data
| | └── .pcd
| ├── include/ # Header files
| | └── .h
| ├── src/ # Source files
| | └── .cpp
| ├── urdf/ # URDF and mesh files
| ├── CMakeLists.txt
| ├── package.xml
| └── README.md
└── / # Custom moveit_config package
```* The tutorials build with [rosdoc_lite](http://wiki.ros.org/rosdoc_lite) and [Sphinx](http://wiki.ros.org/Sphinx) builder. Each tutorial should live in its own subdirectory under the `./tutorials/doc/` directory.
* Each tutorial should use the [reStructuredText](http://www.sphinx-doc.org/en/stable/rest.html) format and follow the structure of `./tutorials/doc/template.rst`.
* Add your tutorial file name to `./tutorials/index.rst`.
* Refer to the example below for how the structure of `./tutorials` directory would look like:```
moveit_example_apps/tutorials/
├── _static/
├── doc/
| ├── /
| | ├── images/ # Screen shots of app outputs
| | └── .rst # Custom app tutorial
| └── template.rst # App tutorial template
├── index.rst # Entry file of moveit_example_apps' tutorials
├── conf.py
├── build_locally.sh
├── rosdoc.yaml
├── README.md
├── CMakeLists.txt
└── package.xml
```### CI Test
In order to guarantee a successful compilation and running at others' side, it is necessary to make the application continuously tested. The application contributor can consider providing the following components as what `random_pick` did to enable moveit_ci to the application:
- `.docker/random_pick/Dockerfile`: for setting up the dependencies of external libraries, which overlay on moveit/moveit:master-source.
- `.rosinstall/random_pick/random_pick.rosinstall`: for the source dependencies required to be built in the catkin workspace.
- `.travis/random_pick/before_script.sh`: for setting up the environment variables and directory path of dependencies in the docker container.
- A custom docker image, built from the docker file. Perhaps this image can be tagged as `moveit/moveit_example_apps:random_pick`.