Status: Archive (code is provided as-is, no updates expected)
DEPRECATED: Please use PyBullet instead
2019 September 27
- We are deprecating Roboschool and now recommend using PyBullet instead.
2017 July 17, Version 1.1
- All envs version bumped to “-v1", due to stronger stuck joint punishment, that improves odds of getting a good policy.
- Flagrun-v1 is much more likely to develop a symmetric gait,
- FlagrunHarder-v1 has new "repeat-underlearned" learning schedule, that allows it to be trained to stand up, walk and turn without falling.
- Atlas robot model, modified (empty links removed, overly powerful feet weakaned).
- All -v1 envs are shipped with better zoo policies, compared to May versions.
- Keyboard-controlled humanoid included.
Release blog post is here:
https://blog.openai.com/roboschool/
Roboschool is a long-term project to create simulations useful for research. The roadmap is as follows:
- Replicate Gym MuJoCo environments.
- Take a step away from trajectory-centric fragile MuJoCo tasks.
- Explore multiplayer games.
- Create tasks with camera RGB image and joints in a tuple.
- Teach robots to follow commands, including verbal commands.
Some wiki pages:
The list of Roboschool environments is as follows:
- RoboschoolInvertedPendulum-v1
- RoboschoolInvertedPendulumSwingup-v1
- RoboschoolInvertedDoublePendulum-v1
- RoboschoolReacher-v1
- RoboschoolHopper-v1
- RoboschoolWalker2d-v1
- RoboschoolHalfCheetah-v1
- RoboschoolAnt-v1
- RoboschoolHumanoid-v1
- RoboschoolHumanoidFlagrun-v1
- RoboschoolHumanoidFlagrunHarder-v1
- RoboschoolPong-v1
To obtain this list: import roboschool, gym; print("\n".join(['- ' + spec.id for spec in gym.envs.registry.all() if spec.id.startswith('Roboschool')]))
.
Roboschool is compatible and tested with python3 (3.5 and 3.6), osx and linux. You may be able to compile it with python2.7 (see Installation from source), but that may require non-trivial amount of work.
If you are running Ubuntu or Debian Linux, or OS X, the easiest path to install roboschool is via pip (:
pip install roboschool
Note: in a headless machine (e.g. docker container) you may need to install graphics libraries; this can be achieved via apt-get install libgl1-mesa-dev
If you are running some other Linux/Unix distro, or want the latest and the greatest code, or want to tweak the compiler optimization options, read on...
First, make sure you are installing from a github repo (not a source package on pypi). That is, clone this repo and cd into cloned folder:
git clone https://github.com/openai/roboschool && cd roboschool
The system-level dependencies of roboschool are qt5 (with opengl), boost-python3 (or boost-python if you are compiling with python2), assimp and cmake. Linux-based distros will need patchelf utility to tweak the runtime paths. Also, some version of graphics libraries is required. Qt5, assimp, cmake and patchelf are rather straightforward to install:
-
Ubuntu / Debian:
sudo apt-get install qtbase5-dev libqt5opengl5-dev libassimp-dev cmake patchelf
-
OSX:
brew install qt assimp cmake
Next, we'll need boost-python3. On osx brew install boost-python3
is usually sufficient, however, on linux it is not always available as a system-level package (sometimes it is available, but compiled against wrong version of python). If you are using anaconda/miniconda, boost-python3 can be installed via conda install boost
. Otherwise, do we despair? Of course not! We install it from source!
There is a script install_boost.sh
that should do most of the heavy lifting - note that it will need sudo
to install boost-python3 after compilation is done.
Next, need a custom version of bullet physics engine. In both osx and linux its installation is a little involved, fortunately, there is a
helper script install_bullet.sh
that should do it for you.
Finally, we also need to set up some environment variables (so that pkg-config knows where has the software been installed) - this can be done via sourcing exports.sh
script
To summarize, all the prerequisites can be installed as follows:
-
Ubuntu / Debian:
sudo apt-get install qtbase5 libqt5opengl5-dev libassimp-dev patchelf cmake ./install_boost.sh ./install_bullet.sh source exports.sh
-
Ubuntu / Debian with anaconda:
sudo apt-get install qtbase5 libqt5opengl5-dev libassimp-dev patchelf cmake conda install boost ./install_bullet.sh source exports.sh
-
OSX:
brew install qt assimp boost-python3 cmake ./install_bullet.sh source exports.sh
To check if that installation is successful, run pkg-config --cflags Qt5OpenGL assimp bullet
- you should see something resembling compiler options and not
an error message. Now we are ready to compile the roboschool project itself.
The compiler options are configured in the Makefile. Feel free to tinker with them or leave those as is. To compile the project code, and then install it as a python package, use the following:
cd roboschool/cpp-household && make clean && make -j4 && cd ../.. && pip install -e .
A simple check if resulting installation is valid:
import roboschool
import gym
env = gym.make('RoboschoolAnt-v1')
while True:
env.step(env.action_space.sample())
env.render()
You can also check the installation running a pretrained agent from the agent zoo, for instance:
python agent_zoo/RoboschoolHumanoidFlagrun_v0_2017may.py
A lot of the issues during installation from source are due to missing / incorrect PKG_CONFIG_PATH variable.
If the command pkg-config --cflags Qt5OpenGL assimp bullet
shows an error, you can try manually finding missing *.pc
files (for instance, for if the pkg-config
complains about assimp, run find / -name "assimp.pc"
- this is a bit bruteforce, but it works :)) and then adding folder with that files to PKG_CONFIG_PATH.
Sometime distros of linux may complain about generated code being not platform-independent, and ask you to recompile something with -fPIC
option (this was seen on older versions of CentOS). In that case, try removing -march=native
compilation option in the Makefile.
On the systems with nvidia drivers present, roboschool sometimes is not be able to find hardware-accelerated libraries. If you see errors like
.build-release/render-ssao.o: In function `SimpleRender::ContextViewport::_depthlinear_paint(int)':
/home/peter/dev/roboschool/roboschool/cpp-household/render-ssao.cpp:75: undefined reference to `glBindMultiTextureEXT'
/home/peter/dev/roboschool/roboschool/cpp-household/render-ssao.cpp:78: undefined reference to `glBindMultiTextureEXT'
collect2: error: ld returned 1 exit status
Makefile:130: recipe for target '../robot-test-tool' failed
you can try disabling hardware rendering by setting ROBOSCHOOL_DISABLE_HARDWARE_RENDER
env variable:
export ROBOSCHOOL_DISABLE_HARDWARE_RENDER=1
We have provided a number of pre-trained agents in the agent_zoo
directory.
To see a humanoid run towards a random varying target:
python agent_zoo/RoboschoolHumanoidFlagrun_v0_2017may.py
To see three agents in a race:
python agent_zoo/demo_race2.py