source: src/documentation/install.dox@ 40d3ea

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable v1.4.0
Last change on this file since 40d3ea was 48d20d, checked in by Frederik Heber <heber@…>, 12 years ago

Added new action FitPotentialAction to fit empirical potentials.

  • moved functionality from levmartester into new Action.
  • removed levmartester.
  • needs both enable-levmar and path to libs/include with-levmar. This allows checking as distinct enable switch.
  • added regression test Fragmentation/FitPotential for morse and harmonic_angle fit to water molecule. Using awk to check on L2 error.
  • added take-best-of option such that fits is done as many times and best (in terms of l2 error) is used. This should make regression test FitPotential more stable (right now we take best of 5).
  • DOCU: extended construct documentation due to new PotentialTypes construct.
  • DOCU: made construct lists items appear alphabetically.
  • DOCU: extended installation documentation with VTK and levmar.
  • DOCU: also URLs for scafacos, VTK, and levmar.
  • Property mode set to 100644
File size: 13.0 KB
RevLine 
[19bc74]1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010 University of Bonn. All rights reserved.
5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/**
9 * \file install.dox
10 *
11 * Created on: Oct 28, 2011
12 * Author: heber
13 */
14
[750cff]15/**
16 * \page install Installation
17 *
[6752dc]18 * \section install-prerequisites Prerequisites
19 *
20 * Several packages are required or advised for compilation of the code.
21 * The code has been developed under ubuntu 10.04 and 12.04, so in the
22 * following we concentrate on these systems.
23 *
24 * A specific section will be added when (cross-)compilation for Windows
25 * has succeeded. Note that compiling without Qt under GNU/Cygwin is
26 * relatively straight-forward along the lines of the required packages
27 * for Ubuntu.
28 *
29 * \subsection install-prerequisites-ubuntu ... for Ubuntu
30 *
31 * Under Ubuntu 12.04 the following packages are required:
32 * -# C++ compiler: e.g. g++
33 * -# LAPACK: liblapack-dev
34 * -# GSL: libgsl0-dev
35 * -# BLAS: e.g. libopenblas-dev or libatlas-base-dev
36 * -# Many Boost Libraries: libboost1.48-all-dev
37 * -# gawk: gawk
38 * -# pkg-config: pkg-config
39 * -# CodePatterns: see below for instructions
40 *
41 * The following packages are optional. Note however that certain features
42 * are not available when these packages are missing:
43 * -# MoleCuilder scripting and start scripts
44 * -# Python: python, python-dev
45 * -# Documentation generated from source code:
46 * -# doxygen: doxygen
47 * -# GraphViz: dot
48 * -# Unit tests
49 * -# CppUnit: libcppunit-dev
50 * -# Graphical User Interface
51 * -# Qt: qt4-dev-tools libqt4-core qt4-qmake
52 * -# Qt3D: see below for instructions
53 * -# BOSSANOVA scheme
54 * -# JobMarket: see below for instructions
55 * -# MPQC: see below for instructions
56 * -# ScaFaCoS: see below for instructions
[48d20d]57 * -# VTK: see below for instructions
58 * -# levmar: see below for instructions
[6752dc]59 *
60 * If you are programming with or for MoleCuilder, the following packages are
61 * advised to use:
62 * -# ccache: ccache
63 * -# git: git
64 * -# autotools: autoconf automake autoheader autoconf libtool
65 *
66 * \subsection install-prerequisites-other Other packages
67 *
68 * Here, we want to give some advice on how we managed to compile packages that
69 * don't come as a Debian/Ubuntu package:
70 *
71 * \subsubsection install-prerequisites-other-codepatterns CodePatterns
72 *
73 * CodePatterns are some general object oriented patterns implemented in C++
74 * which are a sort of novice attempt to what some of the boost libraries can
75 * do. E.g. a thread-safe singleton pattern.
76 *
77 * Refer to the project's webpage for further instructions.
78 *
79 * \subsubsection install-prerequisites-other-qt3d Qt3D
80 *
81 * The graphical user interface heavily relies on Qt3D to display atoms and
82 * their bonds and to allow for selections. As the GUI has been developed with
83 * Qt4.8 where Qt3D is not yet implemented - this has been done with Qt5 --
84 * Qt3D has to be compiled and installed manually. Required for compilation
85 * are the complete dev-tools of Qt4. Then, obtain the code from the repository
86 * as described here: http://doc-snapshot.qt-project.org/qt3d-1.0/qt3d-building.html
87 * Make sure that the branch \b qt4 is checked out.
88 * Afterwards, create the Makefiles (check that qt4's qmake is used!), compile, and
89 * install via
90 * \code
91 * qmake-qt4 quick3d.pro
92 * sudo make
93 * sudo make install
94 * \endcode
95 * Note that I had to manually create \b /usr/include/qt4/Qt3D to pass
96 * compilation and installation with error.
97 *
98 * Furthermore, we require a Qt3D pkg-config file, which is sadly not created.
99 * This can be easily created by copying e.g. QtOpenGl.pc and search&replacing
100 * OpenGl to Qt3D (check for double QtQt appearances).
101 *
102 * \subsubsection install-prerequisites-other-jobmarket JobMarket
103 *
104 * JobMarket is a package for allowing a server to give wrapped-up jobs to
105 * clients which work on the given job and return some wrapped-up results.
106 * This has been implemented with boost::asio.
107 *
108 * The package is private property of Frederik Heber. Contact the author for
109 * further information on how to obtain the code and installation instructions.
110 *
111 * \subsubsection install-prerequisites-other-scafacos ScaFaCoS
112 *
[48d20d]113 * ScaFaCoS (http://www.scafacos.org/) is a library of fast Coulomb solvers,
114 * created by the same-named BMBF funded project. The library contains Versatile
115 * MultiGrid (vmg) as one of its solvers which is used in the BOSSANOVA scheme
116 * for the calculation of long-range forces.
[6752dc]117 *
118 * ScaFaCoS requires the following packages to compile:
119 * -# MPI: mpi-default-dev libopenmpi-dev
120 * -# F2C: libf2c2-dev
121 * -# Fortran compiler: gfortan
[48d20d]122 * -# VTK >=5.10
123 *
124 * Firstly, you should obtain a recent copy of the visualization tool kit (VTK)
125 * (http://www.vtk.org/) and compile as
126 * \code
127 * export MPI_HOME=$( which mpirun | sed 's#/bin/mpirun##g')
128 * export CXX_FLAGS=-fPIC
129 * cmake -DCMAKE_INSTALL_PREFIX:PATH=<install-path> \
130 * -DBUILD_SHARED_LIBS=TRUE \
131 * -DCMAKE_BUILD_WITH_INSTALL_RPATH:BOOL=OFF \
132 * -DCMAKE_INSTALL_RPATH:PATH=<install-path>/lib/vtk-<install-version> \
133 * -DCMAKE_INSTALL_RPATH_USE_LINK_PATH:BOOL=ON \
134 * -DCMAKE_SKIP_BUILD_RPATH:BOOL=OFF \
135 * -DVTK_USE_PARALLEL:BOOL=ON \
136 * -DVTK_USE_MPI:BOOL=ON \
137 * -DMPI_LIBRARY:PATH=${MPI_HOME}/lib/libmpi.so \
138 * -DMPI_EXTRA_LIBRARY:PATH=${MPI_HOME}/lib/libmpi_cxx.so \
139 * -DMPI_INCLUDE_PATH:PATH=${MPI_HOME}/include/mpi \
140 * ..
141 * make -j4
142 * make install
143 * \endcode
144 * where we force rpath-linking and shared libraries (MPI is actually not
145 * required here).
146 *
[6752dc]147 * Compilation additionally required use of
148 * \code CPPFLAGS="-fPIC" \endcode
149 * to generate position-independent code. This is because ScaFaCoS so far does
150 * not use libtool which would otherwise take care of this and created shared
151 * libraries. Note that VMG is the only required solver, others are not used, e.g.
152 * for a debug compile you might want to use:
153 * \code
[48d20d]154 * ../configure \
155 * -C \
156 * --prefix=<path> \
157 * --enable-shared \
158 * BSPLINE_DEG=3 \
159 * MPICC=mpicc.openmpi \
160 * MPICXX=mpicxx.openmpi \
161 * MPIEXEC=mpirun.openmpi \
162 * CPPFLAGS="-Wall -g3 -O0 -ggdb -fPIC" \
163 * --enable-mpi \
164 * --with-boost-libdir=/usr/lib --with-boost=/usr \
165 * --with-vtk=<path-to-vtk> --with-vtk-version=<vtk-version path string, i.e. -5.10> \
166 * --enable-fcs-solvers=vmg
[6752dc]167 * \endcode
[48d20d]168 * where we specify a recent boost and the installed VTK version from above.
169 *
170 * \subsubsection install-prerequisites-other-levmar LevMar
171 *
172 * We also require the levmar (http://www.ics.forth.gr/~lourakis/levmar/) which
173 * implements a Levenberg-Marquardt for non-linear regression which is employed
174 * for fitting empirical potentials to energies obtained from calculated
175 * fragment energies.
176 *
177 * Compile and install as follows
178 * \code
179 * cmake \
180 * -DCMAKE_INSTALL_PREFIX:PATH=<install-path> \
181 * -DCMAKE_C_FLAGS="-fPIC" \
182 * ..
183 * make
184 * cp -f liblevmar.a <install-path>/lib
185 * cp -f levmar.h <install-path>/include
186 * \endcode
187 * where we have to copy the stuff by hand as no \a install target exists.
[6752dc]188 *
189 * \subsubsection install-prerequisites-other-mpqc MPQC
190 *
191 * Massively Parallel Quantum Chemistry (http://www.mpqc.org/) is a Hartree-Fock
192 * solver with emphasis on concurrency. We, however, require only the solver part.
193 * The code base has been adapted a bit to allow use within JobMarket.
194 * Also, it uses the ScaFaCoS package to calculate long-range forces.
195 *
[750cff]196 * \section install-compiling Compiling the Code
197 *
198 * After you obtained the code, you do the following:
199 *
200 * \code
201 * ./bootstrap
202 * \endcode
203 *
204 * This creates the necessary autoconf and automake files.
205 *
206 * After this,
207 *
208 * \code
209 * mkdir build
210 * cd build
211 * ../configure --prefix=`pwd`
212 * \endcode
213 *
[6752dc]214 * which will run the configure script that checks whether you meet all the
215 * requirements. Note that you may supply system-specific paths as follows:
[750cff]216 * -# GNU Scientific Library (specify via LDFLAGS, ...)
217 * -# Qt4 framework (--with-Qt=<dir> or --with-Qt-include-dir, --with-Qt-bin-dir,
218 * --with-Qt-lib-dir and --with-Qt-lib)
[6752dc]219 * -# Boost library 1.40 or newer with program_options and threads (--with-boost=<dir>,
220 * --with-boost-lib=<path>)
[750cff]221 * -# CPPUnit framework (--with-cppunit-prefix=<dir>)
222 * -# CodePatterns (--with-codepatterns=<dir>)
223 *
[0a7834]224 * The following packages are optional (code parts/features are disabled if not
[0cd225]225 * found):
[0a7834]226 * -# JobMarket (--enable-jobmarket --with-jobmarket=<dir>
227 * -# VMG library of ScaFaCoS (--enable-vmg --with-vmg-mpi MPICXX=mpicxx PKGCONFIG=<path to ScaFaCoS pkdir>)
228 * -# levmar (--with-levmar=<dir>)
229 *
[750cff]230 * \a --prefix is the argument to tell configure where all program code should go
231 * to (pwd is the unix command for the current working directory). There are
232 * others, see
233 *
234 * \code
235 * ../configure --help
236 * \endcode
237 *
238 * and some enable/disable switches you should check out:
239 *
240 * - \a --enable-ecut - says that the TestRunner, comprising all unit tests in one
241 * exectuable, shall make use of the Eclipse CppUnitTest (ECUT). If this is
242 * started within eclipse with this plugin installed, a shiny interface will tell
243 * you what failed and what not.
244 * - \a --enable-debug - activates many internal asserts, memory debugger and more
245 * (makes code a lot slower but gives information in case something fails)
[0a7834]246 * - \a --enable-python - activates python scripting. For one you can control
247 * molecuilder within your python code by simply calling its actions. For another
248 * it automatically executes a script \b molecuilder.py in the current folder
249 * prior to launching the respective UI.
250 * - \a --disable-cache - disables caching of certain variables (see CodePatterns).
251 * - \a --enable-valgrind - each test of the testsuite is launched by wrapping
252 * the call through valgrind checking on correct handling of memory.
[0cd225]253 *
[750cff]254 *
255 * \note A note about configure: If one library is found only under some specific path, you
256 * can add CFLAGS, CPPFLAGS, LDFLAGS, ... to the configure call, like this
257 * \code
258 * ../configure --prefix=`pwd` --enable-hydrogen CFLAGS="-Wall -g3" CXXFLAGS="-Wall -g3"
259 * \endcode
260 * which enables all compiler warnings and full debugging of the code without any
261 * optimization. configure saves these variables, too, such that when it is called
262 * to re-configure it will still make use of them from its cache file.
263 *
264 * There are several flags that change the way molecuilder is compiled and probably
265 * make it run faster, more unsafe, ...
266 * -# \a -DLOG_OBSERVER, What the Observers do is logged, the log is printed on exit
267 * -# \a -DNO_MEMDEBUG, MemDebug (memory debugger) is disabled
268 * -# \a -DNO_CACHING, Cachable are short-wired, i.e. always recalculate, this slows
269 * down the code a lot
270 * -# \a -DNDEBUG, include NO_MEMDEBUG, also ASSERTs are not checked, this speeds up
271 * the code by a factor of 5
[19bc74]272 *
[6752dc]273 * \subsection install-difficulties Difficulties
274 *
275 * You might encounter some problems along the way, which we list up here:
276 * -# Switching from Lucid Lynx to Precise Pangolin, libtool has been patched to
277 * \b link_all_deplibs=no which causes linking to fail. A temporary way around it
278 * is to seek&replace all instances in your build directory (replace no with
279 * unknown). The more general way is to replace packaged and patched libtool
280 * with an unpatched version you have to compile yourself.
281 *
[750cff]282 * \section install-install Installing
283 *
284 * Now, we are ready to compile and install.
285 *
286 * \code
287 * make
288 * make install
289 * \endcode
290 *
291 * \attention If you have a multi-core system, it is highly recommended to use the
292 * \a -j option of make to allow for multiple threads to work on compiling or
293 * checking the codfe simultaneously.
294 *
295 * And if everything went well, you should launch the unit tests and the testsuite
296 * by (see section \ref tests on how to launch the tests individually)
297 *
298 * \code
299 * make check
300 * \endcode
301 *
302 * If everything is OK, you have a working version of MoleCuilder in form of the
303 * executables \b bin/molecuilder and \b bin/molecuildergui.
304 *
305 * If you have to delete all compiled stuff, enter
306 *
307 * \code
308 * make clean
309 * \endcode
310 *
311 * or
312 *
313 * \code
314 * make distclean
315 * \endcode
316 *
317 * which will also delete all autoconf stuff for configure.
318 *
319 * distclean is at times necessary when stuff does not compile and there's
320 * seemingly no logic behind it, i.e. especially when paths of modules have
321 * changed. To recover your configure options, either look at \b config.log in
322 * the build directory or enter
323 *
324 * \code
325 * ./config.status --version
326 * \endcode
[19bc74]327 *
328 * Further useful commands are
[750cff]329 * -# make clean uninstall: deletes .o-files and removes executable from the given
330 * binary directory
331 * -# make doc: Creates these html pages out of the documented source
[0a7834]332 * -# make distcheck: Checks whether the code compiles and all tests runs without
333 * from a distributed archive. This is checked for each release version.
[750cff]334 *
[48d20d]335 * \date 2013-04-09
[19bc74]336 */
Note: See TracBrowser for help on using the repository browser.