-
If installing in a virtual machine:
- Bear in mind that Torch doesn't support Debian at the moment. Ubuntu (latest) is recommended.
- Choose the 32- or 64-bit OS version that you want to target. If you don't know, use 64-bit.
- Provide at least 4GB of memory and 20GB of virtual disk space.
-
Install dependencies.
-
On Ubuntu 15.10:
sudo apt-get install build-essential git cmake cmake-qt-gui libboost-all-dev libpython2.7-dev lua5.1 liblua5.1-0-dev openjdk-8-jdk swig xsdcxx libxerces-c-dev doxygen xsltproc ffmpeg python-tk python-imaging-tk
export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64/
sudo update-ca-certificates -f
(http://stackoverflow.com/a/29313285/126823) -
On Ubuntu 14.04:
sudo apt-get install build-essential git cmake cmake-qt-gui libboost-all-dev libpython2.7-dev lua5.1 liblua5.1-0-dev openjdk-7-jdk swig libxerces-c-dev doxygen xsltproc libav-tools python-tk python-imaging-tk libbz2-dev
export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64/
sudo update-ca-certificates -f
(http://stackoverflow.com/a/29313285/126823) -
On Debian 8:
sudo apt-get install build-essential git cmake cmake-qt-gui libboost-all-dev libpython2.7-dev lua5.1 liblua5.1-0-dev openjdk-7-jdk swig xsdcxx libxerces-c-dev doxygen xsltproc libav-tools python-tk python-imaging-tk
export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64/
sudo update-ca-certificates -f
(http://stackoverflow.com/a/29313285/126823) -
On Debian 7:
sudo apt-get install build-essential git cmake cmake-qt-gui libbz2-dev python2.7-dev lua5.1 liblua5.1-0-dev openjdk-7-jdk swig libxerces-c-dev doxygen xsltproc ffmpeg python-tk python-imaging-tk
export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64/
Also, remove Java 6 and make sure that
java -version
returns the right version (1.7).sudo update-ca-certificates -f
(http://stackoverflow.com/a/29313285/126823) -
On Fedora 23:
su -c 'dnf install http://download1.rpmfusion.org/free/fedora/rpmfusion-free-release-$(rpm -E %fedora).noarch.rpm http://download1.rpmfusion.org/nonfree/fedora/rpmfusion-nonfree-release-$(rpm -E %fedora).noarch.rpm'
(for ffmpeg)sudo dnf install git cmake cmake-gui boost-devel python-devel java-1.8.0-openjdk-devel swig xsd xerces-c-devel doxygen libxslt ffmpeg gcc-c++ mono-devel compat-lua compat-lua-devel lua-socket-compat tkinter python-pillow-tk
-
On Arch Linux:
sudo pacman -S --needed git cmake python2 tk jdk8-openjdk swig xsd xerces-c doxygen libxslt ffmpeg gcc mono lua51 lua51-socket
Install the following AUR packages:
luabind-rpavlik-git boost-build torch7-git torch7-trepl-git
(Skip to step 9) -
On CentOS 7:
sudo rpm --import http://li.nux.ro/download/nux/RPM-GPG-KEY-nux.ro
sudo rpm -Uvh http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noarch.rpm
(for ffmpeg)sudo yum install git cmake cmake-gui boost-devel python-devel java-1.8.0-openjdk-devel swig xerces-c-devel doxygen libxslt ffmpeg ffmpeg-devel gcc-c++ lua lua-devel bzip2-devel tkinter python-pillow-tk
-
-
Install Torch: (if supported by your platform)
- Follow the instructions at http://torch.ch/docs/getting-started.html
- Test:
th
-
Install Mono: (if not Fedora or Arch Linux)
- The Mono Project has an excellent Getting Started guide, please read it.
- For the impatient, Linux details are here
-
On Debian 7 only: Build Boost
mkdir ~/boost
cd ~/boost
wget http://sourceforge.net/projects/boost/files/boost/1.60.0/boost_1_60_0.tar.gz
tar xvf boost_1_60_0.tar.gz
cd boost_1_60_0
./bootstrap.sh --prefix=.
./b2 link=static cxxflags=-fPIC install
-
On Debian 7, CentOS 7 and Ubuntu 14.04 only: Install CodeSynthesis XSD:
- For Debian and Ubuntu:
wget http://www.codesynthesis.com/download/xsd/4.0/linux-gnu/x86_64/xsd_4.0.0-1_amd64.deb
- (Use
http://codesynthesis.com/download/xsd/4.0/linux-gnu/i686/xsd_4.0.0-1_i386.deb
if installing on a 32 bit machine)
- (Use
sudo dpkg -i --force-all xsd_4.0.0-1_amd64.deb
- (Use
sudo dpkg -i --force-all xsd_4.0.0-1_i386.deb
on a 32 bit machine)
- (Use
sudo apt-get install -f
- For CentOS:
wget http://www.codesynthesis.com/download/xsd/4.0/linux-gnu/x86_64/xsd-4.0.0-1.x86_64.rpm
sudo rpm -i --force xsd-4.0.0-1.x86_64.rpm
This step is needed because we require xsd version 4.0.
(When mono-devel is updated, you will need to manually remove then reinstall xsd as above, because of the package conflicts.) - For Debian and Ubuntu:
-
Install Luabind:
git clone https://github.com/rpavlik/luabind.git ~/rpavlik-luabind
cd rpavlik-luabind
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Release ..
On Debian 7 only:
cmake -DBoost_INCLUDE_DIR=/home/$USER/boost/boost_1_60_0/include -DCMAKE_BUILD_TYPE=Release ..
On Arch Linux only:cmake -DLUA_INCLUDE_DIR=/usr/include/lua5.1/ -DCMAKE_BUILD_TYPE=Release ..
make
- Test:
ctest
(A few of the tests fail currently but this doesn't seem to affect us.)
-
Install Lua dependencies:
sudo apt-get install luarocks
sudo luarocks install luasocket
-
Install ALE: (optional - skip this if you don't want to provide ALE support)
git clone https://github.com/mgbellemare/Arcade-Learning-Environment.git ~/ALE
- If you want a GUI, you need to install SDL:
sudo apt-get install libsdl1.2-dev
(sudo dnf install SDL-devel zlib-devel
on Fedora,sudo pacman -S sdl zlib
on Arch Linux) cd ~/ALE
git checkout ed3431185a527c81e73f2d71c6c2a9eaec6c3f12 .
cmake -DUSE_SDL=ON -DUSE_RLGLUE=OFF -DBUILD_EXAMPLES=ON -DCMAKE_BUILD_TYPE=RELEASE .
make
(If you don't want a GUI, use-DUSE_SDL=OFF
, or leave it unspecified - it's off by default.)- You will need to put ~/ALE on your LD_LIBRARY_PATH so that Malmo can find libAle.so:
Addexport LD_LIBRARY_PATH=$LD_LIBRARY_PATH:~/ALE/
to your ~/.bashrc
source ~/.bashrc
Note: To include ALE in your malmo build, add
-DINCLUDE_ALE=ON
to your cmake command in step 10. If you stored your ALE directory somewhere other than ~/ALE, also add-DROOT_ALE_DIR=/path/to/your/ALE
-
Install necessary Python dependencies:
- pip install future
- pip install pillow
-
Build Malmo:
git clone https://github.com/Microsoft/malmo.git ~/MalmoPlatform
wget https://raw.githubusercontent.com/bitfehler/xs3p/1b71310dd1e8b9e4087cf6120856c5f701bd336b/xs3p.xsl -P ~/MalmoPlatform/Schemas
- Add
export MALMO_XSD_PATH=~/MalmoPlatform/Schemas
to your~/.bashrc
and dosource ~/.bashrc
cd ~/MalmoPlatform
mkdir build
cd build
- For a Debug build:
cmake -DCMAKE_BUILD_TYPE=Debug ..
On Debian 7 only:
cmake -DBoost_INCLUDE_DIR=/home/$USER/boost/boost_1_60_0/include -DCMAKE_BUILD_TYPE=Debug ..
- For a Release build:
cmake -DCMAKE_BUILD_TYPE=Release ..
On Debian 7 only:
cmake -DBoost_INCLUDE_DIR=/home/$USER/boost/boost_1_60_0/include -DCMAKE_BUILD_TYPE=Release ..
make install
- You can then run the samples from e.g.
install/Python_Examples
-
Test Malmo:
ctest
ctest -E Integration
to exclude the integration tests.ctest -VV
to get verbose output.
-
Make a distributable:
- Run all the tests.
- Change the version number in CMakeLists.txt and Minecraft/src/main/java/com/microsoft/Malmo/MalmoMod.java, and commit.
cmake -DCMAKE_BUILD_TYPE=Release ..
make package
- Don't make a build directory or run cmake yet.
- Open KDevelop.
Project > Open/Import Project...
- Navigate to the git repo and open the root CMakeLists.txt file.
- Make a build folder for KDevelop4.
- Build and debug from within the KDevelop4 GUI.