Metadata-Version: 2.1
Name: gym-ignition
Version: 1.0b2
Summary: Gym-Ignition: A toolkit for developing OpenAI Gym environments simulated with Ignition Gazebo.
Home-page: https://github.com/robotology/gym-ignition
Author: Diego Ferigo
Author-email: diego.ferigo@iit.it
License: LGPL
Description: <p align="center">
        <h1 align="center">gym-ignition</h1>
        </p>
        
        <p align="center">
        <b><a href="https://github.com/robotology/gym-ignition#what">What</a></b>
        •
        <b><a href="https://github.com/robotology/gym-ignition#why">Why</a></b>
        •
        <b><a href="https://github.com/robotology/gym-ignition#how">How</a></b>
        •
        <b><a href="https://github.com/robotology/gym-ignition#demo">Demo</a></b>
        •
        <b><a href="https://github.com/robotology/gym-ignition#setup">Setup</a></b>
        •
        <b><a href="https://github.com/robotology/gym-ignition#Citation">Citation</a></b>
        </p>
        
        <div align="center">
        <p><br/></p>
        <table>
            <tbody>
                 <tr>
                    <td align="left">General</td>
                    <td align="center">
                        <a href="https://isocpp.org">
                        <img src="https://img.shields.io/badge/standard-C++17-blue.svg?style=flat&logo=c%2B%2B" alt="C++ Standard" />
                        </a>
                        <a href="https://github.com/robotology/gym-ignition">
                        <img src="https://img.shields.io/github/languages/code-size/robotology/gym-ignition.svg" alt="Size" />
                        </a>
                        <a href="https://github.com/robotology/gym-ignition/blob/master/LICENSE">
                        <img src="https://img.shields.io/badge/license-LGPL-19c2d8.svg" alt="Size" />
                        </a>
                    </td>
                </tr> 
                 <tr>
                    <td align="left">CI/CD</td>
                    <td align="center">
                        <a href="https://github.com/robotology/gym-ignition/actions">
                        <img src="https://github.com/robotology/gym-ignition/workflows/Docker%20Images/badge.svg" alt="Docker Images" />
                        </a>
                        <a href="https://github.com/robotology/gym-ignition/actions">
                        <img src="https://github.com/robotology/gym-ignition/workflows/CI/badge.svg" alt="CI" />
                        </a>
                        <a href="https://github.com/robotology/gym-ignition/actions">
                        <img src="https://github.com/robotology/gym-ignition/workflows/PyPI%20CD/badge.svg" alt="PyPI CD" />
                        </a>
                        <a href="https://www.codacy.com/app/diegoferigo/gym-ignition?utm_source=github.com&amp;utm_medium=referral&amp;utm_content=diegoferigo/gym-ignition&amp;utm_campaign=Badge_Grade">
                        <img src="https://api.codacy.com/project/badge/Grade/899a7c8304e14ed9b2330eb309cdad15" alt="Codacy Badge" />
                        </a>
                    </td>
                </tr>   
                <tr>
                    <td align="left"><code>gym-ignition</code></td>
                    <td align="center">
                        <a href="https://pypi.org/project/gym-ignition/">
                        <img src="https://img.shields.io/pypi/v/gym-ignition.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition/">
                        <img src="https://img.shields.io/pypi/pyversions/gym-ignition.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition/">
                        <img src="https://img.shields.io/pypi/status/gym-ignition.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition/">
                        <img src="https://img.shields.io/pypi/format/gym-ignition.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition/">
                        <img src="https://img.shields.io/pypi/l/gym-ignition.svg" />
                        </a>
                    </td>
                </tr>
                <tr>
                    <td align="left"><code>gym-ignition-nightly</code></td>
                    <td align="center">
                        <a href="https://pypi.org/project/gym-ignition-nightly/">
                        <img src="https://img.shields.io/pypi/v/gym-ignition-nightly.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition-nightly/">
                        <img src="https://img.shields.io/pypi/pyversions/gym-ignition-nightly.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition-nightly/">
                        <img src="https://img.shields.io/pypi/status/gym-ignition-nightly.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition-nightly/">
                        <img src="https://img.shields.io/pypi/format/gym-ignition-nightly.svg" />
                        </a>
                        <a href="https://pypi.org/project/gym-ignition-nightly/">
                        <img src="https://img.shields.io/pypi/l/gym-ignition-nightly.svg" />
                        </a>
                    </td>
                </tr>
            </tbody>
        </table>
        <p><br/></p>
        </div>
        
        ## What
        
        Gym-Ignition provides the capability of creating **reproducible robotics environments** for reinforcement learning research.
        
        The project is composed of the following components:
        
        | Component                                     | Description                                                  |
        | --------------------------------------------- | ------------------------------------------------------------ |
        | [**`ignition`**](ignition/)                   | A set of classes to interface `gympp` with the new Ignition Gazebo simulator, part of the [Ignition Robotics](http://ignitionrobotics.org) suite. |
        | [**`plugins`**](plugins/)                     | Ignition Gazebo plugins.                                     |
        | [**`gym_ignition`**](gym_ignition/)           | Python package for creating OpenAI Gym environments. Environments can be implemented either in C++ using `gympp` or in Python using the SWIG binded classes of the `ignition` component. |
        | [**`gym_ignition_data`**](gym_ignition_data/) | SDF and URDF models and Gazebo worlds.                       |
        | [**`gympp`**](gympp/)                         | An _experimental_ C++ port of the OpenAI [Gym interfaces](https://github.com/openai/gym/tree/master/gym), used to create pure C++ environments. |
        
        ## Why
        
        Refer to the [Citation](#citation) for the extended rationale behind this project.
        
        `TL;DR`
        
        We designed Gym-Ignition driven by the following reasons:
        
        - Advances in RL research are pushed by the development of more complex environments, and vice versa.
        - There's no standard framework in the robotics community for creating simulated robotic environments.
        - Environments that can be transferred from simulation to reality with minimal changes do not exist.
        - Alternative solutions are not developed by roboticists for roboticist, and therefore they do not use familiar tools.
        - Existing robotics environments are typically difficult to adapt to run on different physics engines and different robots.
        - Only few solutions offer realistic rendering capabilities.
        
        ## How
        
        This project interfaces with the new generation of the [Gazebo](http://gazebosim.org) simulator, called [Ignition Gazebo](https://ignitionrobotics.org/libs/gazebo).
        It is part of the new [Ignition Robotics](http://ignitionrobotics.org) suite developed by [Open Robotics](https://www.openrobotics.org/).
        
        Ignition Robotics is currently under heavy development.
        Though, it already offers enough functionalities for this project's aims:
        
        - Simulator-as-a-library
        - New modular architecture
        - C++ utilities developed with a robotic mindset
        - New abstractions of physics engines and rendering engines that exploit runtime plugins
        - Full support of [DART](https://github.com/dartsim/dart) and coming support of [bullet3](https://github.com/bulletphysics/bullet3)
        - Support of distributed simulations
        - Well maintained and packaged
        - [Ignition Fuel](https://app.ignitionrobotics.org/dashboard) database to download models and worlds
        
        ### Features
        
        At the time of writing, Gym-Ignition offers the following features:
        
        - Environments compatible with [OpenAI Gym](https://github.com/openai/gym/)
        - Worlds and models are [SDF descriptions](http://sdformat.org)
        - Reproducibility guarantees
        - Accelerated and multiprocess execution
        - Environments are a combination of three elements:
          - **Task**: the logic of the decision-making problem. It defines how to process the given action, how to calculate the reward, how to structure the observation, and how to reset the environment. Task objects are robot-independent and runtime-independent.
          - **Robot**: unified interface to access to robot resources. It is used to gather data and send commands to either simulated or real robot in a seamless way.
          - **Runtime**: implements the actual step of the environment. Simulated runtimes step the simulator, real-time runtimes deal with real-time execution constraints. A Task object can be executed by any runtime without any change.
        - Experimental support to create C++ environments
        
        ## Demo
        
        We provide two different methods to test Gym-Ignition without the need to install it locally:
        
        1. **Colab notebook**: [![](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/robotology/gym-ignition/blob/master/examples/colab/RandomPolicy.ipynb) and run the example
        1. **Docker image**:
           ```sh
           docker pull diegoferigo/gym-ignition:latest
           pip3 install rocker
           
           # Intel GPU
           rocker --devices /dev/dri --x11 diegoferigo/gym-ignition /github/examples/python/launch_cartpole.py
           
           # Nvidia GPU
           rocker --x11 --nvidia diegoferigo/gym-ignition /github/examples/python/launch_cartpole.py
           ```
        
        ## Setup
        
        The setup instructions expect a **Ubuntu** distribution with at least **Python 3.6**.
        Gym-Ignition is compatible also with other distributions (and, also, other OSs) under the assumption that the Ignition Robotics suite can be installed either from repos or source.
        Though, to keep the instructions simple, we only list the steps for Ubuntu Bionic 18.04.
        
        We follow the policy of supporting the most recent Ubuntu LTS distribution, excluding the periods close to a new release. Old LTS distribution are no longer officially supported as soon as the the first minor release of the new LTS becomes available.
        
        The process is different whether you're an _user_ that wants to create environments using Gym-Ignition or you are a _developer_ that wants to edit the Python and C++ upstream code.
        
        Execute all the setup commands in the same terminal.
        
        #### Common Steps
        
        1. Install the LTS version of **Ignition Gazebo** (Citadel):
        
           ```sh
           sudo sh -c 'echo "deb http://packages.osrfoundation.org/gazebo/ubuntu-stable `lsb_release -cs` main" > /etc/apt/sources.list.d/gazebo-stable.list'
           wget http://packages.osrfoundation.org/gazebo.key -O - | sudo apt-key add -
           sudo apt update
           sudo apt install ignition-citadel
           ```
        
           Refer to the [official documentation](https://ignitionrobotics.org/docs/citadel/install) for more detailed information.
           
        1. Create a Python [virtual environment](https://docs.python.org/3.6/tutorial/venv.html) as follows:
           ```sh
           sudo apt install virtualenv
           virtualenv -p python3.6 $HOME/venv
           source $HOME/venv/bin/activate
           ```
        
        ### User setup
        
        1. `pip3 install gym-ignition`
        
        You can now download and run the example [`launch_cartpole.py`](examples/python/launch_cartpole.py).
        
        ### Developer setup
        
        1. Update CMake using the [official PPA](https://apt.kitware.com/) if you have a version older than 3.12
           
        1. Install gcc 8 with `apt install gcc-8 g++-8`.
           Export the following environment variables to enable it temporarily:
        
           ```sh
           export CC=gcc-8
           export CXX=g++-8
           ```
        
        1. Install [SWIG](https://github.com/swig/swig) with `apt install swig`
        
        1. Optionally install [iDynTree](https://github.com/robotology/idyntree) with enabled Python bindings
        
        1. Clone this repository
        
        1. Build and install the CMake project
           ```sh
           cd gym-ignition
           mkdir build
           cd build
           cmake -DCMAKE_INSTALL_PREFIX=<installprefix> ..
           cmake --build .
           cmake --build . --target install
           ```
           
           Where `<installprefix>` is the destination of the CMake project. It can either be a system or user folder. The default is `/usr/local`. 
           
        1. Install the Python package in [editable mode](https://pip.pypa.io/en/stable/reference/pip_install/#editable-installs):
           ```sh
           cd ..
           pip3 install -e .
           ```
           
        1. Export the following environment variable:
           ```sh
           # C++ bindings
           export PYTHONPATH=<installprefix>/lib/python3.6/site-packages
           ```
        
        After these steps, you can run the [cartpole example](examples/python/launch_cartpole.py) executing:
        
         ```sh
         python3 /path/to/gym-ignition-repo/examples/python/launch_cartpole.py
         ```
        
        ### Unstable builds
        
        Gym-Ignition still doesn't have a steady release cycle strategy.
        This project targets mainly research, and its development is very active.
        In order to quickly deliver new features, we do our best to have a fast release cycle.
        
        If you find interesting [PRs](https://github.com/robotology/gym-ignition/pulls) that are not yet included in the [most recent release](https://github.com/robotology/gym-ignition/releases), you can get the latest unstable version as follows:
        
        1. **User installation**: `pip3 install gym-ignition-nightly`
        
        1. **Developer installation**: check-out the `devel` branch after cloning the repository in step 4 and follow the remaining steps
        
        ## Citation
        
        ```
        @INPROCEEDINGS{ferigo2020gymignition,
            title={Gym-Ignition: Reproducible Robotic Simulations for Reinforcement Learning},
            author={D. {Ferigo} and S. {Traversaro} and G. {Metta} and D. {Pucci}},
            booktitle={2020 IEEE/SICE International Symposium on System Integration (SII)},
            year={2020},
            pages={885-890},
            doi={10.1109/SII46433.2020.9025951}
        } 
        ```
        
        ---
        
        **Disclaimer:** Gym-Ignition is an independent project and is not related by any means to OpenAI and Open Robotics.
        
Keywords: openai gym reinforcement learning environment gazebo robotics ignition
Platform: any
Classifier: Development Status :: 4 - Beta
Classifier: Operating System :: POSIX :: Linux
Classifier: Topic :: Games/Entertainment :: Simulation
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Classifier: Framework :: Robot Framework
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: Programming Language :: C++
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: License :: OSI Approved :: GNU General Public License v2 or later (GPLv2+)
Requires-Python: >=3.6
Description-Content-Type: text/markdown
