mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-11 00:41:56 -06:00
76 lines
4.1 KiB
TeX
76 lines
4.1 KiB
TeX
|
\section{Quick Installation of \Dumux} \label{quick-install}
|
||
|
|
||
|
This only provides one quick way of installing \Dumux.
|
||
|
You should have a recent working Linux environment, no \Dune core modules should be installed.
|
||
|
If you need more information,
|
||
|
have \Dune already installed, please have a look at the detailed installation
|
||
|
instructions in Section \ref{install}.
|
||
|
|
||
|
\subsection{Obtaining the code with the script \texttt{checkout-dumux}}
|
||
|
|
||
|
The shell-script \texttt{checkout-dumux} facilitates setting up a {\Dune}/{\Dumux} directory tree (currently for the trunk version).
|
||
|
It is contained in the download section of the \Dumux web page \cite{DUMUX-HP}.
|
||
|
For example the second line below will check out the required \Dune modules and \texttt{dumux},
|
||
|
\texttt{dumux-devel} and the \texttt{external} folder, which contains some useful external software and libraries.
|
||
|
Again, \texttt{joeuser} needs to be replaced by the actual user name.
|
||
|
|
||
|
\begin{lstlisting}[style=Bash]
|
||
|
$ checkout-dumux -h # show help,
|
||
|
$ checkout-dumux -gme -u joeuser -p password -d DUMUX
|
||
|
\end{lstlisting}
|
||
|
|
||
|
|
||
|
\subsection{Build of \Dune and \Dumux}
|
||
|
\label{buildIt}
|
||
|
Building of \Dune and \Dumux is done by the command-line script \texttt{dunecontrol} as described in \Dune Installation Notes \cite{DUNE-INST}
|
||
|
and in much more comprehensive form in the \Dune Buildsystem Howto \cite{DUNE-BS}.
|
||
|
If something fails during the execution of \texttt{dunecontrol} feel free to report it to the \Dune or \Dumux developer mailing list,
|
||
|
but also try to include error details.\\
|
||
|
|
||
|
It is possible to compile \Dumux with nearly no explicit options to the build system.
|
||
|
%, but experience showed that the code quality through all parts of \Dune is not yet high enough to give the compiler full
|
||
|
%freedom for allowing certain kinds of optimizations.
|
||
|
However, for the successful compilation of \Dune and \Dumux, it is currently necessary to pass the
|
||
|
%As options, switches for the optimization can be set in parts
|
||
|
%build system for code by default, it is safer to pass
|
||
|
the option \texttt{-fno-strict-aliasing} to the C++-compiler
|
||
|
\cite{WIKIPED-ALIASING}, which is done here via a command-line argument to \texttt{dunecontrol}:
|
||
|
|
||
|
|
||
|
\begin{lstlisting}[style=Bash]
|
||
|
$ # make sure you are in the directory DUNE-Root
|
||
|
$ ./dune-common/bin/dunecontrol --configure-opts="CXXFLAGS=-fno-strict-aliasing" all
|
||
|
\end{lstlisting}
|
||
|
|
||
|
Too many options can make life hard. That's why usually option-files are being used together with dunecontrol and its sub-tools.
|
||
|
Larger sets of options are kept in them. If you are going to compile with options suited for debugging the code, the following
|
||
|
can be a starting point:
|
||
|
|
||
|
%Below in command-line make sure to insert the right name of dumux' root directory, which is in the case of installation from tar-files \texttt{dumux-2.0} or in the case of installation from subversion just \texttt{dumux}. For a developer it is also possible to take the options file from \texttt{dumux-devel}.
|
||
|
|
||
|
\begin{lstlisting}[style=Bash]
|
||
|
$ # make sure you are in the directory DUNE-Root
|
||
|
$ cp dumux/debug.opts my-debug.opts # create a personal version
|
||
|
$ gedit my-debug.opts # optional editing the options file
|
||
|
$ ./dune-common/bin/dunecontrol --opts=my-debug.opts all
|
||
|
\end{lstlisting}
|
||
|
|
||
|
More optimized code, which is typically not usable for standard debugging tasks, can be produced by
|
||
|
|
||
|
\begin{lstlisting}[style=Bash]
|
||
|
$ cp dumux/optim.opts my-optim.opts
|
||
|
$ ./dune-common/bin/dunecontrol --opts=my-optim.opts all
|
||
|
\end{lstlisting}
|
||
|
|
||
|
Sometimes it is necessary to have additional options which
|
||
|
are specific to a package set of an operating system or
|
||
|
sometimes you have your own preferences.
|
||
|
Feel free to work with your own set of options, which may evolve over time.
|
||
|
The option files above are to be understood more as a starting point
|
||
|
for setting up an own customization than as something which is fixed.
|
||
|
The use of external libraries can make it necessary to add quite many options in an option-file.
|
||
|
It can be helpful to give your customized option file its own name, as done above.
|
||
|
One avoids confusing it with the option files which came out of the distribution
|
||
|
and which can be possibly updated by subversion later on.
|
||
|
|