\section{Compiling the renderer} \label{sec:compiling} To compile Mitsuba, you will need a recent C++ compiler (e.g. GCC 4.2+ or Visual Studio 2010) and some additional libraries, which Mitsuba uses internally. Builds on all supported platforms are done using a unified system based on SCons (\url{http://www.scons.org}), which is a Python-based software construction tool. The exact process is different depending on which operating system is used and will be explained in the following subsections. \subsection{Common steps} To get started, you will need to download a recent version of the Mitsuba source code. Before doing this, ensure that you have read the licensing agreement (Section~\ref{sec:license}), and that you abide by its contents. Note that, being a ``viral'' license, the GPL automatically applies to derivative work. Amongst other things, this means that Mitsuba's source code is \emph{off-limits} to those who develop rendering software not distributed under a compatible license. Check that the Mercurial (\url{http://mercurial.selenic.com/}) versioning system\footnote{On Windows, you might want to use the convenient TortoiseHG shell extension (\url{http://tortoisehg.bitbucket.org/}) to run the subsequent steps directly from the Explorer.} is installed, which is required to fetch the most recent source code release. Begin by entering the following at the command prompt (or run an equivalent command from a graphical Mercurial frontend): \begin{shell} $\texttt{\$}$ hg clone https://www.mitsuba-renderer.org/hg/mitsuba \end{shell} This should dowload a full copy of the main repository. \subsubsection{Build configurations} Common to all platforms is that a build configuration file must be selected. Several options are available on each operating system: \paragraph{Linux:} On Linux, there are two supported configurations: \begin{description} \item[\code{build/config-linux-gcc.py}:] Optimized single precision GCC build. The resulting binaries include debug symbols for convenience, but these can only be used for relatively high-level debugging due to the enabled optimizations. \item[\code{build/config-linux-gcc-debug.py}:] Non-optimized single precision GCC build with debug symbols. When compiled with this configuration, Mitsuba will run extremely slowly. Its main use is to track down elusive bugs. \end{description} \paragraph{Windows:} On Windows, builds can either be performed using the Visual Studio 2010\footnote{No other Visual Studio versions are currently supported.} compiler or Intel XE Composer (on top of Visual Studio 2010). Note that Visual Studio 2010 Service Pack 1 \emph{must} be installed or the resulting binaries will crash. \begin{description} \item[\code{build/config-\{win32, win64\}-\{msvc2010, msvc2010-debug\}.py}:] Create 32 or 64 bit binaries using Microsoft Visual C++ version 2010. The configurations with the suffix \code{-debug} will include debug symbols in all binaries, which run very slowly. \item[\code{build/config-\{win32, win64\}-icl.py}:] Create 32 or 64 bit release binaries using Intel XE Composer (on top of Visual Studio 2010). Versions XE 2012 and 2013 are known to work. \end{description} \paragraph{Mac OS:} On Mac OS, builds can either be performed using the the XCode 4 \code{llvm-gcc} toolchain or Intel XE Composer. It is possible to target MacOS 10.6 (Snow Leopard) or 10.7 (Lion) as the oldest supported operating system release. In both cases, XCode must be installed along with the supplementary command line tools. \begin{description} \item[\code{config-macos\{10.6, 10.7\}-gcc-\{x86,x86\_64,universal\}.py}:] Create Intel 32 bit, 64 bit, or universal binaries using the \code{llvm-gcc} toolchain. \item[\code{config-macos\{10.6, 10.7\}-icl-\{x86,x86\_64\}.py}:] Create Intel 32 bit or 64 bit binaries using the Intel XE Composer toolchain. Versions XE 2012 and 2013 are known to work. \end{description} Note that the configuration files assume that XCode was installed in the \code{/Applications} folder. They must be be manually updated when this is not the case. \subsubsection{Selecting a configuration} Having chosen a configuration, copy it to the main directory and rename it to \code{config.py}, e.g.: \begin{shell} $\texttt{\$}$ cp build/config-linux-gcc.py config.py \end{shell} \subsection{Compilation flags} \label{sec:compiling-flags} There are several flags that affect the behavior of Mitsuba and must be specified at compile time. These usually don't need to be changed, but if you want to compile Mitsuba for spectral rendering, or to use double precision for internal computations then the following may be useful. Otherwise, you may skip ahead to the subsection that covers your operating system. To change the compilation flags, open the \code{config.py} file that was just copied and look up the \code{CXXFLAG} parameter. The following options are available: \begin{description} \item[\texttt{MTS\_DEBUG}] Enable assertions etc. Usually a good idea, and enabled by default (even in release builds). \item[\texttt{MTS\_KD\_DEBUG}] Enable additional checks in the kd-tree. This is quite slow and mainly useful to track down bugs when they are suspected. \item[\texttt{MTS\_KD\_CONSERVE\_MEMORY}] Use a more compact representation for triangle geometry (at the cost of speed). This flag causes Mitsuba to use the somewhat slower Moeller-Trumbore triangle intersection method instead of the default Wald intersection test, which has an overhead of 48 bytes per triangle. Off by default. \item[\texttt{MTS\_SSE}]Activate optimized SSE routines. On by default. \item[\texttt{MTS\_HAS\_COHERENT\_RT}]Include coherent ray tracing support (depends on \texttt{MTS\_SSE}). This flag is activated by default. \item[\texttt{MTS\_DEBUG\_FP}]Generated NaNs and overflows will cause floating point exceptions, which can be caught in a debugger. This is slow and mainly meant as a debugging tool for developers. Off by default. \item[\texttt{SPECTRUM\_SAMPLES=}$\langle ..\rangle$]This setting defines the number of spectral samples (in the 368-830 $nm$ range) that are used to render scenes. The default is 3 samples, in which case the renderer automatically turns into an RGB-based system. For high-quality spectral rendering, this should be set to 30 or higher. Refer also to \secref{colorspaces}. \item[\texttt{SINGLE\_PRECISION}] Do all computation in single precision. This is normally sufficient and therefore used as the default setting. \item[\texttt{DOUBLE\_PRECISION}] Do all computation in double precision. This flag is incompatible with \texttt{MTS\_SSE}, \texttt{MTS\_HAS\_COHERENT\_RT}, and \texttt{MTS\_DEBUG\_FP}. \item[\texttt{MTS\_GUI\_SOFTWARE\_FALLBACK}]Causes the GUI to use a software fallback instead of the hardware-accelerated realtime preview. This is useful when the binary will be executed over a remote link using a protocol such as RDP (which does not provide the requisite OpenGL features). \end{description} All of the default configurations files located in the \texttt{build} directory use the flags \code{SINGLE\_PRECISION}, \code{SPECTRUM\_SAMPLES=3}, \code{MTS\_DEBUG}, \code{MTS\_SSE}, as well as \code{MTS\_HAS\_COHERENT\_RT}. \subsection{Building on Debian or Ubuntu Linux} \label{sec:compiling-ubuntu} You'll first need to install a number of dependencies. It is assumed here that you are using a recent version of Ubuntu Linux (Precise Pangolin / 12.04 LTS or later), hence some of the package may be named differently if you are using Debian Linux or another Ubuntu version. First, run \begin{shell} $\text{\$}$ sudo apt-get install build-essential scons mercurial qt4-dev-tools libpng12-dev libjpeg-dev libilmbase-dev libxerces-c-dev libboost-all-dev libopenexr-dev libglewmx-dev libxxf86vm-dev libpcrecpp0 libeigen3-dev libfftw3-dev \end{shell} To get COLLADA support, you will also need to install the \texttt{collada-dom} packages or build them from scratch. Here, we install the \code{x86\_64} binaries and development headers that can be found on the Mitsuba website (at \url{http://www.mitsuba-renderer.org/releases/current}) \begin{shell} $\text{\$}$ sudo dpkg --install collada-dom_*.deb \end{shell} To start a regular build, run \begin{shell} $\text{\$}$ scons \end{shell} inside the Mitsuba directory. In the case that you have multiple processors, you might want to parallelize the build by appending \code{-j }\emph{core count} to the \code{scons} command. If all goes well, SCons should finish successfully within a few minutes: \begin{shell} scons: $\texttt{done}$ building targets. \end{shell} To run the renderer from the command line, you first have to import it into your shell environment: \begin{shell} $\text{\$}$ source setpath.sh \end{shell} Having set up everything, you can now move on to \secref{basics}. \subsubsection{Creating Debian or Ubuntu Linux packages} The preferred way of redistristributing executables on Debian or Ubuntu Linux is to create \code{.deb} package files. To make custom Mitsuba packages, it is strongly recommended that you work with a pristine installation of the target operating system\footnote{Several commercial graphics drivers ``pollute'' the OpenGL setup so that the compiled Mitsuba binaries can only be used on machines using the same drivers. For this reason, it is better to work from a clean boostrapped install.}. This can be done as follows: first, install \code{debootstrap} and download the most recent operating system release to a subdirectory. The following example is based on Ubuntu 12.04 LTS (``Precise Pangolin''), but the steps are almost identical for other versions of Ubuntu or Debian Linux. \begin{shell} $\text{\$}$ sudo apt-get install debootstrap $\text{\$}$ sudo debootstrap --arch amd64 precise precise-pristine \end{shell} Next, \code{chroot} into the created directory, enable the \code{multiverse} package repository, and install the necessary tools for creating package files: \begin{shell} $\text{\$}$ sudo chroot precise-pristine $\text{\$}$ echo "deb http://archive.ubuntu.com/ubuntu precise universe" >> /etc/apt/sources.list $\text{\$}$ apt-get update $\text{\$}$ apt-get install debhelper dpkg-dev pkg-config \end{shell} Now, you should be able to set up the remaining dependencies as described in \secref{compiling-ubuntu}. Once this is done, check out a copy of Mitsuba to the root directory of the \code{chroot} environment, e.g. \begin{shell} $\text{\$}$ hg clone https://www.mitsuba-renderer.org/hg/mitsuba \end{shell} To start the compilation process, enter \begin{shell} $\text{\$}$ cd mitsuba $\text{\$}$ cp -R data/linux/debian debian $\text{\$}$ dpkg-buildpackage -nc \end{shell} After everything has been built, you should find the created package files in the root directory. \subsubsection{Releasing Ubuntu packages} To redistribute Ubuntu packages over the Internet or a local network, it is convenient to put them into an \code{apt}-compatible repository. To prepare such a repository, put the two \code{deb}-files built in the last section, as well as the \code{collada-dom} \code{deb}-files into a public directory made available by a HTTP server and inside it, run \begin{shell} path-to-htdocs$\text{\$}$ dpkg-scanpackages path/to/deb-directory /dev/null | gzip -9c > path/to/deb-directory/Packages.gz \end{shell} This will create a respository index file named \code{Packages.gz}. Note that you must execute this command in the root directory of the HTTP server's web directory and provide the relative path to the package files -- otherwise, the index file will specify the wrong package paths. Finally, the whole directory can be uploaded to some public location and then referenced by placing a line following the pattern \begin{shell} deb http:// ./ \end{shell} into the \code{/etc/apt/sources.list} file. This setup is convenient for distributing a custom Mitsuba build to many Debian or Ubuntu machines running (e.g. to nodes in a rendering cluster). \subsection{Building on Fedora Core} You'll first need to install a number of dependencies. It is assumed here that you are using FC15, hence some of the package may be named differently if you are using another version. First, run \begin{shell} $\text{\$}$ sudo yum install mercurial gcc-c++ scons boost-devel qt4-devel OpenEXR-devel xerces-c-devel python-devel glew-devel libpng-devel libjpeg-devel collada-dom-devel eigen3-devel \end{shell} Afterwards, simply run \begin{shell} $\text{\$}$ scons \end{shell} inside the Mitsuba directory. In the case that you have multiple processors, you might want to parallelize the build by appending \code{-j }\emph{core count} to the command. If all goes well, SCons should finish successfully within a few minutes: \begin{shell} scons: $\texttt{done}$ building targets. \end{shell} To run the renderer from the command line, you first have to import it into your shell environment: \begin{shell} $\text{\$}$ source setpath.sh \end{shell} Having set up everything, you can now move on to \secref{basics}. \subsubsection{Creating Fedora Core packages} To create \code{RPM} packages, you will need to install the \code{RPM} development tools: \begin{shell} $\text{\$}$ sudo yum install rpmdevtools \end{shell} Once this is done, run the following command in your home directory: \begin{shell} $\text{\$}$ rpmdev-setuptree \end{shell} and create a Mitsuba source package in the appropriate directory: \begin{shell} $\text{\$}$ ln -s mitsuba mitsuba-$\code{\MitsubaVersion}$ $\text{\$}$ tar czvf rpmbuild/SOURCES/mitsuba-$\code{\MitsubaVersion}$.tar.gz mitsuba-$\code{\MitsubaVersion}$/. \end{shell} Finally, \code{rpmbuilder} can be invoked to create the package: \begin{shell} $\text{\$}$ rpmbuild -bb mitsuba-$\code{\MitsubaVersion}$/data/linux/fedora/mitsuba.spec \end{shell} After this command finishes, its output can be found in the directory \code{rpmbuild/RPMS}. \subsection{Building on Arch Linux} You'll first need to install a number of dependencies: \begin{shell} $\text{\$}$ sudo pacman -S gcc xerces-c glew openexr boost libpng libjpeg qt scons mercurial python \end{shell} For COLLADA support, you will also have to install the \code{collada-dom} library. For this, you can either install the binary package available on the Mitsuba website, or you can compile it yourself using the \code{PKGBUILD} supplied with Mitsuba, i.e. \begin{shell} $\text{\$}$ cd $\text{\$}$ cp /data/linux/arch/collada-dom/PKGBUILD . $\text{\$}$ makepkg PKGBUILD <..compiling..> $\text{\$}$ sudo pacman -U \end{shell} Finally, Eigen 3 must be installed. Again, there is a binary package on the Mitsuba website and the corresponding \code{PKGBUILD} can be obtained here: \url{http://aur.archlinux.org/packages.php?ID=47884}. Once all dependencies are taken care of, simply run \begin{shell} $\text{\$}$ scons \end{shell} inside the Mitsuba directory. In the case that you have multiple processors, you might want to parallelize the build by appending \code{-j }\emph{core count} to the command. If all goes well, SCons should finish successfully within a few minutes: \begin{shell} scons: $\texttt{done}$ building targets. \end{shell} To run the renderer from the command line, you first have to import it into your shell environment: \begin{shell} $\text{\$}$ source setpath.sh \end{shell} Having set up everything, you can now move on to \secref{basics}. \subsubsection{Creating Arch Linux packages} Mitsuba ships with a \code{PKGBUILD} file, which automatically builds a package from the most recent repository version: \begin{shell} $\text{\$}$ makepkg data/linux/arch/mitsuba/PKGBUILD \end{shell} % This is currently outdated %\subsection{Compiling on Gentoo Linux} %Simon Haegler has contributed a Gentoo \code{ebuild} script that can be used to Mitsuba. %It can be found inside the user repository \code{git://git.overlays.gentoo.org/user/mistafunk.git} %and is located at \code{media-gfx/mitsuba/mitsuba-0.3.0.ebuild}. \subsection{Building on Windows} Compiling Mitsuba's dependencies on Windows is a laborious process; for convenience, there is a repository that provides them in precompiled form. To use this repository, clone it using Mercurial and rename the directory so that it forms the \code{dependencies} subdirectory inside the main Mitsuba directory, i.e. run something like \begin{shell} C:\>cd mitsuba C:\mitsuba\>hg clone https://www.mitsuba-renderer.org/hg/dependencies_windows C:\mitsuba\>rename dependencies_windows dependencies \end{shell} There are a few other things that need to be set up: make sure that your installation of Visual Studio is up to date, since Mitsuba binaries created with versions prior to Service Pack 1 will crash. Next, you will need to install Python 2.6.x (\url{www.python.org}) and SCons\footnote{Note that on some Windows machines, the SCons installer generates a warning about not finding Python in the registry. In this case, you can instead run \code{python setup.py install} within the source release of SCons.} (\url{http://www.scons.org}, any 2.x version will do) and ensure that they are contained in the \code{\%PATH\%} environment variable so that entering \code{scons} on the command prompt (\code{cmd.exe}) launches the build system. Having installed all dependencies, run the ``Visual Studio \emph{2010} Command Prompt'' from the Start Menu (\code{x86} for 32-bit or \code{x64} for 64bit), navigate to the Mitsuba directory, and simply run \begin{shell} C:\mitsuba\>scons \end{shell} In the case that you have multiple processors, you might want to parallelize the build by appending the option \code{-j }\emph{core count} to the \code{scons} command. If all goes well, the build process will finish successfully after a few minutes. \emph{Note} that in comparison to the other platforms, you don't have to run the \code{setpath.sh} script at this point. All binaries are automatically copied into the \code{dist} directory, and they should be executed directly from there. \subsubsection{Integration with the Visual Studio interface} Basic Visual Studio 2010 integration with support for code completion exists for those who develop Mitsuba code on Windows. To use the supplied projects, simply double-click on one of the two files \code{build/mitsuba-msvc2010.sln} and \code{build/mitsuba-msvc2010.sln}. These Visual Studio projects still internally use the SCons-based build system to compile Mitsuba; whatever build configuration is selected within Visual Studio will be used to pick a matching configuration file from the \texttt{build} directory. \subsection{Building on Mac OS X} \vspace{-5mm} \remarks{ \item Unfortunately, OpenMP is not available when compiling using the regular \code{clang} toolchain (it is available when using Intel XE Composer). This will cause the following parts of Mitsuba to run single-threaded: bitmap resampling (i.e. MIP map generation), blue noise point generation in the \pluginref{dipole} plugin, as well as the \pluginref{ppm} and \pluginref{sppm} plugins. } Compiling Mitsuba's dependencies on Mac OS is a laborious process; for convenience, there is a repository that provides them in precompiled form. To use this repository, clone it using Mercurial and rename the directory so that it forms the \code{dependencies} subdirectory inside the main Mitsuba directory, i.e. run something like \begin{shell} $\text{\$}$ cd mitsuba $\text{\$}$ hg clone https://www.mitsuba-renderer.org/hg/dependencies_macos $\text{\$}$ mv dependencies_macos dependencies \end{shell} You will also need to install SCons (>2.0.0, available at \code{www.scons.org}) and a recent release of XCode, including its command-line compilation tools. Next, run \begin{shell} $\text{\$}$ scons \end{shell} inside the Mitsuba directory. In the case that you have multiple processors, you might want to parallelize the build by appending \code{-j }\emph{core count} to the command. If all goes well, SCons should finish successfully within a few minutes: \begin{shell} scons: $\texttt{done}$ building targets. \end{shell} To run the renderer from the command line, you first have to import it into your shell environment: \begin{shell} $\text{\$}$ source setpath.sh \end{shell}