mitsuba/doc/basics.tex

307 lines
15 KiB
TeX
Raw Normal View History

\section{Basic usage}
\label{sec:basics}
2010-08-11 06:38:22 +08:00
The rendering functionality of Mitsuba can be accessed through
a command line interface and an interactive Qt-based frontend. This section
provides some basic instructions on how to use them.
\subsection{Interactive frontend}
To launch the interactive frontend, run \code{Mitsuba.app} on MacOS,
2010-08-11 06:38:22 +08:00
\code{mtsgui.exe} on Windows, and \code{mtsgui} on Linux (after sourcing \code{setpath.sh}).
You can also drag and drop scene files onto the application icon or the running program to open them.
A quick video tutorial on using the GUI can be found here: \url{http://vimeo.com/13480342}.
\subsection{Command line interface}
2010-08-16 23:48:29 +08:00
\label{sec:mitsuba}
The \texttt{mitsuba} binary is an alternative non-interactive rendering
2011-07-06 23:52:02 +08:00
frontend for command-line usage and batch job operation.
2010-08-11 06:38:22 +08:00
To get a listing of the parameters it supports, run
the executable without parameters:
\begin{shell}
$\texttt{\$}$ mitsuba
2010-08-11 06:38:22 +08:00
\end{shell}
2011-07-06 23:52:02 +08:00
\begin{console}[label=lst:mitsuba-cli,caption=Command line options of the \texttt{mitsuba} binary]
2012-04-14 02:15:23 +08:00
Mitsuba version $\texttt{\MitsubaVersion}$, Copyright (c) $\texttt{\MitsubaYear}$ Wenzel Jakob
2011-07-06 23:52:02 +08:00
Usage: mitsuba [options] <One or more scene XML files>
Options/Arguments:
-h Display this help text
-D key=val Define a constant, which can referenced as "$\$$key" in the scene
-o fname Write the output image to the file denoted by "fname"
-a p1;p2;.. Add one or more entries to the resource search path
-p count Override the detected number of processors. Useful for reducing
the load or creating scheduling-only nodes in conjunction with
the -c and -s parameters, e.g. -p 0 -c host1;host2;host3,...
-q Quiet mode - do not print any log messages to stdout
-c hosts Network rendering: connect to mtssrv instances over a network.
Requires a semicolon-separated list of host names of the form
host.domain[:port] for a direct connection
or
user@host.domain[:path] for a SSH connection (where
"path" denotes the place where Mitsuba is checked
out -- by default, "~/mitsuba" is used)
-s file Connect to additional Mitsuba servers specified in a file
with one name per line (same format as in -c)
-j count Simultaneously schedule several scenes. Can sometimes accelerate
rendering when large amounts of processing power are available
(e.g. when running Mitsuba on a cluster. Default: 1)
-n name Assign a node name to this instance (Default: host name)
-t Test case mode (see Mitsuba docs for more information)
-x Skip rendering of files where output already exists
-r sec Write (partial) output images every 'sec' seconds
-b res Specify the block resolution used to split images into parallel
workloads (default: 32). Only applies to some integrators.
-v Be more verbose
-w Treat warnings as errors
-z Disable progress bars
For documentation, please refer to http://www.mitsuba-renderer.org/docs.html
\end{console}
2011-06-25 22:49:26 +08:00
\lstref{mitsuba-cli} shows the output resulting from this command. The most common
2010-08-11 06:38:22 +08:00
mode of operation is to render a single scene, which is provided as a parameter, e.g.
\begin{shell}
$\texttt{\$}$ mitsuba path-to/my-scene.xml
\end{shell}
It is also possible to connect to network render nodes, which essentially lets Mitsuba parallelize
over additional cores. To do this, pass a semicolon-separated list of machines to
the \code{-c} parameter.
2010-08-11 06:38:22 +08:00
\begin{shell}
$\texttt{\$}$ mitsuba -c machine1;machine2;... path-to/my-scene.xml
\end{shell}
There are two different ways in which you can access render nodes:
\begin{itemize}
\item\textbf{Direct}: Here, you create a direct connection to a running \code{mtssrv} instance on
another machine (\code{mtssrv} is the Mitsuba server process). From the the performance
standpoint, this approach should always be preferred over the SSH method described below when there is
2010-08-11 06:38:22 +08:00
a choice between them. There are some disadvantages though: first, you need to manually start
\code{mtssrv} on every machine you want to use.
2010-08-11 06:38:22 +08:00
And perhaps more importantly: the direct communication
protocol makes no provisions for a malicious user on the remote side. It is too costly
to constantly check the communication stream for illegal data sequences, so Mitsuba simply doesn't do it.
The consequence of this is that you should only use the direct communication approach within
trusted networks.
For direct connections, you can specify the remote port as follows:
\begin{shell}
$\texttt{\$}$ mitsuba -c machine:1234 path-to/my-scene.xml
\end{shell}
When no port is explicitly specified, Mitsuba uses default value of 7554.
\item \textbf{SSH}:
This approach works as follows: The renderer creates a SSH connection
to the remote side, where it launches a Mitsuba worker instance.
All subsequent communication then passes through the encrypted link.
This is completely secure but slower due to the encryption overhead.
If you are rendering a complex scene, there is a good chance that it
won't matter much since most time is spent doing computations rather than
communicating
Such an SSH link can be created simply by using a slightly different syntax:
2010-08-11 06:38:22 +08:00
\begin{shell}
$\texttt{\$}$ mitsuba -c username@machine path-to/my-scene.xml
\end{shell}
The above line assumes that the remote home directory contains
a Mitsuba source directory named \code{mitsuba},
which contains the compiled Mitsuba binaries.
If that is not the case, you need to provide the path to such a directory manually, e.g:
2010-08-11 06:38:22 +08:00
\begin{shell}
$\texttt{\$}$ mitsuba -c username@machine:/opt/mitsuba path-to/my-scene.xml
\end{shell}
For the SSH connection approach to work, you \emph{must} enable passwordless
authentication.
Try opening a terminal window and running the command \code{ssh username@machine}
(replace with the details of your remote connection).
If you are asked for a password, something is not set up correctly --- please see
\url{http://www.debian-administration.org/articles/152} for instructions.
On Windows, the situation is a bit more difficult since there is no suitable SSH client by
default. To get SSH connections to work, Mitsuba requires \code{plink.exe} (from PuTTY) to
be on the path. For passwordless authentication with a Linux/OSX-based
server, convert your private key to PuTTY's format using \code{puttygen.exe}.
Afterwards, start \code{pageant.exe} to load and authenticate the key. All
of these binaries are available from the PuTTY website.
It is possible to mix the two approaches to access some machines directly and others
over SSH.
2010-08-11 06:38:22 +08:00
\end{itemize}
When doing many network-based renders over the command line, it can become tedious to
specify the connections every time. They can alternatively be loaded from a text file
where each line contains a separate connection description as discussed previously:
\begin{shell}
$\texttt{\$}$ mitsuba -s servers.txt path-to/my-scene.xml
\end{shell}
where \code{servers.txt} e.g. contains
\begin{shell}
2010-08-11 06:38:22 +08:00
user1@machine1.domain.org:/opt/mitsuba
machine2.domain.org
machine3.domain.org:7346
\end{shell}
2010-08-11 06:38:22 +08:00
\subsubsection{Passing parameters}
2011-07-06 23:52:02 +08:00
Any attribute in the XML-based scene description language can be parameterized from the
2010-08-11 06:38:22 +08:00
command line.
For instance, you can render a scene several times with different reflectance values
on a certain material by changing its description to something like
2010-08-11 06:38:22 +08:00
\begin{xml}
2011-07-06 23:52:02 +08:00
<bsdf type="diffuse">
<spectrum name="reflectance" value="$\texttt{\$}$reflectance"/>
2010-08-11 06:38:22 +08:00
</bsdf>
\end{xml}
and running Mitsuba as follows:
\begin{shell}
$\texttt{\$}$ mitsuba -Dreflectance=0.1 -o ref_0.1.exr scene.xml
$\texttt{\$}$ mitsuba -Dreflectance=0.2 -o ref_0.2.exr scene.xml
$\texttt{\$}$ mitsuba -Dreflectance=0.5 -o ref_0.5.exr scene.xml
2010-08-11 06:38:22 +08:00
\end{shell}
\subsubsection{Writing partial images to disk}
When doing lengthy command line renders on Linux or OSX, it is possible
to send a signal to the process using
\begin{shell}
2010-08-11 06:38:22 +08:00
$\texttt{\$}$ killall -HUP mitsuba
\end{shell}
This causes the renderer to write out the partially finished
image, after which it continues rendering. This can sometimes be useful to
2010-08-11 06:38:22 +08:00
check if everything is working correctly.
\subsubsection{Rendering an animation}
The command line interface is ideally suited for rendering numbers of files in batch
operation. You can simply pass in the files using a wildcard in the filename.
2011-07-06 23:52:02 +08:00
If you've already rendered a subset of the frames and you only want to complete the remainder,
add the \texttt{-x} flag, and all files with existing output will be skipped. You can also
let the scheduler work on several scenes at once using the \texttt{-j} parameter --- this is
2011-07-06 23:52:02 +08:00
especially useful when parallelizing over multiple machines: as some of the participating machines
2010-08-11 06:38:22 +08:00
finish rendering the current frame, they can immediately start working on the next one
instead of having to wait for all other cores to finish. Altogether, you
2011-07-06 23:52:02 +08:00
might start the with parameters such as the following
2010-08-11 06:38:22 +08:00
\begin{shell}
$\texttt{\$}$ mitsuba -xj 2 -c machine1;machine2;... animation/frame_*.xml
\end{shell}
2013-03-06 06:34:37 +08:00
Note that this requires a shell capable of expanding the asterisk into a list of
filenames. The default Windows shell \code{cmd.exe} does not do this---however,
the PowerShell supports the following syntax:
\begin{shell}
dir frame_*.xml | % $\texttt{\{}$ <path to mitsuba.exe> $\texttt{\$\_}$ $\texttt{\}}$
\end{shell}
2010-08-16 23:48:29 +08:00
\subsection{Direct connection server}
\label{sec:mtssrv}
2010-08-16 23:48:29 +08:00
A Mitsuba compute node can be created using the \code{mtssrv} executable. By default,
it will listen on port 7554:
\begin{shell}
$\texttt{\$}$ mtssrv
..
maxwell: Listening on port 7554.. Send Ctrl-C or SIGTERM to stop.
\end{shell}
Type \code{mtssrv -h} to see a list of available options.
If you find yourself unable to connect to the server, \code{mtssrv} is probably listening on
the wrong interface. In this case, please specify an explicit IP address or hostname:
\begin{shell}
$\texttt{\$}$ mtssrv -i maxwell.cs.cornell.edu
\end{shell}
As advised in Section~\ref{sec:mitsuba}, it is advised to run \code{mtssrv} \emph{only} in trusted networks.
One nice feature of \code{mtssrv} is that it (like the \code{mitsuba} executable)
also supports the \code{-c} and \code{-s} parameters, which create connections
2011-07-06 23:52:02 +08:00
to additional compute servers.
Using this feature, one can create hierarchies of compute nodes. For instance,
the root \code{mttsrv} instance of such a hierarchy could share its work with a
number of other machines running \code{mtssrv}, and each of these might also
2011-07-06 23:52:02 +08:00
share their work with further machines, and so on...
The parallelization over such hierarchies happens transparently---when
connecting a renderering process to the root node, it sees a machine
2011-07-06 23:52:02 +08:00
with hundreds or thousands of cores, to which it can submit work without
needing to worry about how exactly it is going to be spread out in
2011-07-06 23:52:02 +08:00
the hierarchy.
2010-08-16 23:48:29 +08:00
Such hierarchies are mainly useful to reduce communication bottlenecks when distributing
large resources (such as scenes) to remote machines. Imagine the following hypothetical scenario:
you would like to render a 50MB-sized scene while at home, but rendering is too slow.
2010-08-16 23:48:29 +08:00
You decide to tap into some extra machines available
at your workplace, but this usually doesn't make things much faster because of the relatively slow broadband
connection and the need to transmit your scene to every single compute node involved.
2010-08-16 23:48:29 +08:00
Using \code{mtssrv}, you can
instead designate a central scheduling node at your workplace, which accepts connections and delegates
rendering tasks to the other machines. In this case, you will only have to transmit the scene once,
2011-07-06 23:52:02 +08:00
and the remaining distribution happens over the fast local network at your workplace.
2010-08-16 23:48:29 +08:00
\subsection{Utility launcher}
\label{sec:mtsutil}
When working on a larger project, one often needs to implement various utility programs that
2010-08-16 23:48:29 +08:00
perform simple tasks, such as applying a filter to an image or processing
a matrix stored in a file. In a framework like Mitsuba, this unfortunately involves
a significant coding overhead in initializing the necessary APIs on all supported platforms.
2010-08-16 23:48:29 +08:00
To reduce this tedious work on the side of the programmer, Mitsuba comes with a utility launcher
called \code{mtsutil}.
The general usage of this command is
\begin{shell}
$\texttt{\$}$ mtsutil [options] <utility name> [arguments]
\end{shell}
For a listing of all supported options and utilities, enter the command without parameters.
\subsubsection{Tonemapper}
\label{sec:tonemapper}
One particularly useful utility that shall be mentioned here is the batch tonemapper, which
loads EXR/RGBE images and writes tonemapped 8-bit PNG/JPGs. This can save much time when one has to
process many high dynamic-range images such as animation frames using the same basic operations,
e.g. gamma correction, changing the overall brightness, resizing, cropping, etc. The available
command line options are shown in \lstref{tonemap-cli}.
\begin{console}[label=lst:tonemap-cli,caption=Command line options of the \texttt{mtsutil tonemap} utility]
$\texttt{\$}$ mtsutil tonemap
Synopsis: Loads one or more EXR/RGBE images and writes tonemapped 8-bit PNG/JPGs
Usage: mtsutil tonemap [options] <EXR/RGBE file (s)>
Options/Arguments:
-h Display this help text
-g gamma Specify the gamma value (The default is -1 => sRGB)
-m multiplier Multiply the pixel values by 'multiplier' (Default = 1)
-b r,g,b Color balance: apply the specified per-channel multipliers
-c x,y,w,h Crop: tonemap a given rectangle instead of the entire image
-s w,h Resize the output image to the specified resolution
-r x,y,w,h,i Add a rectangle at the specified position and intensity, e.g.
to make paper figures. The intensity should be in [0, 255].
-f fmt Request a certain output format (png/jpg, default:png)
-a Require the output image to have an alpha channel
-p key,burn Run Reinhard et al.'s photographic tonemapping operator. 'key'
between [0, 1] chooses between low and high-key images and
'burn' (also [0, 1]) controls how much highlights may burn out
2013-11-06 04:40:48 +08:00
-B fov Apply a bloom filter that simulates scattering in the human
eye. Requires the approx. field of view of the images to be
processed in order to compute a point spread function.
-x Temporal coherence mode: activate this flag when tonemapping
frames of an animation using the '-p' option to avoid flicker
-o file Save the output with a given filename
-t Multithreaded: process several files in parallel
2013-11-06 04:40:48 +08:00
The operations are ordered as follows: 1. crop, 2. bloom, 3. resize, 4. color
balance, 5. tonemap, 6. annotate. To simply process a directory full of EXRs
in parallel, run the following: 'mtsutil tonemap -t path-to-directory/*.exr'
\end{console}