(Switch to: Lua · Python · Level Generation · Tensor · Text Levels · Build · Known Issues)
DeepMind Lab uses Bazel as its build system. Its main
BUILD
file defines a number of build targets and their dependencies. The
build rules should work out of the box on Debian (Jessie or newer) and Ubuntu
(version 14.04 or newer), provided the required packages are installed.
DeepMind Lab also builds on other Linux systems, but some changes to the build
files might be required, see below.
DeepMind Lab is written in C99 and C++11, and you will need a sufficiently modern compiler. GCC 4.8 should suffice.
Tested on Debian 8.6 (Jessie) and Ubuntu 14.04 (Trusty) and newer.
-
Install Bazel by adding a custom APT repository, as described on the Bazel homepage or using an installer. This should also install GCC and zip.
-
Install DeepMind Lab's dependencies:
$ sudo apt-get install lua5.1 liblua5.1-0-dev libffi-dev gettext \ freeglut3-dev libsdl2-dev libosmesa6-dev python-dev python-numpy realpath
-
Build DeepMind Lab and run a random agent:
$ cd lab # Build the Python interface to DeepMind Lab with OpenGL lab$ bazel build :deepmind_lab.so --define headless=glx # Build and run the tests for it lab$ bazel run :python_module_test --define headless=glx # Rebuild the Python interface in non-headless mode and run a random agent lab$ bazel run :random_agent --define headless=false
The Bazel target :deepmind_lab.so
builds the Python module that interfaces
DeepMind Lab. It can be build in headless hardware rendering mode (--define headless=glx
), headless software rendering mode (--define headless=osmesa
) or
non-headless mode (--define headless=false
).
The random agent target :random_agent
has a number of optional command line
arguments. Run
lab$ bazel run :random_agent -- --help
to see those.
Tested on Ubuntu 16.10 (yakkety).
-
Install Bazel by adding a custom APT repository, as described on the Bazel homepage or using an installer. This should also install GCC and zip.
-
Install DeepMind Lab's dependencies:
$ sudo apt-get install lua5.1 liblua5.1-0-dev libffi-dev gettext \ freeglut3-dev libsdl2-dev libosmesa6-dev python3-dev python3-numpy realpath
-
Edit
python3.BUILD
so it maps to the correct python version (defaults to 3.5). Specifically, change lines 8 and 9 to point to "include/python". -
Build DeepMind Lab and run a random agent:
$ cd lab # Build the Python interface to DeepMind Lab with OpenGL lab$ bazel build :deepmind_lab_py3.so --define headless=glx # Build and run the tests for it lab$ bazel run :python3_module_test --define headless=glx # Rebuild the Python interface in non-headless mode and run a random agent lab$ bazel run :random_agent_py3 --define headless=false
The Bazel target :deepmind_lab_py3.so
builds the Python module that interfaces
DeepMind Lab. It can be build in headless hardware rendering mode (--define headless=glx
), headless software rendering mode (--define headless=osmesa
) or
non-headless mode (--define headless=false
).
The random agent target :random_agent_py3
has a number of optional command line
arguments. Run
lab$ bazel run :random_agent_py3 -- --help
to see those.
Tested on release 7.2 (Maipo).
-
Add the Extra Packages as described on fedoraproject.org
-
Install Bazel's and DeepMind Lab's dependencies
sudo yum -y install unzip java-1.8.0-openjdk lua lua-devel libffi-devel zip \ java-1.8.0-openjdk-devel gcc gcc-c++ freeglut-devel SDL2 SDL2-devel \ mesa-libOSMesa-devel python-devel numpy
-
Download and run a Bazel binary installer, e.g.
sudo yum -y install wget wget https://github.com/bazelbuild/bazel/releases/download/0.3.2/bazel-0.3.2-installer-linux-x86_64.sh sh bazel-0.3.2-installer-linux-x86_64.sh
-
Edit
lua.BUILD
to reflect how Lua is installed on your system:cc_library( name = "lua", linkopts = ["-llua"], visibility = ["//visibility:public"], )
The output of
pkg-config lua --libs --cflags
might be helpful to find the right include folders and linker options. -
Build DeepMind Lab using Bazel as above.
Tested on SUSE Linux Enterprise Server 12.
-
Install Bazel's and DeepMind Lab's dependencies
sudo zypper --non-interactive install java-1_8_0-openjdk \ java-1_8_0-openjdk-devel gcc gcc-c++ lua lua-devel python-devel \ python-numpy-devel libSDL-devel libOSMesa-devel freeglut-devel
-
Download and run a Bazel binary installer, e.g.
sudo yum -y install wget wget https://github.com/bazelbuild/bazel/releases/download/0.3.2/bazel-0.3.2-installer-linux-x86_64.sh sh bazel-0.3.2-installer-linux-x86_64.sh
-
Edit
lua.BUILD
to reflect how Lua is installed on your system:cc_library( name = "lua", linkopts = ["-llua"], visibility = ["//visibility:public"], )
The output of
pkg-config lua --libs --cflags
might be helpful to find the right include folders and linker options. -
Edit
python.BUILD
to reflect how Python is installed on your system:cc_library( name = "python", hdrs = glob([ "include/python2.7/*.h", "lib64/python2.7/site-packages/numpy/core/include/**/*.h", ]), includes = [ "include/python2.7", "lib64/python2.7/site-packages/numpy/core/include", ], visibility = ["//visibility:public"], )
The outputs of
rpm -ql python
andrpm -ql python-numpy-devel
might be helpful to find the rihgt include folders. -
Build DeepMind Lab using Bazel as above.