source: doc/userguide/userguide.xml@ 708ec1

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 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_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
Last change on this file since 708ec1 was 2082637, checked in by Frederik Heber <heber@…>, 9 years ago

Added Parse- and SaveParticleParametersAction to parse/save ParticleRegistry.

  • added regression test for parsing and saving particles file.
  • Property mode set to 100644
File size: 148.3 KB
Line 
1<?xml version='1.0' encoding='UTF-8'?>
2<!-- This document was created with Syntext Serna Free. --><!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
3<!ENTITY molecuilder_logo SYSTEM "pictures/molecuilder_logo.png" NDATA PNG>
4<!ENTITY dialog_box SYSTEM "pictures/dialog_box.png" NDATA PNG>
5<!ENTITY dialog_add-atom_tooltip SYSTEM "pictures/dialog_add-atom_tooltip.png" NDATA PNG>
6<!ENTITY dialog_complex SYSTEM "pictures/dialog_complex.png" NDATA PNG>
7<!ENTITY dialog_exit SYSTEM "pictures/dialog_exit.png" NDATA PNG>
8<!ENTITY example_basic_view SYSTEM "pictures/example_basic_view.png" NDATA PNG>
9]>
10<book xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xi="http://www.w3.org/2001/XInclude" xmlns:svg="http://www.w3.org/2000/svg" xmlns:m="http://www.w3.org/1998/Math/MathML" xmlns:html="http://www.w3.org/1999/xhtml" xmlns:db="http://docbook.org/ns/docbook" version="5.0">
11 <info>
12 <title>MoleCuilder - a Molecule Builder</title>
13 <author>
14 <personname>
15 <firstname>Frederik</firstname>
16 <surname>Heber</surname>
17 </personname>
18 <affiliation>
19 <orgname>heber@ins.uni-bonn.de</orgname>
20 </affiliation>
21 </author>
22 <pubdate>07/03/14</pubdate>
23 </info>
24 <chapter>
25 <title>Introduction</title>
26 <figure>
27 <title>MoleCuilder logo depicting a tesselated buckyball and a benzene molecule</title>
28 <mediaobject>
29 <imageobject>
30 <imagedata width="100%" scalefit="1" entityref="molecuilder_logo"/>
31 </imageobject>
32 </mediaobject>
33 </figure>
34 <section xml:id="whatis">
35 <title xml:id="whatis.title">What is MoleCuilder?</title>
36 <para>In Short,<command> MoleCuilder</command> is a concatenation of
37 molecule and builder.</para>
38 <para>In more words, molecular dynamics simulations are frequently
39 employed to simulate material behavior under stress, chemical reactions
40 such as of cementitious materials, or folding pathways and docking
41 procedures of bio proteins. Even if the computational load, due to the
42 large number of atoms, is very demanding, nonetheless they may serve as
43 a starting point, e.g. extracting parameters for a coarser model.
44 However, what is on the other hand the starting point of molecular
45 dynamics simulations? It is the coordinate and element of each atom
46 combined with potential functions that model the interactions.</para>
47 <para>MoleCuilder allows to fully construct such a starting point:
48 letting the user construct atomic and molecular geometries by a simple
49 point&amp;click approach, a CAD-pendant on the nanoscale. Creating
50 suitable empirical potentials by fitting parameters to ab-initio
51 calculations within hours. Specific emphasis is placed on a
52 simple-to-use interface, allowing for the quick-and-dirty building of
53 molecular systems, and on scriptability. The last being important a eventually not a single, but
54 many, related molecular systems have to be created.</para>
55 <para>We hope you will enjoy using MoleCuilder as much as we had creating it and still continue extending it. It obtains its flexibility from the use of agile programming techniques and state-of-the-art libraries such as Boost. If you feel dissatiesfied with certain parts, please do not hesitate to give feedback (see below).</para>
56 <section xml:id="installation">
57 <title xml:id="installation.title">Installation requirements</title>
58 <para>For installations requirements and instructions we refer to the
59 internal documentation of MoleCuilder, created via <productname>doxygen</productname>. from the
60 source code.</para>
61 </section>
62 <section xml:id="license">
63 <title xml:id="license.title">License</title>
64 <para>As long as no other license statement is given, MoleCuilder is
65 free for user under the GNU Public License (GPL) Version 2 (see
66 <uri>www.gnu.de/documents/gpl-2.0.de.html</uri>).</para>
67 </section>
68 <section xml:id="disclaimer">
69 <title xml:id="disclaimer.title">Disclaimer</title>
70 <para>We quote section 11 from the GPLv2 license:</para>
71 <remark>Because the program is licensed free of charge, there is not warranty for the program, to the extent permitted by applicable law. Except when otherwise stated in writing in the copyright holders and/or other parties provide the program &quot;as is&quot; without warranty of any kind, either expressed or implied. Including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. The entire risk as to the quality and performance of the program is with you. Should the program prove defective, you assume the cost of all necessary servicing, repair, or correction.</remark>
72 </section>
73 <section xml:id="feedback">
74 <title xml:id="feedback.title">Feedback</title>
75 <para>If you encounter any bugs, errors, or would like to submit
76 feature request, please use the email address provided at the very
77 beginning of this user guide. The author is especially thankful for
78 any description of all related events prior to occurrence of the
79 error, saved &quot;session scripts&quot; (see below) and auxiliary files. Please
80 mind sensible space restrictions of email attachments.</para>
81 </section>
82 <section xml:id="notation">
83 <title xml:id="notation.title">Notation</title>
84 <para>We briefly explain a few specific wordings associated with the
85 program:</para>
86 <itemizedlist>
87 <listitem>
88 <para><emphasis>Action</emphasis> is a command that allows for
89 undoing and redoing, i.e. a single atomic procedure for
90 manipulating the molecular system. Here, atomic refers to indivisible and not to atoms. It is also referred to as a command.</para>
91 </listitem>
92 <listitem>
93 <para>Selection refers to a subsets from the set of instances of a
94 particular type, e.g. atoms, molecules, shapes, ...</para>
95 </listitem>
96 <listitem>
97 <para>Shape means a specific region of the domain that can be
98 described in the way of constructive geometry, i.e. as the
99 intersection, negation, and combination of primitives such as
100 spheres, cubes, or cylinders.</para>
101 </listitem>
102 <listitem>World refers to the whole of the molecular system, i.e. all atoms with coordinates and element type (over all time steps), all bonds between pairs of atoms, the size of the simulation domain. This state is also referred to as the state.</listitem>
103 <listitem>Time step is the current discrete position in time. Molecular dynamics simulations are executed in discrete (but very small) time steps. Each atom has a distinct position per time step. The discrete positions over the discrete time steps samples its trajectory during a simulation.</listitem>
104 </itemizedlist>
105 </section>
106 <section xml:id="completeness">
107 <title xml:id="completeness.title">Completeness</title>
108 <para>This documentation takes quite some effort to write. Hence, the
109 described features and especially the actions herein are settled with
110 respect to their functionality, while newer features or actions are
111 probably missing. This should be a clear sign to you that these are
112 probably not safe to use yet. If you nonetheless require them, you should acquire some familiarity with the code itself. This suggests
113 changing to the developer documentation which is maintained along with
114 the source code with <productname>doxygen</productname>.</para>
115 </section>
116 </section>
117 </chapter>
118 <chapter>
119 <title>Features</title>
120 <para>Basically, <command>MoleCuilder</command> parses geometries from
121 files, manipulates them, and stores them again in files. The manipulation
122 can be done either via a command-line interface or via the graphical user
123 interface.</para>
124 <section xml:id="concepts">
125 <title xml:id="concepts.title">Concepts</title>
126 <para>In general, we divide the molecular systems into three different
127 components or scales.</para>
128 <orderedlist>
129 <listitem>
130 <para>Atoms</para>
131 <para>Atoms are the undividable objects of the molecular systems.
132 They have at least an element <quote>Z</quote> and three coordinates
133 <quote>(x,y,z)</quote>.</para>
134 </listitem>
135 <listitem>
136 <para>Molecules</para>
137 <para>Molecules are bound conglomeration of atoms. They contain a
138 number of atoms, i.e. by beginning at an arbitrary atom of the molecule and traversing its bond graph eventually all of the molecule&apos;s atoms are visited. Currently, a bond refers to a covalent bonding between atoms. Also, molecules may have a
139 bounding box, i.e. a subdomain that contains all of the atoms in the
140 molecule.</para>
141 <para>Note that the molecular structure of the system, i.e. the
142 bonding graph, is determined by MoleCuilder and used to dissect the
143 system into distinct molecules on request.</para>
144 </listitem>
145 <listitem>
146 <para>Clusters</para>
147 <para>Clusters are unbound conglomeration of atoms. Clusters serves
148 as groups of atoms for specific operations that would be to
149 restricted if they worked on just molecules.</para>
150 </listitem>
151 <listitem>
152 <para>Domain</para>
153 <para>The domain refers to the simulation domain. It is the
154 parallelepiped in <inlineequation>
155 <m:math display="inline">
156 <m:mi>\mathbb{R}^3</m:mi>
157 </m:math>
158 </inlineequation>where either periodic, wrapped, or open boundary
159 conditions apply. The domain contains all atoms, i.e. the box
160 containing all atoms.</para>
161 </listitem>
162 </orderedlist>
163 </section>
164 <section xml:id="interfaces">
165 <title xml:id="interfaces.title">Interfaces</title>
166 <para>MoleCuilder has four different interfaces: Command-line, text
167 menu, graphical user interface, and python interface.</para>
168 <orderedlist>
169 <listitem>
170 <para>Command-Line</para>
171 <para>The command-line interface allows to use MoleCuilder
172 non-interactively via a terminal session. The program is executed by
173appending to the shell command a number of commands including all
174 required options that are then executed one after the other. After
175 execution of the last command, the program quits. The command-line
176 interface usually works on a specific file that is given as input,
177 manipulated, analysed, ... via the sequence of commands and
178 eventually all changes are stored in the this file. Hence, the input
179 file acts as the state of the starting configuration that is
180 modified via MoleCuilder.</para>
181 </listitem>
182 <listitem>
183 <para>Text menu</para>
184 <para>The text-menu is similar to the command-line interface with
185 the exception that it allows for interactive sessions. Commands are
186 chosen from a text menu and executed directly after selection by the
187 user.</para>
188 </listitem>
189 <listitem>
190 <para>Graphical interface</para>
191 <para>The graphical interface is based on Qt. It features a full graphical, three-dimensional
192representation of the simulation domain with atoms and
193 their bonds. It allows manipulation in point&amp;click fashion.
194 Commands are selected from pull-down menus and dialogs are used to
195 query the user for all required parameters to such a command.</para>
196 </listitem>
197 <listitem>
198 <para>Python interface</para>
199 <para>The last interface is accessible only within the python
200 programming language. MoleCuilder can be loaded as a module and its
201 commands can be executed with either the python interpreter
202 interactively or via python scripts non-interactively. Note that
203 this allows auxiliary calculations to be performed in pythons whose
204 results may be used as parameters in subsequent commands.</para>
205 </listitem>
206 </orderedlist>
207 </section>
208 <section xml:id="fileformats">
209 <title xml:id="fileformats.title">Known File formats</title>
210 <para>We briefly list the file formats MoleCuilder can parse and
211 store. We refer to external websites for more detailed information where appropriate.</para>
212 <itemizedlist>
213 <listitem>
214 <para>XYZ, <filename>.xyz</filename> (simplest of all formats,
215 line-wise element and three coordinates with two line header, number
216 of lines and a comment line)</para>
217 </listitem>
218 <listitem>
219 <para><link xlink:href="http://www.mpqc.org/">
220 <productname>MPQC </productname>
221 </link>, <filename>.in</filename></para>
222 </listitem>
223 <listitem>
224 <para><link xlink:href="http://www.pdb.org/">PDB</link>, <filename> .pdb</filename></para>
225 </listitem>
226 <listitem>
227 <para><productname>ESPACK</productname>, <filename>.conf</filename>
228 (electronic structure package by Institute for Numerical Simulation,
229 University of Bonn, code not in circulation)</para>
230 </listitem>
231 <listitem>
232 <para><link xlink:href="http://www.psicode.org/">
233 <productname>PSI4 </productname>
234 </link>, <filename>.psi</filename></para>
235 </listitem>
236 <listitem>
237 <para><link xlink:href="http://www.tremolo-x.org/">
238 <productname> TREMOLO</productname>
239 </link>, <filename>.data</filename></para>
240 </listitem>
241 <listitem>
242 <para>XML, <filename>.xml</filename> (XML as read by
243 <link xlink:href="http://www.scafacos.org/">ScaFaCoS</link>
244 project)</para>
245 </listitem>
246 </itemizedlist>
247 <para>These are identified via their suffixes and can be converted from
248 one into another (with possible loss of data outside of the intersection of
249 stored properties of the two involved file formats).</para>
250 </section>
251 </chapter>
252 <chapter>
253 <title>Interfaces</title>
254 <para>In this chapter, we explain the intention and use of the four
255 interfaces.</para>
256 <para>We will give the most extensive explanation of the command-line
257 interface, all subsequent interfaces are explained in highlighting their
258 differences with respect to the command-line interface. This is because
259 the command-line lends itself very well to representation in this textual
260 user guide. Although some images of the graphical interface are given
261 below, they would blow the size of the guide out of proportion.</para>
262 <para>In any case, you should make yourself familiar with at least one of
263 the interactive (text menu, GUI) and one of the non-interactive
264 (command-line, python) interfaces to use MoleCuilder to its full potential:
265 The interactive interface gives you the immediate feedback in constructing
266 &quot;synthesis&quot; (build) chains (of commands) for constructing your specific
267 molecular system in the computer. The non-interactive interface lends
268 itself to quick creation of related systems that differ only by specific
269 parameters you have modified in the script (command-line can be used in
270 shell scripts, python itself is a scripted language). Also, the
271 non-interactive interfaces are used for storing sessions which helps you
272 in documentation your experiments and later on understanding of what has
273 been actually created by the prescribed commands, i.e. debugging.</para>
274 <section xml:id="command-line-interface">
275 <title xml:id="command-line-interface.title">Command-line interface</title>
276 <para>The command-line interface reads options and commands from the
277 command line and executes them sequentially. This may be for example:
278 Open an empty file, add 2 hydrogen atoms and add 1 oxygen atom, recognize the bond graph, choose a
279 simulation box, fill the box with this given &quot;filler&quot; molecule, save the
280 file. This enables the use of MoleCuilder in simple script-files to
281 create a whole range of geometries that only differ in a few parameters
282 automatically.</para>
283 <para>Traditionally, <command>MoleCuilder</command> operates on a single
284 configuration file - the state - which may also store additional
285 information depending on the chosen file format such as parameters for
286 ab-initio computations. To some small extent <command>MoleCuilder</command> also allows manipulation of these paramters. An example for the above procedure is given
287 below:</para>
288 <programlisting>
289 ./molecuilder \
290 -i sample.xyz \
291 --add-atom H \
292 --domain-position &quot;0.,0.,0.&quot; \
293 ...
294 </programlisting>
295 <para>The first argument is the executable itself. Second, there is a
296 slew of arguments -- one per line split with a backslash telling the comman
297 shell that the line still continues -- consisting of the input action and
298 an arbitrarily named file <filename>sample.xyz</filename>, which may be
299 empty and whose file format is chosen by the given extension. The third
300 is the add-atom action following by an option that gives the position in
301 the domain where to add the &quot;H&quot;ydrogen atom. An action is always
302 introduced via a double hyphen and its full name (containing just
303 non-capital letters and hyphens) or a single hyphen and a single letter
304 for its shortform, such as <emphasis role="bold"> -a</emphasis> for adding an atom to the system. It is
305 followed by a fixed number of options. Most of these have default values
306 and in this do not have to be specified.</para>
307 <formalpara><title>Invalid values</title><para>Certain options accept only very specific input. For example, the option value associated with <emphasis role="bold">add-atom</emphasis></para>, i.e. the chemical element, can only be one of the chemical symbols that exist and not any arbitrary string. Each option value is checked on parsing the command-line. If any value is not valid, an error message is given and none of the actions is executed.</formalpara>
308 <formalpara>
309 <title>Shortforms of Actions</title>
310 <para>Note that not all action have shortforms and it is best practice
311 to have the full action name instead of its shortform to make the
312 command-line comprehendable to you in years to come.</para>
313 </formalpara>
314 <note>
315 <para>Note further that when placing a slew of commands in a script file it is generally recommended to use the above formatting: One command or option per line and each</para>
316 <para>option receives an extra tab for indentation.</para>
317 </note>
318 <section xml:id="preliminaries">
319 <title xml:id="preliminaries.title">Preliminaries</title>
320 <para>Some preliminary remarks are in order which we have gathered
321 here on how these actions work in general.</para>
322 <para>We first delve into some details about secondary structure
323 such as selections, shapes, and randomization required to specify
324 subsets of atoms and molecules you wish to manipulate. Then, we have
325give the details on the manipulation ordered by the
326 scale they act upon - single atoms, multiple atoms organized as
327 molecules, and all atoms organized by their containing domain.</para>
328 <para>In the following we will always give a command to illustrate the
329 procedure but just its necessary parts, i.e. &quot;...&quot; implies to prepend
330 it with the executable and input command for a specific configuration
331 file, for storing the manipulated state of the molecular system. </para>
332 <para>So if we write</para>
333 <programlisting>... --help</programlisting>
334 <para>Then we actually mean you to write</para>
335 <programlisting>./molecuilder --help</programlisting>
336 <para>Note that this specific exemplary command is very useful as it will always give you a list of all available actions and also a
337 brief explanation on how to properly enter values of a specific type,
338 e.g. an element, a vector, or a list of numbers. Details to a specific
339 action can be requested when its full name is known, e.g. for
340 &quot;add-atom&quot;,</para>
341 <programlisting>./molecuilder --help add-atom</programlisting>
342 <para>which fills you in on each option to the action: its full name,
343 its expected type, and a possibly present default value, and a brief
344 description of the option.</para>
345 <para>An Action can be undone and redone, e.g. undo adding an atom as
346 follows,</para>
347 <programlisting>... --add-atom H --domain-position &quot;0,0,0&quot; --undo</programlisting>
348 <para>and redo as follows</para>
349 <programlisting>... --add-atom H --domain-position &quot;0,0,0&quot; --undo --redo</programlisting>
350 <para>With the non-interactive interfaces this may seem rather
351 superfluous but it comes in very handy in the interactive ones. Also
352 this should tell you that actions are placed internally in a queue, i.e. a history,
353 that undo and redo manipulate.</para>
354 <para>Due to a current limitation of the implementation each command can be used on the command-line only once. Note that this <emphasis role="italic">only</emphasis> applies to the command-line interface. All other interfaces, especially all interactive ones, do not have such a restriction. For the command-line interface there are several ways to work around it. Either by splitting the whole chain of commands into several chunks, each using only unique commands and using the input file (the state) to contain and transport the intermediate stages as input for the next stage. Or to switch to other commands: often there are several possible ways of achieving a goal, especially when using selections.</para>
355 <para>Being done now with the preliminaries we now go through all available actions present in MoleCuilder.</para>
356 </section>
357 <section xml:id="fileparsers">
358 <title xml:id="fileparsers.title">File parsers</title>
359 <para>We have already given a list of all known file formats, see
360 <link linkend="fileformats">File formats</link>. Next, we explain how these
361 file formats are picked and manipulated.</para>
362 <section xml:id="fileparsers.parsing">
363 <title xml:id="fileparsers.parsing.title">Parsing files</title>
364 <para>We already discussed that the command-line interface works
365 state-based and hence you should supply it with a file to work
366 on.</para>
367 <programlisting>... --input water.data</programlisting>
368 <para>This will load all information, especially atoms with their
369 element and position, from the file <filename>water.data</filename>
370 into the state. Most importantly, all changes will eventually be stored to this file,
371 or to files with the prefix <filename>water</filename> and suffixes
372 of desired file formats, e.g. <filename>water.in</filename> if you
373 specified <productname>MPQC</productname>.</para>
374 <programlisting>... --load morewater.xyz</programlisting>
375 <para>This will load another file <filename>water.xyz</filename>,
376 however changes will still be written to files prefixed with
377 <filename>water</filename> as designated by the <emphasis role="bold">input</emphasis> command. Note that now already two state files
378 will stored, <filename>water.data</filename> and
379 <filename>water.xyz</filename> as these two different file formats
380 have been used. This is the default behavior: any additional file format used in loading is registered internally and the output file will then be written in all registered formats on exit.</para>
381 </section>
382 <section xml:id="fileparsers.set-output">
383 <title xml:id="fileparsers.set-output.tile">Adding output file formats</title>
384 <para>We already know that loading a file also picks a file format
385 by its suffix. We may add further file formats to which the state of
386 the molecular system is written to on program exit.</para>
387 <programlisting>... --set-output mpqc tremolo</programlisting>
388 <para>This will store the final state of the molecular systems as
389 <productname>MPQC</productname> and as
390 <productname>TREMOLO</productname> configuration file. See
391 <link linkend="fileformats">File formats</link> for the list of all file formats available.</para>
392 </section>
393 <section xml:id="fileparsers.output-as">
394 <title xml:id="fileparsers.output-as.title">Output the World</title>
395 <para>This will store the current World, i.e. all its atoms, to a
396 given file, where the output format is determined from the file
397 suffix.</para>
398 <programlisting>... --output-as world.xyz</programlisting>
399 <para>This will be automatically done on program exit, but in case an intermediate state is required (making sense for interactive and python interfaces), this command can be used.</para>
400 </section>
401 <section xml:id="fileparsers.save-selected-molecules">
402 <title xml:id="fileparsers.save-selected-molecules.title">Output the current molecular system</title>
403 <para>This will store all atoms contained in the currently selected
404 molecules to file. This is different to<emphasis role="bold">store-saturated-fragment</emphasis>
405 as it will not saturate dangling bonds because only whole molecules,
406 i.e. whose bond graph is connected, will be stored.</para>
407 <programlisting>... --save-selected-molecules waters.pdb
408 </programlisting>
409 </section>
410 </section>
411 <section xml:id="selections">
412 <title xml:id="selections.title">Selections and unselections</title>
413 <para>In order to tell MoleCuilder on what subset of atoms a specific
414 Action is to be performed, there are <emphasis>selection actions</emphasis>. Note that a selection per se does not change
415 anything in the state of the molecular system in any way. Essentially, it is just a filter.</para>
416 <para>Selections either work on atoms, on molecules, or on shapes
417 (this we explain later on). A given selection is maintained from the
418 execution of the selection action to the end of program or until
419 modified by another selection applied on the same type (atom,
420 molecule, shape). Selections are not stored to file (i.e. do not belong to the state).</para>
421 <para>We only give here a brief list on the available kind of selections for each of the three types they work on.
422Each action is executed either as follows, exemplified by selecting
423 all atoms.</para>
424 <programlisting>.... --select-all-atoms</programlisting>
425 <para>or, exemplified by unselecting the last molecule,</para>
426 <programlisting>... --unselect-molecule-by-order -1</programlisting>
427 <para>i.e. they are prepended by either <emphasis role="bold">select</emphasis> or <emphasis role="bold">unselect</emphasis>.</para>
428 <itemizedlist>
429 <listitem>
430 <para>Atoms</para>
431 <itemizedlist>
432 <listitem>
433 <para>All</para>
434 <programlisting>
435 ... --select-all-atoms
436 </programlisting>
437 </listitem>
438 <listitem>
439 <para>None</para>
440 <programlisting>
441 ... --unselect-all-atoms
442 </programlisting>
443 <programlisting>
444 ... --clear-atom-selection
445 </programlisting>
446 </listitem>
447 <listitem>
448 <para>Invert selection</para>
449 <programlisting>
450 ... --invert-atoms
451 </programlisting>
452 </listitem>
453 <listitem>
454 <para>By Element (all hydrogen atoms, all sulphur atoms,
455 ...)</para>
456 <programlisting>
457 ... --select-atom-by-element 1
458 </programlisting>
459 <programlisting>
460 ... --unselect-atom-by-element 1
461 </programlisting>
462 </listitem>
463 <listitem>
464 <para>By Id (atom with id 76)</para>
465 <programlisting>
466 ... --select-atom-by-id 76
467 </programlisting>
468 <programlisting>
469 ... --unselect-atom-by-id 76
470 </programlisting>
471 </listitem>
472 <listitem>
473 <para>By Order (the first (1), the second, ... the last
474 created(-1), the last but one)</para>
475 <programlisting>
476 ... --select-atom-by-order 1
477 </programlisting>
478 <programlisting>
479 ... --unselect-atom-by-order -2
480 </programlisting>
481 </listitem>
482 <listitem>
483 <para>By Shape (all atoms inside the volume specified by the currently selected shape)</para>
484 <programlisting>
485 ... --select-atom-inside-volume
486 </programlisting>
487 <programlisting>
488 ... --unselect-atoms-inside-volume
489 </programlisting>
490 </listitem>
491 <listitem>
492 <para>By Molecule (all atoms belonging to currently selected
493 molecules)</para>
494 <programlisting>
495 ... --select-molecules-atoms
496 </programlisting>
497 <programlisting>
498 ... --unselect-molecules-atoms
499 </programlisting>
500 </listitem>
501 <listitem>
502 <para>Push/Pop the current selection to/from a stack to store
503 it momentarily and allow modifications in MakroActions (this is very specific and used mostly internally).</para>
504 <programlisting>
505 ... --push-atom-selection
506 </programlisting>
507 <programlisting>
508 ... --pop-atom-selection
509 </programlisting>
510 </listitem>
511 </itemizedlist>
512 </listitem>
513 <listitem>
514 <para>Molecules</para>
515 <itemizedlist>
516 <listitem>
517 <para>All</para>
518 <programlisting>
519 ... --select-all-molecules
520 </programlisting>
521 </listitem>
522 <listitem>
523 <para>None</para>
524 <programlisting>
525 ... --unselect-all-molecules
526 </programlisting>
527 <programlisting>
528 ... --clear-molecule-selection
529 </programlisting>
530 </listitem>
531 <listitem>
532 <para>Invert selection</para>
533 <programlisting>
534 ... --invert-molecules
535 </programlisting>
536 </listitem>
537 <listitem>
538 <para>By Id (molecule with id 4)</para>
539 <programlisting>
540 ... --select-molecule-by-id 2
541 </programlisting>
542 <programlisting>
543 ... --unselect-molecule-by-id 2
544 </programlisting>
545 </listitem>
546 <listitem>
547 <para>By Order (first created molecule, second created
548 molecule, ...)</para>
549 <programlisting>
550 ... --select-molecule-by-order 2
551 </programlisting>
552 <programlisting>
553 ... --unselect-molecule-by-order -2
554 </programlisting>
555 </listitem>
556 <listitem>
557 <para>By Formula (molecule with H2O as formula)</para>
558 <programlisting>
559 ... --select-molecules-by-formula &quot;H2O&quot;
560 </programlisting>
561 <programlisting>
562 ... --unselect-molecules-by-formula &quot;H2O&quot;
563 </programlisting>
564 </listitem>
565 <listitem>
566 <para>By Name (all molecules named &quot;water4&quot;)</para>
567 <programlisting>
568 ... --select-molecules-by-name &quot;water4&quot;
569 </programlisting>
570 <programlisting>
571 ... --unselect-molecules-by-name &quot;water4&quot;
572 </programlisting>
573 </listitem>
574 <listitem>
575 <para>By Atom (all molecules for which at least one atom is
576 currently selected)</para>
577 <programlisting>
578 ... --select-atoms-molecules
579 </programlisting>
580 <programlisting>
581 ... --unselect-atoms-molecules
582 </programlisting>
583 </listitem>
584 <listitem>
585 <para>Push/Pop the current selection to/from a stack to store
586 it momentarily and allow modifications in MakroActions.</para>
587 <programlisting>
588 ... --push-molecule-selection
589 </programlisting>
590 <programlisting>
591 ... --pop-molecule-selection
592 </programlisting>
593 </listitem>
594 </itemizedlist>
595 </listitem>
596 <listitem>
597 <para>Shapes</para>
598 <itemizedlist>
599 <listitem>
600 <para>All</para>
601 <programlisting>
602 ... --select-all-shapes
603 </programlisting>
604 </listitem>
605 <listitem>
606 <para>None</para>
607 <programlisting>
608 ... --unselect-all-shapes
609 </programlisting>
610 </listitem>
611 <listitem>
612 <para>By Name (all shapes named &quot;sphere1&quot;)</para>
613 <programlisting>
614 ... --select-shape-by-name &quot;sphere1&quot;
615 </programlisting>
616 <programlisting>
617 ... --unselect-shape-by-name &quot;sphere1&quot;
618 </programlisting>
619 </listitem>
620 </itemizedlist>
621 </listitem>
622 </itemizedlist>
623 <remark>Note that an unselected instance (e.g. an atom) remains unselected upon further unselection and vice versa with selection.</remark>
624 <para>These above selections work then in conjunction with other
625 actions and make them very powerful, e.g. you can remove all atoms
626 inside a sphere by a selecting the spherical shape and subsequently
627 selecting all atoms inside the shape and then removing them.</para>
628 </section>
629 <section xml:id="shapes">
630 <title xml:id="shapes.title">Shapes</title>
631 <para>Shapes are specific regions of the domain. There are just a few
632 so-called <emphasis>primitive</emphasis> shapes such as cuboid,
633 sphere, cylinder, the whole domain, or none of it. However, these can be
634 combined via boolean operations such as and, or, and not. This
635 approach is called <emphasis>constructive geometry</emphasis>. E.g. by
636 combining a sphere with the negated (<emphasis role="italic">not</emphasis> operation) of a smaller sphere, we
637 obtain a spherical surface of specific thickness.</para>
638 <section xml:id="shapes.create-shape">
639 <title xml:id="shapes.create-shape.title">Creating shapes</title>
640 <para>Primitive shapes can be created as follows,</para>
641 <programlisting>
642 ... --create-shape \
643 --shape-type sphere \
644 --shape-name &quot;sphere1&quot; \
645 --stretch &quot;2,2,2&quot; \
646 --translation &quot;5,5,5&quot;
647 </programlisting>
648 <para>This will create a sphere of radius 2 (initial radius is 1)
649 with name &quot;sphere1&quot; that is centered at (5,5,5). Other primitives are
650 cuboid and cylinder, where a rotation can be specified as
651 follows.</para>
652 <programlisting><programlisting>
653 ... --create-shape \
654 --shape-type cuboid \
655 --shape-name &quot;box&quot; \
656 --stretch &quot;1,2,2&quot; \
657 --translation &quot;5,5,5&quot; \
658 --angle-x &quot;90&quot;
659 </programlisting>
660 ... --create-shape \
661 --shape-type cylinder \
662 --shape-name &quot;cylinder&quot; \
663 --stretch &quot;1,2,2&quot; \
664 --translation &quot;5,5,5&quot; \
665 --angle-y &quot;90&quot;
666 </programlisting>
667 </section>
668 <section xml:id="shapes.combine-shapes">
669 <title xml:id="shapes.combine-shapes.title">Combining shapes</title>
670 <para>Any two shapes can be combined by boolean operations as follows</para>
671 <programlisting>
672 ... --combine-shapes \
673 --shape-name &quot;combinedshape&quot; \
674 --shape-op &quot;AND&quot;
675 </programlisting>
676 <para>This will combine two currently selected shapes vis the &quot;AND&quot; operation
677 and create a new shape called &quot;combinedshape&quot;. Note that the two old shapes
678 are still present after this operation. We briefly explain each operation:
679 </para>
680 <itemizedlist>
681 <listitem>
682 <para><emphasis>AND</emphasis> combines two currently selected shapes
683 into a new shape that consists of only the volume where shapes overlap.</para>
684 </listitem>
685 <listitem>
686 <para><emphasis>OR</emphasis> combines two currently selected shapes
687 into a new shape that consists of all the volume that either shape
688 occupies.</para>
689 </listitem>
690 <listitem>
691 <para><emphasis>NOT</emphasis> creates the inverse to a currently selected
692 single shape that contains the volume with respect to the simulation domain
693 that the present one does not.</para>
694 </listitem>
695 </itemizedlist>
696 </section>
697 <section xml:id="shapes.remove-shape">
698 <title xml:id="shapes.remove-shape.title">Removing shapes</title>
699 <para>Removing a shape is as simple as removing an atom.</para>
700 <programlisting>... --remove-shape </programlisting>
701 <para>This removes all currently selected shapes.</para>
702 </section>
703 <section xml:id="shapes.manipulation">
704 <title xml:id="shapes.manipulation.title">Manipulating shapes</title>
705 <para>Shapes can be stretched, scaled, rotated, and translated to
706 modify primitives or combined primitive shapes. As you have seen
707 this manipulation could have occurred already at creation but we may also
708do it later on. As usual, we just list examples of the various manipulations
709 below, each of them works on the currently selected shapes.</para>
710 <programlisting>
711 ... --stretch-shapes &quot;1,1,2&quot; \
712 --stretch-center &quot;5,5,5&quot;
713 </programlisting>
714 <para>This stretches the shapes relative to the center at (5,5,5)
715 (default is origin) by a factor of 2 in the z direction.</para>
716 <programlisting>
717 ... --rotate-shapes \
718 --center &quot;10,2,2&quot; \
719 --angle-x 90 \
720 --angle-y 0 \
721 --angle-z 0
722 </programlisting>
723 <para>This way all selected shapes are rotated by 90 degrees around
724 the x axis with respect to the center at (10,2,2).</para>
725 <programlisting>... --translate-shapes &quot;5,0,0&quot; </programlisting>
726 <para>This translates all selected shapes by 5 along the x
727 axis.</para>
728 </section>
729 </section>
730 <section xml:id="randomization">
731 <title xml:id="randomization.title">Randomization</title>
732 <para>Some operations require randomness as input, e.g. when filling a
733 domain with molecules these may be randomly translated and rotated.
734 Random values are obtained by a random number generator that consists
735 of two parts: engine and distribution. The engine yields a <emphasis role="italic">uniform</emphasis> set
736 of random numbers in a specific interval, the distribution modifies
737 them, e.g. to become gaussian.</para>
738 <para>There are several Actions to modify the specific engine and
739 distribution and their parameters. One example usage is that with the
740 aforementioned filling of the domain (see below) molecules are rotated randomly.
741 If you specify a random number generator that randomly just spills out
742 values 0,1,2,3, then the randomness is just the orientation of the
743 molecule with respect to a specific axis: x,y,z. (rotation is at most
744 360 degrees and 0,1,2,3 act as divisor, hence rotation angle will then be always
745 a multiple of 90 degrees).</para>
746 <programlisting>
747 ... --set-random-number-distribution &quot;uniform_int&quot; \
748 --random-number-distribution-parameters &quot;p=1&quot;
749 </programlisting>
750 <para>This changes the distribution to &quot;uniform_int&quot;, i.e. integer
751 numbers that are distributed uniformly.</para>
752 <programlisting>
753 ... --set-random-number-engine &quot;mt19937&quot; \
754 --random-numner-engine-parameters &quot;seed=10&quot;
755 </programlisting>
756 <para>Specifying the seed allows you to obtain the same sequence of
757 random numbers for testing purposes.</para>
758 </section>
759 <section xml:id="atoms">
760 <title xml:id="atoms.title">Manipulate atoms</title>
761 <para>Here, we explain in detail how to add, remove atoms, change its
762 element type, scale the bond in between or measure the bond length or
763 angle.</para>
764 <section xml:id="atoms.add-atom">
765 <title xml:id="atoms.add-atom.title">Adding atoms</title>
766 <para>Adding an atom to the domain requires the element of the atom
767 and its coordinates as follows,</para>
768 <programlisting>
769 ... --add-atom O \
770 --domain-position &quot;2.,3.,2.35&quot;
771 </programlisting>
772 <para>where the element is given via its chemical symbol and the
773 vector gives the position within the domain</para>
774 </section>
775 <section xml:id="atoms.remove-atom">
776 <title xml:id="atoms.remove-atom.title">Removing atoms</title>
777 <para>Removing atom(s) does not need any option and operates on the
778 currently selected ones.</para>
779 <programlisting>... --remove-atom</programlisting>
780 </section>
781 <section xml:id="atoms.saturate-atom">
782 <title xml:id="atoms.saturate-atom.title">Saturating atoms</title>
783 <para>Newly instantiated atoms have no bonds to any other atom. If
784 you want to fill up their valence by a slew of hydrogen atoms
785 residing on a sphere around this atom, use this action.</para>
786 <programlisting>
787 ... --saturate-atoms
788 </programlisting>
789 <para>A number of hydrogen atoms is added around each selected atom corresponding to the valence of the chemical element. The hydrogen atoms are placed in the same
790 distance to this atom and approximately with same distance to their
791 nearest neighbors. Already present bonds (i.e. the position of neighboring atoms) is taken into account.</para>
792 </section>
793 <section xml:id="atoms.translate-atom">
794 <title xml:id="atoms.translate-atom.title">Translating atoms</title>
795 <para>In order to translate the current selected subset of atoms you
796have to specify a translation vector.</para>
797 <programlisting>
798 ... --translate-atoms &quot;-1,0,0&quot; \
799 --periodic 0
800 </programlisting>
801 <para>This translates all atoms by &quot;-1&quot; along the x axis and does not
802 mind the boundary conditions, i.e. it might shift atoms outside of the
803 domain.</para>
804 </section>
805 <section xml:id="atoms.mirror-atoms">
806 <title xml:id="atoms.mirror-atoms.title">Mirroring atoms</title>
807 <para>Present (and selected) atoms can be mirrored with respect to
808 a certain plane. You have to specify the normal vector of the plane
809 and the offset with respect to the origin as follows</para>
810 <programlisting>
811 ... --mirror-atoms &quot;1,0,0&quot; \
812 --plane-offset 10.1 \
813 --periodic 0
814 </programlisting>
815 </section>
816 <section xml:id="atoms.translate-to-origin">
817 <title xml:id="atoms.translate-to-origin.title">Translating atoms to origin</title>
818 <para>The following Action is convenient to place a subset of atoms
819 at a known position, the origin, and then translate them to some other
820 absolute coordinate. It calculates the average position of the set
821 of selected atoms and then translates all atoms by the negative of
822 this center, i.e. the center over all selected atoms is afterwards at the origin.</para>
823 <programlisting>... --translate-to-origin</programlisting>
824 <para>Note that this naturally does not heed the boundary conditions of the simulation domain.</para>
825 </section>
826 <section xml:id="atoms.change-element">
827 <title xml:id="atoms.change-element.title">Changing an atoms element </title>
828 <para>You can easily turn lead or silver into gold, by selecting the
829 silver atom and calling the change element action.</para>
830 <programlisting>... --change-element Au</programlisting>
831 </section>
832 </section>
833 <section xml:id="bond">
834 <title xml:id="bond.title">Bond-related manipulation</title>
835 <para>Atoms can also be manipulated with respect to the bonds.
836 <remark>Note that with bonds we always mean covalent bonds.</remark> First, we explain how to modify the bond structure itself, then we go
837 in the details of using the bond information to change bond distance
838 and angles.</para>
839 <section xml:id="bond.create-adjacency">
840 <title xml:id="bond.create-adjacency.title">Creating a bond graph </title>
841 <para>In case you have loaded a configuration file with no bond
842 information, e.g. XYZ, it is necessary to create the bond graph.
843 This is done by a heuristic distance criterion.</para>
844 <programlisting>... --create-adjacency</programlisting>
845 <para>This uses by default a criterion based on van-der-Waals radii,
846 i.e. if we look at two atoms indexed by &quot;a&quot; and &quot;b&quot;</para>
847 <equation>
848 <title>V(a) + V(b) - \tau &lt; R_{ab} &lt; V(a) + V(b) + \tau</title>
849 <m:math display="block">
850 <m:mi>where V(.) is the lookup table for the radii for a given element and \tau is a threshold value, set to 0.4.</m:mi>
851 </m:math>
852 </equation>
853 <para>As a second option, you may load a file containing bond table
854 information.</para>
855 <programlisting>... --bond-table table.dat</programlisting>
856 <para>which would parse a file <filename>table.dat</filename> for a
857 table giving typical bond distances between elements a and b. These
858 are used in the above criterion as <inlineequation>
859 <m:math display="inline">
860 <m:mi>V(a,b)</m:mi>
861 </m:math>
862 </inlineequation> in place of <inlineequation>
863 <m:math display="inline">
864 <m:mi>V(a)+V(b)</m:mi>
865 </m:math>
866 </inlineequation>.</para>
867 </section>
868 <section xml:id="bond.destroy-adjacency">
869 <title xml:id="bond.destroy-adjacency.title">Destroying the bond graph</title>
870 <para>The bond graph can be removed completely (and all bonds along
871 with it).</para>
872 <programlisting>... --destroy-adjacency</programlisting>
873 </section>
874 <section xml:id="bond.correct-bonddegree">
875 <title xml:id="bond.correct-bonddegree.title">Correcting bond degrees</title>
876 <para>Typically, after loading an input file with bond information, e.g.
877 a PDB file, the bond graph is complete but we lack the weights. That
878 is we do not know whether a bond is single, double, triple, ...
879 This action corrects the bond degree by enforcing charge neutrality
880 among the connected atoms.
881 </para>
882 <para>This action is in fact quadratically scaling in the number of
883 atoms. Hence, for large systems this may take longer than expected.
884 </para>
885 <programlisting>... --correct-bonddegree</programlisting>
886 <para>However, in normal use scenarios the action is fast and linear scaling.</para>
887 </section>
888 <section xml:id="bond.depth-first-search">
889 <title xml:id="bond.depth-first-search.title">Analysing a bond graph</title>
890 <para>You can perform a depth-first search analysis that reveals
891 cycles and other graph-related information.</para>
892 <programlisting>... --depth-first-search</programlisting>
893 <para>Note that this will only print some information and has no other impact on the state.</para>
894 </section>
895 <section xml:id="bond.subgraph-dissection">
896 <title xml:id="bond.subgraph-dissection.title">Dissecting the molecular system into molecules</title>
897 <para>The bond graph information can be used to recognize the
898 molecules within the system. Imagine you have just loaded a PDB file
899 containing bond information. However, initially all atoms are dumped
900 into the same molecule. Before you can start manipulating, you need
901 to dissect the system into individual molecules. Note that this is
902 just structural information and does not change the state of the
903 system.</para>
904 <programlisting>... --subgraph-dissection</programlisting>
905 <para>This analyses the bond graph, removes all currently present molecules and creates new molecules that each contain a single connected
906 subgraph, hence the naming of the Action.</para>
907 </section>
908 <section xml:id="bond.update-molecules">
909 <title xml:id="bond.update-molecules.title">Updating molecule structure</title>
910 <para>When the bond information has changed, new molecules might
911 have formed, this action updates all the molecules by scanning
912 the connectedness of the bond graph of the molecular system.
913 </para>
914 <programlisting>... --update-molecules</programlisting>
915 </section>
916 <section xml:id="bond.adds-bond">
917 <title xml:id="bond.adds-bond.title">Adding a bond manually</title>
918 <para>When the automatically created adjacency or bond graph
919 contains faulty bonds or lacks some, you can add them manually.
920 </para>
921 <programlisting>... --add-bonds</programlisting>
922 <para>If two atoms are selected, the single bond in between is added, if not
923already present. If more than two atoms are selected, than the
924 bond between any pair of these is added.</para>
925 <note>
926 <para>This is especially useful in conjunction with the
927 fragmentation scheme (explained later on). If you want to know the contribution from
928 certain fragments whose subgraph is not connected, you can simply
929 make the associated subset of atoms connected by selecting all
930 bonds and adding the bonds.</para>
931 </note>
932 </section>
933 <section xml:id="bond.remove-bonds">
934 <title xml:id="bond.remove-bonds.title">Removing a bond manually </title>
935 <para>In much the same way as adding a bond, you can also remove a
936 bond.</para>
937 <programlisting>... --remove-bonds</programlisting>
938 <para>Similarly, if more than two atoms are selected, then all bonds
939 found between any pair of these is removed.</para>
940 </section>
941 <section xml:id="bond.save-bonds">
942 <title xml:id="bond.save-bonds.title">Saving bond information </title>
943 <para>Bond information can be saved to a file in <link xlink:href="http://www.molecuilder.com/">
944 <productname>TREMOLO </productname>
945 </link>&apos;s dbond style.</para>
946 <programlisting>... --save-bonds system.dbonds</programlisting>
947 <para>Similarly is the following Action which saves the bond
948 information as a simple list of one atomic id per line and in
949 the same line, separated by spaces, the ids of all atoms connected
950 to it.</para>
951 <programlisting>... --save-adjacency system.adj</programlisting>
952 <para>This corresponds to the <emphasis role="bold">bond-file</emphasis> Action.</para>
953 </section>
954 <section xml:id="fileparsers.bond-file">
955 <title xml:id="fileparsers.bond-file.title">Load extra bond information</title>
956 <para>The reverse Action of <emphasis role="bold">save-bonds</emphasis> is the following which loads bond information from the file <emphasis role="bold">water.dbond</emphasis>.</para>
957 <programlisting>... --bond-file water.dbond</programlisting>
958 <para>Note that because of the use of ids the bond file is intimately connected to the associated input file containing the atomic coordinates and thus both should parsed right after another and to the very beginning of any sequence of Actions.</para>
959 </section>
960 <section xml:id="bond.stretch-bond">
961 <title xml:id="bond.stretch-bond.title">Stretching a bond</title>
962 <para>Stretching a bond actually refers to translation of the
963 associated pair of atoms. However, this action will keep the rest of
964 the molecule to which both atoms belong to invariant as well.</para>
965 <programlisting>... --stretch-bond 1.2</programlisting>
966 <para>This scales the original bond distance to the new bond
967 distance 1.2, shifting the right hand side and the left hand side of
968 the molecule accordingly.</para>
969 <warning>
970 <para>this fails with aromatic rings (but you can always
971 undo).</para>
972 </warning>
973 </section>
974 <section xml:id="bond.change-bond-angle">
975 <title xml:id="bond.change-bond-angle.title">Changing a bond angle </title>
976 <para>In the same way as stretching a bond, you can change the angle
977 in between two bonds. This works if exactly three atoms are selected
978 and two pairs are bonded.</para>
979 <programlisting>... --change-bond-angle 90</programlisting>
980 <para>This will change the angle from its value to 90 degrees by
981 translating the two outer atoms of this triangle (the atom connected
982 to both other atoms serves as rotation joint).</para>
983 </section>
984 </section>
985 <section xml:id="molecule">
986 <title xml:id="molecule.title">Manipulate molecules</title>
987 <para>Molecules are agglomerations of atoms that are (covalently) bonded. Hence,
988 the Actions working on molecules differ from those working on atoms.
989 Joining two molecules can only be accomplished by adding a bond in
990 between, and in the reverse fashion splitting a molecule by removing
991some or even all bonds in between. The Actions below mostly deal with copying
992 molecules. Removing of molecules is done via selecting the molecule&apos;s
993 atoms and removing them, which removes the atoms as well.</para>
994 <note>
995 <para>Initially when you load a file via the input action all atoms
996 are placed in a single molecule despite any present bond
997 information, see <link linkend="fragmentation">Dissecting the molecular system into molecules</link></para>
998 </note>
999 <section xml:id="molecule.copy">
1000 <title xml:id="molecule.copy.title">Copy molecules</title>
1001 <para>A basic operation is to duplicate a molecule. This works on a
1002 single, currently selected molecule. Afterwards, we elaborate on a
1003 more complex manner of copying, filling a specific shape with
1004 molecules.</para>
1005 <programlisting>
1006 ... --copy-molecule \
1007 --position &quot;10,10,10&quot;
1008 </programlisting>
1009 <para>This action copies the selected molecule and inserts it at the
1010 position (10,10,10) in the domain with respect to the molecule&apos;s
1011 center. In effect, it copies all the atoms of the original molecule
1012 and adds new bonds in between these copied atoms such that their
1013 bond subgraphs are identical.</para>
1014 </section>
1015 <section xml:id="molecule.change-molname">
1016 <title xml:id="molecule.change-molname.title">Change a molecules name</title>
1017 <para>You can change the name of a molecule which is important for
1018 selection.</para>
1019 <programlisting>... -change-molname &quot;test</programlisting>
1020 <para>This will change the name of the (only) selected molecule to
1021 &quot;test&quot;.</para>
1022 <para>Connected with this is the default name an unknown molecule
1023 gets.</para>
1024 <programlisting>... --default-molname test</programlisting>
1025 <para>This will change the default name of new molecules to
1026 &quot;test&quot;.</para>
1027 <note>
1028 <para>Note that a molecule loaded from file gets the filename
1029 (without suffix) as its name.</para>
1030 </note>
1031 </section>
1032 <section xml:id="molecule.remove-molecule">
1033 <title xml:id="molecule.remove-molecule.title">Remove molecules </title>
1034 <para>This removes one or multiple selected molecules.</para>
1035 <programlisting>... -remove-molecule</programlisting>
1036 <para>This essentially just removes all of the molecules&apos; atoms
1037 which in turn also causes the removal of the molecule.</para>
1038 </section>
1039 <section xml:id="molecule.translate-molecules">
1040 <title xml:id="molecule.translate-molecules.title">Translate molecules </title>
1041 <para>This translates one or multiple selected molecules by a
1042 specific offset..</para>
1043 <programlisting>... -translate-molecules</programlisting>
1044 <para>As before, this is actually just an operation on all of the molecule&apos;s atoms, namely translating them.</para>
1045 </section>
1046 <section xml:id="molecule.rotate-around-self">
1047 <title xml:id="molecule.rotate-around-self.title">Rotate around self </title>
1048 <para>You can rotate a molecule around its own axis.</para>
1049 <programlisting>
1050 ... --rotate-around-self &quot;90&quot; \
1051 --axis &quot;0,0,1&quot;
1052 </programlisting>
1053 <para>This rotates the molecule around the z axis by 90 degrees as
1054 if the origin were at its wn center of origin.</para>
1055 </section>
1056 <section xml:id="molecule.rotate-around-origin">
1057 <title xml:id="molecule.rotate-around-origin.title">Rotate around origin</title>
1058 <para>In the same manner the molecule can be rotated around an
1059 external origin.</para>
1060 <programlisting>
1061 ... --rotate-around-origin 90 \
1062 --position &quot;0,0,1&quot;\
1063 </programlisting>
1064 <para>This rotates the molecule around an axis from the origin to
1065 the position (0,0,1), i.e. around the z axis, by 90 degrees.</para>
1066 </section>
1067 <section xml:id="molecule.rotate-to-principal-axis-system">
1068 <title xml:id="molecule.rotate-to-principal-axis-system.title"> Rotate to principal axis system</title>
1069 <para>The principal axis system is given by an ellipsoid that mostly
1070 matches the molecules shape. The principal axis system can be
1071 simply determined by</para>
1072 <programlisting>... --principal-axis-system</programlisting>
1073 <para>To rotate the molecule around itself to align with this system
1074 do as follows</para>
1075 <programlisting>... --rotate-to-principal-axis-system &quot;0,0,1&quot;
1076 </programlisting>
1077 <para>This rotates the molecule in such a manner that the ellipsoids
1078 largest axis is aligned with the z axis. <remark>Note that &quot;0,0,-1&quot; would align anti-parallel.</remark></para>
1079 </section>
1080 <section xml:id="molecule.verlet-integration">
1081 <title xml:id="molecule.verlet-integration.title">Perform verlet integration</title>
1082 <para>Atoms not only have a position, but each instance also stores
1083 velocity and a force vector. These can be used in a velocity verlet
1084 integration step. Velocity verlet is an often employed time
1085 integration algorithm in molecular dynamics simulations.</para>
1086 <programlisting>
1087 ... --verlet-integration \
1088 --deltat 0.1 \
1089 --keep-fixed-CenterOfMass 0
1090 </programlisting>
1091 <para>This will integrate with a timestep of <inlineequation>
1092 <m:math display="inline">
1093 <m:mi>\Delta_t = 0.1</m:mi>
1094 </m:math>
1095 </inlineequation>and correcting forces and velocities such that
1096 the sum over all atoms is zero.</para>
1097 </section>
1098 <section xml:id="molecule.force-annealing">
1099 <title xml:id="molecule.force-annealing.title">Anneal the atomic forces</title>
1100 <para>This will shift the atoms in a such a way as to decrease (or
1101 anneal) the forces acting upon them.</para>
1102 <para>Forces may either be already present for the set of atoms by
1103 some other way (e.g. from a prior fragmentation calculation) or,
1104 as shown here, loaded from an external file. We anneal the forces for
1105 one step with a certain initial step width of 0.5 atomic time
1106 units and do not create a new timestep for each optimization
1107 step.</para>
1108 <programlisting>
1109 ... --force-annealing \
1110 --forces-file test.forces \
1111 --deltat 0.5 \
1112 --steps 1 \
1113 --output-every-step 0
1114 </programlisting>
1115 </section>
1116 <section xml:id="molecule.linear-interpolation-of-trajectories">
1117 <title xml:id="molecule.linear-interpolation-of-trajectories.title"> Linear interpolation between configurations</title>
1118 <para>This is similar to verlet integration, only that it performs
1119 a linear integration irrespective of the acting atomic forces.
1120 </para>
1121 <para>The following call will produce an interpolation between the
1122 configurations in time step 0 and time step 1 with 98 intermediate
1123 steps, i.e. current step 1 will end up in time step 99. In this
1124 case an identity mapping is used to associated atoms in start and
1125 end configuration.</para>
1126 <programlisting>
1127 ... --linear-interpolation-of-trajectories \
1128 --start-step 0 \
1129 --end-step 1 \
1130 --interpolation-steps 100 \
1131 --id-mapping 1
1132 </programlisting>
1133 </section>
1134 </section>
1135 <section xml:id="domain">
1136 <title xml:id="domain.title">Manipulate domain</title>
1137 <para>Here, we elaborate on how to duplicate all the atoms inside the
1138 domain, how to scale the coordinate system, how to center the atoms
1139 with respect to certain points, how to realign them by given
1140 constraints, how to mirror and most importantly how to specify the
1141 domain.</para>
1142 <section xml:id="domain.change-box">
1143 <title xml:id="domain.change-box.title">Changing the domain</title>
1144 <para>The domain is specified by a symmetric 3x3 matrix. The
1145 eigenvalues (diagonal entries in case of a diagonal matrix) give the
1146 length of the edges, additional entries specify transformations of
1147 the box such that it becomes a more general parallelepiped.</para>
1148 <programlisting>... change-box &quot;20,0,20,0,0,20&quot;</programlisting>
1149 <para>As the domain matrix is symmetric, six values suffice to fully
1150 specify it. We have to give the six components of the lower triangle matrix. Here, we change the box to a cuboid of equal edge length of
1151 20.<warning>
1152 <para>In case of the python interface an upper triangle matrix is given. Hence, the above would read &quot;20,0,0,20,0,20&quot;.</para>
1153 </warning></para>
1154 </section>
1155 <section xml:id="domain.bound-in-box">
1156 <title xml:id="domain.bound-in-box.title">Bound atoms inside box </title>
1157 <para>The following applies the current boundary conditions to the
1158 atoms. In case of periodic or wrapped boundary conditions the atoms
1159 will be periodically translated to be inside the domain
1160 again.</para>
1161 <programlisting>... --bound-in-box</programlisting>
1162 </section>
1163 <section xml:id="domain.center-in-box">
1164 <title xml:id="domain.center-in-box.title">Center atoms inside the domain</title>
1165 <para>This is a combination of changing the box and bounding the
1166 atoms inside it.</para>
1167 <programlisting>... --center-in-box &quot;20,0,20,0,0,20&quot;</programlisting>
1168 </section>
1169 <section xml:id="domain.center-edge">
1170 <title xml:id="domain.center-edge.title">Center the atoms at an edge</title>
1171 <para>MoleCuilder can calculate the minimum box (parallel to the
1172 cardinal axis) all atoms would fit in and translate all atoms in
1173 such a way that the lower, left, front edge of this minimum is at
1174 the origin (0,0,0).</para>
1175 <programlisting>... --center-edge</programlisting>
1176 </section>
1177 <section xml:id="domain.add-empty-boundary">
1178 <title xml:id="domain.add-empty-boundary.title">Extending the boundary by adding an empty boundary</title>
1179 <para>In the same manner as above a minimum box is determined that
1180 is subsequently expanded by a boundary of the given additional
1181 thickness. This applies to either side, i.e. left and right, top and bottom, front and back.</para>
1182 <programlisting>... --add-empty-boundary &quot;5,5,5&quot;</programlisting>
1183 <para>This will enlarge the box in such a way that every atom is at
1184 least by a distance of 5 away from the boundary of the domain (in
1185 the infinity norm).</para>
1186 </section>
1187 <section xml:id="domain.scale-box">
1188 <title xml:id="domain.scale-box.title">Scaling the box</title>
1189 <para>You can enlarge the domain by simple scaling factors.</para>
1190 <programlisting>... --scale-box &quot;1,1,2.5&quot;</programlisting>
1191 <para>Here, the domain is stretched in the z direction by a factor
1192 of 2.5.</para>
1193 </section>
1194 <section xml:id="domain.repeat-box">
1195 <title xml:id="domain.repeat-box.title">Repeating the box</title>
1196 <para>Under periodic boundary conditions often only the minimal
1197 periodic cell is stored. E.g. for a crystallic system this minimal cell is all that&apos;s needed to completely specify a larger body. If need be, multiple images can be easily
1198 added to the current state of the system by repeating the box, i.e.
1199 the box along with all contained atoms is copied and placed
1200 adjacently.</para>
1201 <programlisting>... --repeat-box &quot;1,2,2&quot;</programlisting>
1202 <para>This will create a 2x2 grid of the current domain, replicating
1203 it along the y and z direction along with all atoms. If the domain
1204 contained before a single water molecule, we will now have four of
1205 them.</para>
1206 </section>
1207 <section xml:id="domain.set-boundary-conditions">
1208 <title xml:id="domain.set-boundary-conditions.title">Change the boundary conditions</title>
1209 <para>Various boundary conditions can be applied that affect how
1210 certain Actions work, e.g. translate-atoms. We briefly give a list
1211 of all possible conditions:</para>
1212 <itemizedlist>
1213 <listitem>
1214 <para>Wrap</para>
1215 <para>Coordinates are wrapped to the other side of the domain,
1216 i.e. periodic boundary conditions.</para>
1217 </listitem>
1218 <listitem>
1219 <para>Bounce</para>
1220 <para>Coordinates are bounced back into the domain, i.e. they
1221 are reflected from the domain walls.</para>
1222 </listitem>
1223 <listitem>
1224 <para>Ignore</para>
1225 <para>No boundary conditions apply.</para>
1226 </listitem>
1227 </itemizedlist>
1228 <para>The following will set the boundary conditions to periodic.
1229 </para>
1230 <programlisting>... --set-boundary-conditions &quot;Wrap Wrap Wrap&quot;</programlisting>
1231 <para>Note that boundary conditions are not enforced unless explicitly requested, e.g. by the <emphasis role="bold">bound-in-box</emphasis> action</para>
1232 </section>
1233 </section>
1234 <section xml:id="filling">
1235 <title xml:id="filling.title">Filling</title>
1236 <para>Filling a specific part of the domain with one type of
1237 molecule, e.g. a water molecule, is the more advanced type of
1238 copying of a molecule (see <emphasis role="bold">copy-molecule</emphasis>) and for this we need several
1239 ingredients.</para>
1240 <para>First, we need to specify the part of the domain. This is done
1241 via a shape. We have already learned how to create and select
1242 shapes. The currently selected shape will serve as the fill-in
1243 region.</para>
1244 <para>Then, there are three types of filling: domain, volume, and
1245 surface. The domain is filled with a regular grid of fill-in points.
1246 A volume and a surface are filled by a set of equidistant points
1247 distributed within the volume or on the surface of a selected
1248 shape. The latter is closed connected to the respective shape selected. Molecules will then be copied and translated points when they
1249 &quot;fit&quot;. Note that not only primitive shape can be used for filling in molecules inside their volume or on their surface but also any kind of combined shape. </para>
1250 <remark>Note however that not all combinations may already be fully working.</remark>
1251 <para>The filler procedure checks each fill-in point whether there
1252 is enough space for the set of atoms. To this end, we require a cluster
1253 instead of a molecule. A cluster is more general than a molecule as it is not restricted to a connected subgraph with respect to the bond graph. A cluster is just a general agglomeration of atoms
1254 combined with a bounding box that contains all of them and serves as
1255 its minimal volume. I.e. we need such a cluster. For this a number of
1256 atoms have to be specified, the minimum bounding box is generated
1257 automatically by which it is checked whether sufficient space is available at the fill-in point.</para>
1258 <para>On top of that, molecules can be selected whose volume is
1259 additionally excluded from the filling region.</para>
1260 <section xml:id="filling.fill-regular-grid">
1261 <title xml:id="filling.fill-regular-grid.title">Fill the domain with molecules</title>
1262 <para>The call to fill the volume of the selected shape with the
1263 selected atoms is then as follows,</para>
1264 <programlisting>
1265 ... --fill-regular-grid \
1266 --mesh-size &quot;5,5,5&quot; \
1267 --mesh-offset &quot;.5,.5,.5&quot; \
1268 --DoRotate 1 \
1269 --min-distance 1. \
1270 --random-atom-displacement 0.05 \
1271 --random-molecule-displacement 0.4 \
1272 --tesselation-radius 2.5
1273 </programlisting>
1274 <para>This generates a cardinal grid of 5x5x5 fill-in points within the
1275 sphere that are offset such as to lie centered within the sphere, defined by a relative offset per axis in [0,1]. Hence, with an offset of &quot;0&quot; we have the points left-aligned, with &quot;0.5&quot; centered, and with &quot;1&quot; right-aligned. Additionally, each molecule is rotated
1276 by a random rotation matrix, each atom is translated randomly by at
1277 most 0.05, each molecule&apos;s center similarly but at most by 0.4. The selected
1278 molecules&apos; volume is obtained by tesselating their surface and
1279 excluding every fill-in point whose distance to this surface does
1280 not exceed 1. We refer to our comments in
1281 <link linkend="randomization">Randomization</link>for details on
1282 changing the randomness and obtaining some extra flexibility thereby.</para>
1283 </section>
1284 <section xml:id="filling.fill-volume">
1285 <title xml:id="filling.fill-volume.title">Fill a shape&apos;s volume with molecules</title>
1286 <para>More specifically than filling the whole domain with molecules,
1287 maybe except areas where other molecules already are, we also can
1288 fill only specific parts by selecting a shape and calling upon
1289 the following action:</para>
1290 <programlisting>
1291 ... --fill-volume \
1292 --counts 12 \
1293 --min-distance 1. \
1294 --DoRotate 1 \
1295 --random-atom-displacement 0.05 \
1296 --random-molecule-displacement 0.4 \
1297 --tesselation-radius 2.5
1298 </programlisting>
1299 <para>The specified option all have the same function as before. Here, we specified to generate 12 points inside the volume of the selected shape.</para>
1300 </section>
1301 <section xml:id="filling.fill-surface">
1302 <title xml:id="filling.fill-surface.title">Fill a shape&apos;s surface with molecules</title>
1303 <para>Filling a surface is very similar to filling its volume.
1304 Again the number of equidistant points has to be specified.
1305 However, randomness is constrained as the molecule has to be aligned
1306 with the surface in a specific manner. The idea is to have the molecules point away from the surface in a similar way. This is done by aligning an axis with the surface normal. The alignment axis refers
1307 to the largest principal axis of the filler molecule and will
1308 be aligned parallel to the surface normal at the fill-in point.
1309This is the same syntax as with <emphasis role="bold">rotate-around-self</emphasis>. </para>
1310 <para>The call below will fill in 12 points with a minimum distance
1311 between the instances of 1 angstroem. We allow for certain random
1312 displacements and use the z-axis for aligning the molecules on
1313 the surface.</para>
1314 <programlisting>
1315 ... --fill-surface \
1316 --counts 12 \
1317 --min-distance 1. \
1318 --DoRotate 1 \
1319 --random-atom-displacement 0.05 \
1320 --random-molecule-displacement 0.4 \
1321 --Alignment-Axis &quot;0,0,1&quot;
1322 </programlisting>
1323 </section>
1324 <section xml:id="filling.suspend-in-molecule">
1325 <title xml:id="filling.suspend-in-molecule.title">Suspend in molecule </title>
1326 <para>Add a given molecule in the simulation domain in such a way
1327 that the total density is as desired.</para>
1328 <programlisting>
1329 ... --suspend-in-molecule 1.
1330 </programlisting>
1331 </section>
1332 <section xml:id="filling.fill-molecule">
1333 <title xml:id="filling.fill-molecule.title">Fill in molecule</title>
1334 <para>This action will be soon be removed.</para>
1335 <programlisting>
1336 ... --fill-molecule
1337 </programlisting>
1338 </section>
1339 <section xml:id="filling.fill-void">
1340 <title xml:id="filling.fill-void.title">Fill void with molecule </title>
1341 <para>This action will be soon be removed.</para>
1342 <programlisting>
1343 ... --fill-void
1344 </programlisting>
1345 </section>
1346 </section>
1347 <section xml:id="analysis">
1348 <title xml:id="analysis.title">Analysis</title>
1349 <para>If atoms are manipulated and molecules are filled in, it is also a good idea to check on the manner of the filling. This can be done by for example looking at the pair correlation or angular correlation function. This may be useful in checking what is the mean distance between water molecules and how they are aligned with respect to each other.</para>
1350 <section xml:id="analysis.pair-correlation">
1351 <title xml:id="analysis.pair-correlation.title">Pair Correlation </title>
1352 <para>For two given elements Pair correlation checks on the typical
1353 distance in which they can be found with respect to one another. E.g. for
1354 water one might be interested what is the typical distance for
1355 hydrogen and oxygen atoms.</para>
1356 <programlisting>
1357 ... --pair-correlation \
1358 --elements 1 8 \
1359 --bin-start 0 \
1360 --bin-width 0.7 \
1361 --bin-end 10 \
1362 --output-file histogram.dat \
1363 --bin-output-file bins.dat \
1364 --periodic 0
1365 </programlisting>
1366 <para>This will compile a histogram for the interval [0,10] in steps
1367 of 0.7 and increment a specific bin if the distance of one such pair
1368 of a hydrogen and an oxygen atom can be found within its distance
1369 interval. These data files can be used for plotting the distribution right away in order to check on the correlation between the elements.</para>
1370 </section>
1371 <section xml:id="analysis.dipole-correlation">
1372 <title xml:id="analysis.dipole-correlation.title">Dipole Correlation </title>
1373 <para>The dipole correlation is similar to the pair correlation, only
1374 that it correlates the orientation of dipoles in the molecular
1375 system with one another.</para>
1376 <para>Note that the dipole correlation works on the currently
1377 selected molecules, e.g. all water molecules if so selected.</para>
1378 <programlisting>
1379 ... --dipole-correlation \
1380 --bin-start 0 \
1381 --bin-width 0.7 \
1382 --bin-end 10 \
1383 --output-file histogram.dat \
1384 --bin-output-file bins.dat \
1385 --periodic 0
1386 </programlisting>
1387 <para>Hence, instead of calculating a function of the distance in [0,infinity), it calculates the angular histogram in [0,2pi).</para>
1388 </section>
1389 <section xml:id="analysis.dipole-angular-correlation">
1390 <title xml:id="analysis.dipole-angular-correlation.title">Dipole Angular Correlation</title>
1391 <para>The dipole angular correlation looks at the angles of a
1392 dipole over time. It takes the orientation of a certain time step
1393 as the zero angle and bins all other orientations found in later
1394 time steps relative to it.
1395 </para>
1396 <para>Note that in contrast to the dipole correlation the dipole
1397 angular correlation works on the molecules determined by a formula.
1398 This is because selections do not work over time steps as molecules
1399 might change.
1400 </para>
1401 <programlisting>
1402 ... --dipole-angular-correlation H2O \
1403 --bin-start 0 \
1404 --bin-width 5 \
1405 --bin-end 360 \
1406 --output-file histogram.dat \
1407 --bin-output-file bins.dat \
1408 --periodic 0 \
1409 --time-step-zero 0
1410 </programlisting>
1411 </section>
1412 <section xml:id="analysis.point-correlation">
1413 <title xml:id="analysis.point-correlation.title">Point Correlation </title>
1414 <para>Point correlation is very similar to pair correlation, only
1415 that it correlates not positions of atoms among one another but
1416 against a fixed, given point.</para>
1417 <programlisting>
1418 ... --point-correlation \
1419 --elements 1 8 \
1420 --position &quot;0,0,0&quot; \
1421 --bin-start 0 \
1422 --bin-width 0.7 \
1423 --bin-end 10 \
1424 --output-file histogram.dat \
1425 --bin-output-file bins.dat \
1426 --periodic 0
1427 </programlisting>
1428 <para>This would calculate the correlation of all hydrogen and
1429 oxygen atoms with respect to the origin.</para>
1430 </section>
1431 <section xml:id="analysis.surface-correlation">
1432 <title xml:id="analysis.surface-correlation.title">Surface Correlation</title>
1433 <para>The surface correlation calculates the distance of a set
1434 of atoms with respect to a tesselated surface.</para>
1435 <programlisting>
1436 ... --surface-correlation \
1437 --elements 1 8 \
1438 --bin-start 0 \
1439 --bin-width 0.7 \
1440 --bin-end 10 \
1441 --output-file histogram.dat \
1442 --bin-output-file bins.dat \
1443 --periodic 0
1444 </programlisting>
1445 </section>
1446 <section xml:id="analysis.molecular-volume">
1447 <title xml:id="analysis.molecular-volume.title">Molecular Volume </title>
1448 <para>This simply calculates the volume that a selected molecule
1449 occupies. For this the molecular surface is determined via a
1450(convex) tesselation of its surface. Note that this surface is minimal is that aspect
1451 that each node of the tesselation consists of an atom of the
1452 molecule.</para>
1453 <programlisting>... --molecular-volume</programlisting>
1454 </section>
1455 <section xml:id="analysis.average-molecule-force">
1456 <title xml:id="analysis.average-molecule-forcetitle">Average force acting on a molecule</title>
1457 <para>This sums up all the forces of each atom of a currently
1458 selected molecule and returns the average force vector. This should
1459 give you the general direction of acceleration of the molecule.
1460 </para>
1461 <programlisting>... --molecular-volume</programlisting>
1462 </section>
1463 </section>
1464 <section xml:id="fragmentation">
1465 <title xml:id="fragmentation.title">Fragmentation</title>
1466 <para>Fragmentation refers to a so-called linear-scaling method called
1467 &quot;Bond-Order diSSection in an ANOVA-like fashion&quot; (BOSSANOVA),
1468 developed by <personname>Frederik Heber</personname>. In this section
1469 we briefly explain what the method does and how the associated actions
1470 work.</para>
1471 <para>The central idea behind the BOSSANOVA scheme is to fragment the
1472 graph of the molecular system into connected subgraphs of a certain
1473 number of vertices, namely a fixed number of atoms. To give an example, loading a ethane atom
1474 with the chemical formula C2H6, fragmenting the molecule up to order 1
1475 means creating two fragments, both methane-like from either carbon
1476 atom including surrounding hydrogen atoms. Fragmenting up to order 2
1477 would return both the methane fragments and additionally the full
1478 ethane molecule as it resembles a fragment of order 2, namely
1479 containing two (non-hydrogen) atoms.</para>
1480 <para>The reason for doing this is that usual ab-initio calculations
1481 of molecular systems via methods such as Density Functional Theory or
1482 Hartree-Fock scale at least as <inlineequation>
1483 <m:math display="inline">
1484 <m:mi>{\cal O}(M^3}</m:mi>
1485 </m:math>
1486 </inlineequation>with the number of atoms <inlineequation>
1487 <m:math display="inline">
1488 <m:mi>M</m:mi>
1489 </m:math>
1490 </inlineequation>. In general, this cost is prohibitive for calculating ground state energies and forces (required for molecular dynamics simulations) for larger molecules such as bio proteins. By fragmenting the molecular system and looking at fragments of fixed size, calculating the ground state energy of a
1491 number of fragment molecules becomes a linear scaling operation with the number of atoms. In the doctoral thesis of Frederik
1492 Heber, it is explained why this is a sensible ansatz mathematically
1493 and shown that it delivers a very good accuracy if electrons (and
1494 hence interactions) are in general localized.</para>
1495 <para>Long-range interactions (e.g. Coulomb or van-der-Waals interactions) are artificially truncated, however,
1496 with this fragmentation ansatz. It can be obtained in a perturbation manner
1497 by sampling the resulting electronic and nuclei charge density on a
1498 grid, summing over all fragments, and solving the associated Poisson
1499 equation. Such a calculation is implemented via the solver
1500 <productname>vmg</productname> by Julian Iseringhausen that is
1501 contained in the <link xlink:href="http://www.scafacos.org/">
1502 <productname>ScaFaCoS</productname>
1503 </link>. This enhancement is currently implemented via another program package named <productname>JobMarket</productname> that is at the moment not available publicly (contact the author Frederik Heber if interested).</para>
1504 <para>Note that we treat hydrogen special (but can be switched off) as
1505 fragments are calculated as closed shell (total spin equals zero).
1506 Also, we use hydrogen to saturate any dangling bonds that occur as
1507 bonds are cut when fragmenting a molecule (this, too, can be switched
1508 off).</para>
1509 <para>Eventually, the goal of fragmentation is to yield an energy and gradients with respect to nuclear positions per atom for each fragment. These forces can be used for molecular dynamics simulations, for structure optimization or for fitting empirical potential functions. The underlying operation consists of three parts. The first part is always the act of splitting up the selected atoms in the molecular system into fragments. The energies of the fragments are calculated in the second part via an external ab-initio solver, where the actual solver used is arbitrary and to some extent up to the user (<productname>MPQC </productname> is used by default). The second part of the fragmentation is to combine fragment results to energy and gradients for the total molecular system.</para>
1510 <para>Note that the molecular system itself is not touched in any way by this fragmentation. </para>
1511 <section xml:id="fragmentation.fragment-molecule">
1512 <title xml:id="fragmentation.fragment-molecule.title">Fragmenting a molecular system</title>
1513 <para>For the current selection of atoms, all fragments consisting
1514 of these (sub)set of atoms are created in the following
1515 manner.</para>
1516 <programlisting>
1517 ... --fragment-molecule &quot;BondFragment&quot; \
1518 --DoCyclesFull 1 \
1519 --distance 3. \
1520 --order 3 \
1521 --grid-level 5 \
1522 --output-types xyz mpqc
1523 </programlisting>
1524 <para>We go through each of the options one after the other. During
1525 fragmentation some files are created storing state information, i.e.
1526 the vertex/atom indices per fragment and so on. These files are used when re-performing the fragmentation on a slightly modified state (e.g. after a time integration step with essentially the same bond graph) for faster operation. These files all need
1527 a common prefix, here &quot;BondFragment&quot;. Then, we specify that cycles
1528 should be treated fully. This compensates for electrons in aromatic
1529 rings being delocalized over the ring. If cycles in the graph,
1530 originating from aromatic rings, are always calculated fully, i.e.
1531 the whole ring becomes a fragment, we partially overcome these
1532 issues. This does however not work indefinitely and accuracy of the
1533 approximation is limited (<inlineequation>
1534 <m:math display="inline">
1535 <m:mi>&gt;10^{-4}</m:mi>
1536 </m:math>
1537 </inlineequation>) in systems with many interconnected aromatic
1538 rings, such as graphene. Next, we give a distance cutoff of 3 angstroem used
1539 in bond graph creation. Then, we specify the maximum order, i.e. the
1540 maximum number of (non-hydrogen) atoms per fragment, here 3. The
1541 higher this number the more expensive the calculation becomes
1542 (because substantially more fragments are created) but also the more
1543 accurate. The grid level refers to the part where long-range Coulomb
1544 interactions are calculated. This is done via solving the associated
1545 Poisson equation with a multigrid solver -- however, this requires the <productname>JobMarket</productname> package. As input the solver
1546 requires the density which is sampled on a cartesian grid whose
1547 resolution these parameter defines (<inlineequation>
1548 <m:math display="inline">
1549 <m:mi>2^{\mathrm{level}}</m:mi>
1550 </m:math>
1551 </inlineequation>). And finally, we give the output file formats,
1552 i.e. which file formats are used for writing each fragment
1553 configuration (prefix is &quot;BondFragment&quot;, remember?). Here, we use
1554 XYZ (mainly for checking the configurations visually) and MPQC,
1555 which is a very robust Hartree-Fock solver. We refer to the
1556 discussion of the <link linkend="fileparsers">Parsers</link>
1557 on how to change the parameters of the ab-initio calculation. That is to the extent implemented in Molecuilder the created configuration files for the specific solver are manipulated with the options also manipulating the state file written on program exit.</para>
1558 <para>After having written all fragment configuration files, you
1559 need to calculate each fragment, grab the resulting energy (and
1560 force vectors) and place them into a result file manually. This at
1561 least is necessary if you have specified output-types above. If not,
1562 the fragments are not written to file but stored internally. Read
1563 on.</para>
1564 </section>
1565 <section xml:id="fragmentation.fragment-automation">
1566 <title xml:id="fragmentation.fragment-automation.title">Calculating fragment energies automatically</title>
1567 <para>Another way of doing this is enabled if you have
1568the <productname>JobMarket</productname> package. Initially, the package was required but now it is only recommended as then calculations can be performed in parallel or arbitrarily many cores (and also the long-range calculation are only available then). JobMarket implements a
1569 client/server ansatz, i.e. two (or more) independent programs are
1570 running (even on another computer but connected via an IP network),
1571 namely a server and at least one client. The server receives
1572 fragment configurations from MoleCuilder and assigns these to a
1573 client who is not busy. The client launches an executable that is
1574 specified in the work package he is assigned and gathers after
1575 calculation a number of values, likewise specified in the package.
1576 The results are gathered together by the server and can be requested
1577 from MoleCuilder once they are done. This essentially describes what
1578 is happening during the execution of this action.</para>
1579 <para>Stored fragment jobs can also be parsed again, i.e. reversing
1580 the effect of having output-types specified in <link linkend="fragmentation.fragment-molecule">Fragmenting a molecule </link>.</para>
1581 <programlisting>
1582 ... --parse-fragment-jobs \
1583 --fragment-jobs &quot;BondFragment00.in&quot; &quot;BondFragment01.in&quot; \
1584 --fragment-path &quot;./&quot; \
1585 --grid-level 5
1586 </programlisting>
1587 <para>Here, we have specified two files, namely
1588 <filename>BondFragment00.in</filename> and
1589 <filename>BondFragment01.in</filename>, to be parsed from the path
1590 &quot;./&quot;, i.e. the current directory. Also, we have specified to sample
1591 the electronic charge density obtained from the calculated ground
1592 state energy solution with a resolution of 5 (see fragment molecule
1593 and also below).</para>
1594 <para>This allows for automated and parallel calculation of all
1595 fragment energies and forces directly within MoleCuilder. The
1596 FragmentationAutomation action takes the fragment configurations
1597 from an internal storage wherein they are placed if in
1598 FragmentMolecule no output-types have been specified.</para>
1599 <programlisting>
1600 ... --fragment-automation \
1601 --fragment-executable mpqc \
1602 --fragment-resultfile BondFragment_results.dat \
1603 --DoLongrange 1 \
1604 --DoValenceOnly 1 \
1605 --grid-level 5 \
1606 --interpolation-degree 3 \
1607 --near-field-cells 4 \
1608 --server-address 127.0.0.1 \
1609 --server-port 1025
1610 </programlisting>
1611 <para>Again, we go through each of the action&apos;s options step by
1612 step.</para>
1613 <para>The executable is required if you do not have a patched
1614 version of <productname>MPQC</productname> that may directly act as
1615 a client to JobMarket&apos;s server. All calculated results are placed in
1616 the result file. If none is given, they are instead again placed in
1617 an internal storage for later access.</para>
1618 <note>
1619 <para>Long-calculations are only possible with a client that knows
1620 how to handle VMG jobs. If you encounter failures, then it is most
1621 likely that you do not have a suitable client.</para>
1622 </note>
1623 <para>In the next line, we have all options related to calculation
1624 of long-range interactions. We only sample valence charges on the
1625 grid, i.e. not core electrons and the nuclei charges are reduced
1626suitably. This avoids problems with sampling highly localized
1627 charges on the grid and is in general recommended. Next, there
1628 follow parameters for the multi grid solver, namely the resolution
1629 of the grid, see under fragmenting the molecule, the interpolation
1630 degree and the number of near field cells. A grid level of 6 is
1631 recommended but costly in terms of memory, the other values are at
1632 their recommend values.</para>
1633 <para>In the last line, parameters are given on how to access the
1634 JobMarket server, namely it address and its port. If the JobMarket package is not available, then these option values cannot be given. Instead the solver is called internally on the same machine and one fragment energy is calculated after the other.</para>
1635 </section>
1636 <section xml:id="fragmentation.analyse-fragment-results">
1637 <title xml:id="fragmentation.analyse-fragment-results.title"> Analyse fragment results</title>
1638 <para>After the energies and force vectors of each fragment have
1639 been calculated, they need to be summed up to an approximation for
1640 the energy and force vectors of the whole molecular system. This is
1641 done by calling this action.</para>
1642 <programlisting>
1643 ... --analyse-fragment-results \
1644 --fragment-prefix &quot;BondFragment&quot; \
1645 --fragment-resultfile BondFragment_results.dat \
1646 --store-grids 1
1647 </programlisting>
1648 <para>The purpose of the prefix should already be known to you, same
1649 with the result file that is the file parsed by MoleCuilder. The
1650 last option states that the sampled charge densities and the
1651 calculated potential from the long-range calculations should be
1652 stored with the summed up energies and forces. Note that this makes
1653 the resulting files substantially larger (Hundreds of megabyte or
1654 even gigabytes as currently the densities are stored on the full cartesian grid). Fragment energies and forces are stored in
1655 so-called internal homology containers. These are explained in the
1656 next section.</para>
1657 <para>Note that this action sets the force vector if these have been
1658 calculated for the fragment. Hence, a
1659 <link linkend="molecule.verlet-integration">verlet integration</link>
1660 is possible afterwards.</para>
1661 </section>
1662 <section xml:id="fragmentation.store-saturated-fragment">
1663 <title xml:id="fragmentation.store-saturated-fragment.title">Store a saturated fragment</title>
1664 <para>This will store the currently selected atoms as a fragment
1665 where all dangling bonds (by atoms that are connected in the bond
1666 graph but have not been selected as well) are saturated with
1667 additional hydrogen atoms. The output formats are set to just xyz.
1668 </para>
1669 <programlisting>
1670 ... --store-saturated-fragment \
1671 --DoSaturate 1 \
1672 --output-types xyz
1673 </programlisting>
1674 </section>
1675 </section>
1676 <section xml:id="homology">
1677 <title xml:id="homology.title">Homologies</title>
1678 <para>After a fragmentation procedure has been performed fully, what
1679 to do with the results? The forces can be used for time integration and structure optimization but what about
1680 the energies? The energy value is basically the function evaluation of
1681 the Born-Oppenheimer surface of the molecular system. For molecular dynamics simulations
1682 continuous ab-initio calculations to evaluate the Born-Oppenheimer
1683 surface, especially the gradient at the current position of the molecular system&apos;s configuration, is not feasible. Instead usually empirical potential functions
1684 are fitted as to resemble the Born-Oppenheimer surface to a sufficient
1685 degree.</para>
1686 <para>One frequently employed method is the many-body expansion of said surface
1687 which is basically nothing else than the fragmentation ansatz described
1688 above. Potential functions resemble a specific term in this many-body
1689 expansion. These are discussed in the next section.</para>
1690 <para>For each of these terms all homologous fragments (i.e. having
1691 the same atoms with respect to the present elements and bonded in the
1692 same way), differing only in the coordinate of each atom, are just a
1693 sampling or a function evaluation of this term of the many-body
1694 expansion with respect to varying nuclei coordinates. Hence, it is
1695 appropriate to use these function evaluations in a non-linear
1696 regression procedure. That is, we want to tune the parameters of the
1697 empirical potential function in such a way as to most closely obtain
1698 the same function evaluation as the ab-initio calculation did using the
1699 same nuclear coordinates. Usually, this is done in a least-square
1700 sense, minimising the euclidean norm.</para>
1701 <para>Homologies -- in the sense used here -- are then nothing else but containers for a specific
1702 type of fragment of all the different, calculated configurations (i.e.
1703 varying nuclear coordinates of the same fragment, i.e. same atoms with identical bonding).</para>
1704 <para>Now, we explain the actions that parse and store
1705 homologies.</para>
1706 <programlisting>... --parse-homologies homologies.dat</programlisting>
1707 <para>This parses the all homologies contained in the file
1708 <filename>homologies.dat</filename> and <emphasis role="italic">appends</emphasis> them to the homology
1709 container.</para>
1710 <programlisting>... --save-homologies homologies.dat</programlisting>
1711 <para>Complementary, this stores the current contents of the homology
1712 container, <emphasis role="italic">overwriting</emphasis> the file
1713 <filename>homologies.dat</filename>.</para>
1714 </section>
1715 <section xml:id="potentials">
1716 <title xml:id="potentials.title">Potentials</title>
1717 <para>In much the same manner as we asked before: what are homology
1718 files or containers good for? However, taking into account what we have just explained, it
1719 should be clear: We fit potential function to these function
1720 evaluations of terms of the many-body expansion of the Born-Oppenheimer
1721 surface of the full system.</para>
1722 <section xml:id="potentials.fit-potential">
1723 <title xml:id="potentials.fit-potential.title">Fitting empirical potentials</title>
1724 <para>Let&apos;s take a look at an exemplary call to the fit potential
1725 action.</para>
1726 <programlisting>
1727 ... --fit-potential \
1728 --fragment-charges 8 1 1 \
1729 --potential-charges 8 1 \
1730 --potential-type morse \
1731 --take-best-of 5
1732 </programlisting>
1733 <para>Again, we look at each option in turn. The first is the
1734 charges or elements specifying the set of homologous fragments that
1735 we want to look at. Here, obviously we are interested in water
1736 molecules, consisting of a single oxygen (8) and two hydrogen atoms (1).
1737 Next, we specify the chemical element type of the potential, here a potential between oxygen (8) and hydrogen (1). We give
1738 the type of the potential as morse, which requires a single distance
1739 or two nuclear coordinates and the distance taken between the two. Finally, we state that the non-linear regression should be
1740 done with five random starting positions, i.e. five individual minimizations, and the set of parameters
1741 with the smallest L2 norm wins.</para>
1742 <note>
1743 <para>Due to translational and rotational degrees of freedom for
1744 fragments smaller than 7 atoms, it is appropriate to look at the
1745 pair-wise distances and not at the absolute coordinates. Hence,
1746 the two atomic positions, here for oxygen and hydrogen, are
1747 converted to a single distance. If we had given an harmonic
1748 angular potential and the then required three charges/elements, &quot;8 1 1&quot;, i.e. oxygen
1749 and two hydrogens, we would have obtained three distances.</para>
1750 <para>MoleCuilder always adds a so-called constant potential to
1751 the fit containing only a single parameter, the energy offset.
1752 This offset compensates for the interaction energy associated with
1753 a fragment of order 1, e.g. a single hydrogen atom. Essentially, this captures the atomic energy that is not associated to any bonding interactions.</para>
1754 <para>Note that by choosing "set-max-iterations" and "take-best-of"
1755 one can force the optimization to try either a single set of random
1756 initial parameters very thoroughly or many different sets just for
1757 a few iterations. Or any in between.</para>
1758 </note>
1759 </section>
1760 <section xml:id="potentials.fit-compound-potential">
1761 <title xml:id="potentials.fit-compound-potential.title">Fitting many empirical potentials simultaneously</title>
1762 <para>Another way is using a file containing a specific set of
1763 potential functions, possibly even with initial values.</para>
1764 <programlisting>
1765 ... --fit-compound-potential \
1766 --fragment-charges 8 1 1 \
1767 --potential-file water.potentials \
1768 --set-threshold 1e-3 \
1769 --training-file test.dat
1770 </programlisting>
1771 <para>Now, all empirical potential functions are summed up into a
1772 so-called compound potential over the combined set of parameters.
1773 These are now fitted simultaneously. For example, let&apos;s say the potential
1774 file <filename>water.potentials</filename> contains a harmonic bond
1775 potential between oxygen and hydrogen and another angular potential
1776 for the angle between hydrogen, oxygen, and hydrogen atom. Then, we would
1777 fit a function consisting of the sum of the two potentials functions in order to approximate the energy of a single
1778 water molecule (actually, it&apos;s the sum of three potentials. As mentioned before, a constant potential is always added to compensate non-bonding energies, i.e. not depending on interatomic distances). Here, the threshold criterion takes the place of the
1779<emphasis role="bold"> take-best-of</emphasis> option. Here, the minimization is reiterated so often on random (but to some extent chosen from a sensible range) starting parameters until the final L2 error is below 1e-3. Also, all data used
1780 for training, i.e. the tuples consisting of the fragments nuclei
1781 coordinates and the associated energy value are written to the file
1782 <filename>test.dat</filename>. This allows for graphical representation or other
1783way of analysis, e.g. for a Morse potential between oxygen and hydrogen the bonding energy can be plotted as a one-dimensional function and compared to the &quot;point cloud&quot; of sample points from the fragment term of Born-Oppenheimer surface. It is this point cloud, i.e. the training data, that is written to the file
1784 <filename>test.dat</filename>.</para>
1785 <para>Note that you can combine the two ways, i.e. start with a
1786 fit-potential call but give an empty potential file. The resulting
1787 parameters are stored in it. Fit other potentials and give different
1788 file names for each in turn. Eventually, you have to combine the file
1789 in a text editor at the moment. And perform a fit-compound-potential
1790 with this file.</para>
1791 <para>Here, also "set-max-iterations" and "take-best-of" can be used
1792 to mix thorough or shallow search from random initial parameter sets.
1793 </para>
1794 </section>
1795 <section xml:id="potentials.parse-potential">
1796 <title xml:id="potentials.parse-potential.title">Parsing an empirical potentials file</title>
1797 <para>Taking part in the compound potential is every potential
1798 function whose signature matches with the designated fragment-charges
1799 and who is currently known to MoleCuilder.</para>
1800 <para>More potentials can be registered (<emphasis role="bold">fit-potential</emphasis> will also
1801 register the potential it fits) by parsing them from a file.</para>
1802 <programlisting>
1803 ... --parse-potentials water.potentials
1804 </programlisting>
1805 <note>Currently, only <productname>TREMOLO</productname>potential files are understood and can be parsed.</note>
1806 </section>
1807 <section xml:id="potentials.save-potential">
1808 <title xml:id="potentials.save-potential.title">Saving an empirical potentials file</title>
1809 <para>The opposite to <emphasis role="bold">parse-potentials</emphasis> is to save all currently registered potential functions to the given
1810 file along with the currently fitted parameters</para>
1811 <programlisting>
1812 ... --save-potentials water.potentials
1813 </programlisting>
1814 <note>Again, only the <productname>TREMOLO</productname>potential format is understood currently and is written.</note>
1815 </section>
1816 <section xml:id="potentials.fit-partial-charges">
1817 <title xml:id="potentials.fit-partial-charges.title">Fitting partial particle charges</title>
1818 <para>The above empirical potential just model the short-range
1819 behavior in the molecular fragment, namely the (covalently) bonded interaction.
1820 In order to model the Coulomb long-range interaction as well without solving
1821 for the electronic ground state in each time step, particle charges
1822 are used that capture to some degree the created dipoles due to
1823 charge transfer from one atom to another when bonded.</para>
1824 <para>Note that so far the placement of partial charges is restricted to the position of nuclei in the molecular system. There are more complex ways of placing partial charges, e.g. as employed in higher TIP water molecules, that also use anti-bonding potentials. This is so far not implemented.</para>
1825 <para>To allow least-squares regression of these partial charges, we
1826 need the results of long-range calculations and the <emphasis role="bold">store-grids</emphasis>
1827 option (see above under <link linkend="fragmentation">Fragmentation </link>) must have been given. With these sampled charge density and
1828 Coulomb potential stored in the homology containers, we call this
1829 action as follows.</para>
1830 <programlisting>
1831 ... --fit-partial-charges \
1832 --fragment-charges 8 1 1 \
1833 --potential-file water.potentials \
1834 --radius 0.2
1835 </programlisting>
1836 <para>This will again use a water molecule as homologous fragment
1837 &quot;key&quot; to request all configurations of this type from the homologies container. Results are
1838 stored in <filename>water.potentials</filename>. The radius is used
1839 to mark the region directly around the nuclei from the fit
1840 procedure. As here the charges of the core electrons and the nuclei
1841 itself dominate, we however are only interested in a good
1842 approximation to the long-range potential, this mask radius allows
1843 to give the range of the excluded zone.</para>
1844 </section>
1845 <section xml:id="potentials.parse-particle-parameters">
1846 <title xml:id="potentials.parse-particle-parameters.title">Parsing a particles file</title>
1847 <para>Empirical Potential contain parameters for function that model
1848 interactions between two or more specific particles. However,
1849 interactions can also be more general, such as a Coulomb
1850 potential, that interacts with any other particle with non-zero
1851 charge, or Lennard-Jones potential that interacts with any other
1852 particle close enough.
1853 Parameters for these particles are encoded in the internal Particle
1854 class and are parsed from and stored to a special particles file.
1855 This parse particle parameters function loads the parameters from
1856 a file, instantiates them in a new particle, and registers them
1857 such that they are known within molecuilder.</para>
1858 <para>More particles can be registered (<emphasis role="bold">fit-partial-charges</emphasis> will also
1859 register the particles it fits) by parsing them from a file.</para>
1860 <programlisting>
1861 ... --parse-particle-parameters water.particles
1862 </programlisting>
1863 <note>Currently, only <productname>TREMOLO</productname>particles files are understood and can be parsed.</note>
1864 </section>
1865 <section xml:id="potentials.save-particle-parameters">
1866 <title xml:id="potentials.save-particle-parameters.title">Saving a particles file</title>
1867 <para>The opposite to <emphasis role="bold">parse-particle-parameters</emphasis>
1868 is to save all currently registered particle and their parameters to
1869 the given file.</para>
1870 <programlisting>
1871 ... --save-particle-parameters water.particles
1872 </programlisting>
1873 <note>Again, only the <productname>TREMOLO</productname>particles format is understood currently and is written.</note>
1874 </section>
1875 </section>
1876 <section xml:id="dynamics">
1877 <title xml:id="dynamics.title">Dynamics</title>
1878 <para>For fitting potentials or charges we need many homologous but
1879 different fragments, i.e. atoms with slightly different positions.
1880 How can we generate these?</para>
1881 <para>One possibility is to use molecular dynamics. With the
1882 aforementioned fragmentation scheme we can quickly calculate not only
1883 energies but also forces if the chosen solver, such as
1884 <link xlink:href="http://www.mpqc.org/">
1885 <productname>MPQC </productname>
1886 </link>, supports it. Integrating these forces
1887 discretely over time gives insight into vibrational features of a
1888 molecular system close to the equilibrium and allows to generate those positions for fitting
1889 potentials that describe these vibrations.</para>
1890 <section xml:id="dynamics.molecular-dynamics">
1891 <title xml:id="dynamics.molecular-dynamics.title">Molecular dynamics </title>
1892 <para>The molecular dynamics action is a so-called macro Action,
1893 i.e. it combines several other Actions into one, namely:</para>
1894 <itemizedlist>
1895 <listitem>
1896 <para>--<emphasis role="bold">verlet-integration</emphasis></para>
1897 </listitem>
1898 <listitem>
1899 <para>--<emphasis role="bold">output</emphasis></para>
1900 </listitem>
1901 <listitem>
1902 <para>--<emphasis role="bold">clear-fragment-results</emphasis></para>
1903 </listitem>
1904 <listitem>
1905 <para>--<emphasis role="bold">destroy-adjacency</emphasis></para>
1906 </listitem>
1907 <listitem>
1908 <para>--<emphasis role="bold">create-adjacency</emphasis></para>
1909 </listitem>
1910 <listitem>
1911 <para>--<emphasis role="bold">update-molecules</emphasis></para>
1912 </listitem>
1913 <listitem>
1914 <para>--<emphasis role="bold">fragment-molecule</emphasis></para>
1915 </listitem>
1916 <listitem>
1917 <para>--<emphasis role="bold">fragment-automation</emphasis></para>
1918 </listitem>
1919 <listitem>
1920 <para>--<emphasis role="bold">analyse-fragment-results</emphasis></para>
1921 </listitem>
1922 </itemizedlist>
1923 <para>The following command will perform a molecular dynamics simulation
1924 for 100 time steps, each time step continuing over <emphasis role="bold">deltat</emphasis> equal to 0.5 atomic time units,
1925 i.e. 1.2e-17 s. Some of the other options listed below, such as <emphasis role="bold">order</emphasis>, <emphasis role="bold">distance</emphasis>, or <emphasis role="bold">fragment-executable</emphasis>, will seem familiar
1926 to you if you have read in this guide about the fragmentation actions. Look at the list above to see that they are a part of the makro action that performs molecular dynamics simulations. Below
1927 we will not keep the bond graph, i.e bonds and molecules may change
1928 over the simulation and hence also the created fragments per time
1929 step.
1930Furthermore, the forces are corrected such that the force add up to zero. </para>
1931 <programlisting>
1932 ... --molecular-dynamics \
1933 --steps 100 \
1934 --keep-bondgraph 0 \
1935 --order 3 \
1936 --distance 3. \
1937 --deltat 0.5 \
1938 --keep-fixed-CenterOfMass 1 \
1939 --fragment-executable mpqc \
1940 </programlisting>
1941 <para>Keeping the bond graph is useful when simulating close to the equilibrium and no bond breaking or forming should occur. Note that in general the BOSSANOVA fragmentation scheme is discontinuous with respect to the formation of bonds in the energy. This discontinuity arrises because of the threshold criterion used for detecting the bond graph. After each simulation step the bond graph is recreated (if <emphasis role="bold">keep-bondgraph</emphasis> is switched off) to accomodate for any structural changes. If bonds are added because two atoms are suddenly within the required distance which before was not the case, additional fragments are generated, calculated, and added to the approximation of the whole system. As the addition of these contributions is sudden -- in general, they will already be non-zero when the bonds are detected -- a slight jump in the total energy of the system can be expected.</para>
1942 <para>To sum it up, the use of the BOSSANOVA scheme in bond breaking/forming scenarios is in general not recommended. That&apos;s why keeping the bond graph is always sensible. However, if potential energies are too far away from equilibrium the simulation may still produce unphysical results.</para>
1943 </section>
1944 <section xml:id="dynamics.optimize-structure">
1945 <title xml:id="dynamics.optimize-structure.title">Structure optimization</title>
1946 <para>Structure optimization is also a macro Action, it basically
1947 combines the same Actions as <emphasis role="bold">molecular-dynamics</emphasis> does. However, it
1948 uses the <emphasis role="bold">force-annealing</emphasis> action instead of <emphasis role="bold">verlet-integration</emphasis>.</para>
1949 <para>The command below performs a structure optimization of the
1950 currently selected atoms (may also be a subset) for up to 100 time
1951 steps, where each time step is again 0.5 atomic time units. The time
1952 step here serves as the initial step width for annealing.
1953 </para>
1954 <programlisting>
1955 ... --optimize-structure \
1956 --keep-bondgraph 1 \
1957 --output-every-step 1 \
1958 --steps 100 \
1959 --order 3 \
1960 --distance 3. \
1961 --deltat 0.5 \
1962 --keep-fixed-CenterOfMass 1 \
1963 --fragment-executable mpqc \
1964 </programlisting>
1965 <para>Note that <emphasis role="bold">output-every-step</emphasis> will allow you to watch the
1966 optimization as each step is placed into a distinct time step.
1967 Otherwise only two time steps would be created: the initial and
1968 the final one containing the optimized structure.</para>
1969 </section>
1970 <section xml:id="dynamics.set-world-time">
1971 <title xml:id="dynamics.set-world-time.title">Set the world&apos;s time step</title>
1972 <para>In order to inspect or manipulate atoms and molecules at a
1973 certain time step, the World&apos;s time has to be set with the following
1974 Action.
1975 </para>
1976 <para>This will set the World&apos;s time to the fifth step (counting
1977 starts at zero).</para>
1978 <programlisting>... --set-world-time 4</programlisting>
1979 <para>Note that each atom has its own tracjectory storage and manages it in a clever way. That&apos;s why subsets of atoms may be time-integrated, while the other atoms will not get taken over on the time axis. They simply remain frozen during the integration.</para>
1980 </section>
1981 <section xml:id="dynamics.save-temperature">
1982 <title xml:id="dynamics.save-temperature.title">Save the temperature information</title>
1983 <para>For each present time step the temperature (i.e. the average velocity
1984 per atom multiplied with its mass) will be stored to a file.</para>
1985 <programlisting> ... --save-temperature temperature.dat</programlisting>
1986 <para>That is <emphasis role="italic">temperature.dat</emphasis> contains two columns: the first contains the time step and the second column contains the temperature of the system in atomic units.</para>
1987 </section>
1988 </section>
1989 <section xml:id="dynamics.tesselation">
1990 <title xml:id="dynamics.tesselation.title">Tesselations</title>
1991 <para>A tesselation is a set of triangles that form a closed surface. They are used to obtain molecular surfaces (and volumes) by rolling
1992 a virtual sphere of a certain radii on a molecule such that it always rests on at least three atoms. From such a resting position the sphere is rolled over all of its three sides until it rests again. This is continued until the closed
1993 surface of connected triangles is created.</para>
1994 <para>Note that tesselations are used internally by the graphical interface in order to show molecules by their surface. This is in general faster than displaying them as a ball-stick model consisting of spheres and cylinders.</para>
1995 <section xml:id="dynamics.tesselation.nonconvex-envelope">
1996 <title xml:id="dynamics.tesselation.nonconvex-envelope.title"> Non-convex envelope</title>
1997 <para>This will create a non-convex envelope for a molecule and store
1998 it to a file for viewing with external programs.</para>
1999 <programlisting>
2000 ... --nonconvex-envelope 6. \
2001 --nonconvex-file nonconvex.dat
2002 </programlisting>
2003 <para>This tesselation file can be conveniently viewed with
2004 <productname>TecPlot</productname> or with one of the Tcl script
2005 in the <emphasis role="italic">util</emphasis> folder with <productname>VMD</productname>. Also,
2006 still pictures can be produced with <productname>Raster3D </productname>.
2007 <note>The required file header.r3d can be found in a subfolder of the util folder.</note>
2008 </para>
2009 </section>
2010 <section xml:id="dynamics.tesselation.convex-envelope">
2011 <title xml:id="dynamics.tesselation.convex-envelope.title">Convex envelope</title>
2012 <para>This will create a convex envelope for a molecule and give the
2013 volumes of both the non-convex and the convex envelope. This is good
2014 for measuring the space a molecule takes up, e.g. when filling a
2015 domain and taking care of correct densities.</para>
2016 <programlisting>
2017 ... --convex-envelope 6. \
2018 --convex-file convex.dat
2019 </programlisting>
2020 <para>This tesselation file can be likewise viewed with
2021 <productname>TecPlot</productname> or with one of the Tcl script
2022 in the util folder with <productname>VMD</productname>.</para>
2023 </section>
2024 </section>
2025 <section xml:id="various">
2026 <title xml:id="various.title">Various commands</title>
2027 <para>Here, we gather all commands that do not fit into one of above
2028 categories for completeness.</para>
2029 <section xml:id="various.verbose">
2030 <title xml:id="various.verbose.title">Changing verbosity</title>
2031 <para>The verbosity level is the amount of stuff printed to screen.
2032 This information will in general help you to understand when
2033 something does not work. Mind the <emphasis>ERROR</emphasis> and
2034 <emphasis>WARNING</emphasis> messages in any case.</para>
2035 <para>This command below sets the verbosity from default of 2 to 4,</para>
2036 <programlisting>... --verbose 4</programlisting>
2037 <para>or shorter,</para>
2038 <programlisting>... -v 4</programlisting>
2039 </section>
2040 <section xml:id="various.dry-run">
2041 <title xml:id="various.dry-run.title">Dry runs</title>
2042 <para>A &quot;dry run&quot; refers to a test run where commands are not
2043 actually executed. You may bracket a certain set of actions by
2044 putting --<emphasis role="bold">dry-run</emphasis> before and --<emphasis role="bold">no-dry-run</emphasis> afterwards. Then, all
2045 actions in between will be looked at but not executed, i.e. they
2046 make it to the history but nothing is changed in the World.</para>
2047 <para>As an example, the following listing contains the adding of a
2048 hydrogen atom at position (5,5,5) inside the aforementioned dry run
2049 statements. Hence, no hydrogen atom is added but the <emphasis role="bold">add-atom</emphasis> action is
2050 stored in the history and will make it to a stored session.</para>
2051 <programlisting> ... --dry-run \
2052 --add-atom 1 --domain-position &quot;5,5,5&quot;
2053 --no-dry-run</programlisting>
2054 <para>This is useful for converting shell commands into python scripts. Commands are not executed but all are eventually found in the written pyrthon file.</para>
2055 </section>
2056 <section xml:id="various.element-db">
2057 <title xml:id="various.element-db.title">Loading an element database</title>
2058 <para>Element databases contain information on valency, van der
2059 Waals-radii and other information for each element.</para>
2060 <para>This loads all element database from the current folder (in a
2061 unix environment):</para>
2062 <programlisting>... --element-db ./</programlisting>
2063 </section>
2064 <section xml:id="various.fastparsing">
2065 <title xml:id="various.fastparsing.title">Fast parsing</title>
2066 <para>Parsing all time steps from a given input file can take a
2067 while, especially for larger systems. If fast parsing is activated,
2068 only the first time step is loaded, all other are ignored.</para>
2069 <programlisting>... --fastparsing 1</programlisting>
2070 </section>
2071 <section xml:id="various.version">
2072 <title xml:id="various.version.title">Giving the version of the program</title>
2073 <para>This prints the version information of the code, especially
2074 important when you request the fixing of bugs or implementation of
2075 features.</para>
2076 <programlisting>... --version</programlisting>
2077 </section>
2078 <section xml:id="various.warranty">
2079 <title xml:id="various.warranty.title">Giving warranty information</title>
2080 <para>As follows warranty information is given,</para>
2081 <programlisting>... --warranty</programlisting>
2082 </section>
2083 <section xml:id="various.help-redistribute">
2084 <title xml:id="various.help-redistribute.title">Giving redistribution information</title>
2085 <para>This gives information on the license and how to redistribute
2086 the program and its source code</para>
2087 <programlisting>... --help-redistribute</programlisting>
2088 </section>
2089 </section>
2090 <section xml:id="sessions">
2091 <title xml:id="sessions.title">Sessions</title>
2092 <para>A session refers to the queue of actions you have executed.
2093 Together with the initial configuration (and all files required for
2094 actions in the queue) this may be seen as a clever way of storing
2095 the state and history of a molecular system manipulation session. When proceeding in a try&amp;error
2096 fashion to construct a certain system, it is a good idea, to store the
2097 session at the point where your attempts start to deviate from one
2098 another.</para>
2099 <para>Note only that but stored session used in the graphical interface may safe a lot of repetitive pointing and clicking. On top of that if the python session file is called <emphasis role="italic">molecuilder.py</emphasis> and resides in the folder you start MoleCuilder from, then it will be executed automatically and even before creating the graphical interface (i.e. it is also faster).</para>
2100 <section xml:id="sessions.store-session">
2101 <title xml:id="sessions.store-session.title">Storing a session </title>
2102 <para>Storing sessions is simple,</para>
2103 <programlisting>
2104 ... --store-session &quot;session.py&quot; \
2105 --session-type python
2106 </programlisting>
2107 <para>Here, the session type is given as python (the other option is
2108&quot; cli&quot; for storing in the manner of the command-line interface, i.e. just as our example code snippets throughout this guide). The written
2109 python script <filename>session.py</filename> can even be used with
2110 the python interface described below, i.e. it is a full python script
2111 (that however requires the so-called <emphasis role="italic">pyMoleCuilder</emphasis> module).</para>
2112 </section>
2113 <section xml:id="sessions.load-session">
2114 <title xml:id="sessions.load-session.title">Loading a session</title>
2115 <para>Loading a session only works for python scripts, i.e. only for session type python and not for type cli. This actually
2116 blurs the line between the command-line interface and the python
2117 interface a bit. Again, MoleCuilder automatically executes a
2118 script called <filename>molecuilder.py</filename> if such a file is
2119 contained in the current directory.</para>
2120 <programlisting>... --load-session &quot;session.py&quot;</programlisting>
2121 <para>This will execute every action with its options contained in the
2122 script <filename>session.py</filename>.</para>
2123 </section>
2124 </section>
2125 <section xml:id="various-specific">
2126 <title xml:id="various-specific.title">Various specific commands </title>
2127 <para>In this (final) section of the action description we list a number
2128 Actions that are very specific to some purposes (or other programs).
2129 </para>
2130 <section xml:id="various-specific.save-selected-atoms-as-exttypes">
2131 <title xml:id="various-specific.save-selected-atoms-as-exttypes.title"> Saving exttypes of a set of atoms</title>
2132 <para>This saves the atomic ids of all currently selected atoms in a
2133 <link xlink:href="http://www.tremolo-x.com/">
2134 <productname>TREMOLO </productname>
2135 </link> exttypes file with the given name.</para>
2136 <programlisting>
2137 ... --save-selected-atoms-as-exttypes \
2138 --filename test.exttypes </programlisting>
2139 </section>
2140 <section xml:id="various-specific.set-parser-parameters">
2141 <title xml:id="various-specific.set-parser-parameters.title">Setting parser specific parameters</title>
2142 <para>You can tweak the parameters stored in files associated to specific ab initio programs to some extent.
2143 For example, <productname>MPQC</productname> stores various
2144 parameters modifying the specific ab-initio calculation performed, e.g. the basis set used, the level of theory, whether gradients are calculated.
2145 For <link xlink:href="http://www.mpqc.org/">
2146 <productname>MPQC </productname>
2147 </link> and
2148 <link xlink:href="http://www.psicode.org/">
2149 <productname>Psi4 </productname>
2150 </link> this can be modified as follows.</para>
2151 <programlisting>
2152 ... --set-parser-parameters mpqc \
2153 --parser-parameters &quot;theory=CLHF;basis=6-31*G;&quot;
2154 </programlisting>
2155 <para>This sets the ab-initio theory to closed-shell Hartree-Fock
2156 and the basis set to 6-31*G. Note the specific &quot;key=value;&quot; system. That is a key such as &quot;theory&quot; is followed by an equivalent sign and by a value, here &quot;CLHF&quot; for closed-shell Hartree-Fock, and finally a semicolon to separate the key-value pairs. Please avoid any unnecessary white spaces. Note that the implementation is probably not complete, hence do check the
2157 <productname>MPQC</productname> manual on further supported values that must be added by hand. We list below the currently implementd list of keys and their values.</para>
2158 <itemizedlist>
2159 <listitem>theory</listitem>
2160 <listitem>basis</listitem>
2161 </itemizedlist>
2162 </section>
2163 <section xml:id="various-specific.set-tremolo-atomdata">
2164 <title xml:id="various-specific.set-tremolo-atomdata.title">Tremolo specific options and potential files</title>
2165 <para><productname>TREMOLO</productname>&apos;s configuration files start
2166 with a specific line telling the amount of information that is contained in the
2167 file. This line can be modified, e.g. to enforce storing of
2168 velocities and forces as well as the atoms positions and
2169 element.</para>
2170 <programlisting>
2171 ... --set-tremolo-atomdata &quot;ATOM id element u=3 v=3 F=3&quot; \
2172 --reset 1
2173 </programlisting>
2174 <para>This will not append but reset the old line and fill it with
2175 the given string.</para>
2176 <para>One further specific action is required when loading certain
2177 <productname>TREMOLO</productname> configuration files. These
2178 contain element notations that refer to parameterized names used in
2179 empirical potentials and molecular dynamics simulations and not the
2180 usual chemical symbols, such as H or O. We may load an auxiliary
2181 file that gives the required conversion from OH1 to H, which is the
2182 so-called potentials file.</para>
2183 <programlisting>... --parse-tremolo-potentials water.potentials</programlisting>
2184 <para>This parses the lookup table from the file
2185 <filename>water.potentials</filename> and it can be used in
2186 following load actions.</para>
2187 <para>Note that this is the same format as written by the fitting actions. However, apart from this the Actions are not related, i.e. <emphasis role="bold">parse-potentials</emphasis> will not also load these element descriptions. If this is desired, the above Action has to be used.</para>
2188 </section>
2189 </section>
2190 </section>
2191 <section xml:id="textmenu-interface">
2192 <title xml:id="textmenu-interface.title">Text menu</title>
2193 <para>We now discuss how to use the text menu interface.</para>
2194 <para>The text menu is very much the interface counterpart to the
2195 command-line interface. However, both work in a terminal session.</para>
2196 <para>In the text menu, actions can be selected from hierarchical lists.
2197 Note that the menus for the graphical interface are organized in the
2198 exactly same way. After an action has been chosen, the option values
2199 have to be entered one after the other. After the last option value has
2200 been given, the action is executed and the result printed to the
2201 screen.</para>
2202 <para>With regards to the other functionality, it is very much the same
2203 as the command-line interface above. It differs by being interactive, i.e. when using an external viewer on the state file and saving it after an Action has been performed, output can be checked. However, you may work in this way also directly by using the graphical interface.</para>
2204 </section>
2205 <section xml:id="graphical-user-interface">
2206 <title xml:id="graphical-user-interface.title">Graphical user interface </title>
2207 <para>The main point of the GUI is that it renders the atoms and
2208 molecules visually. These are represented by the common
2209 stick-and-ball-model by default. For faster rendering, molecules can also be visualized by the a non-convex envelope, see Tesselations. Single or multiple atoms and molecules can easily
2210 be accessed, activated, and manipulated via tables. Changes made in the
2211 tables cause immediate update of the visual representation. Under the
2212 hood each of these manipulations is nothing but the call to an action,
2213 hence is fully undo- and redoable.</para>
2214 <para>This interface is most helpful in designing more advanced structures that are
2215 conceptually difficult to imagine without visual aid. Results can be inspected directly and, if unsuitable, can be undone and reperformed with tweaked parameters. At the end, a
2216file containing the session may be stored and this script can then be used to construct
2217 various derived or slightly modified structures.</para>
2218 <section xml:id="graphical-user-interface.basic-view">
2219 <title xml:id="graphical-user-interface.basic-view.title">Basic view </title>
2220 <para>Let us first give an impression of the basic view of the GUI after a molecule has been loaded.</para>
2221 <figure>
2222 <title>Screenshot of the basic view of the GUI after loading a file with eight water molecules.</title>
2223 <mediaobject>
2224 <imageobject>
2225 <imagedata width="100%" scalefit="1" entityref="example_basic_view"/>
2226 </imageobject>
2227 </mediaobject>
2228 </figure>
2229 <section xml:id="graphical-user-interface.3d-view">
2230 <title xml:id="graphical-user-interface.3d-view.title">3D view </title>
2231 <para>In the above figure, you see the stick-and-ball representation
2232 of the water molecules, the &quot;dreibein&quot; giving the positive axis
2233 directions and the slightly translucent cuboid of the domain on a black background.</para>
2234 </section>
2235 <section xml:id="graphical-user-interface.information-tabs">
2236 <title xml:id="graphical-user-interface.information-tabs.title"> Information Tabs</title>
2237 <para>Beneath this 3D view that you can rotate at will with your mouse
2238 and zoom in and out with your scroll wheel, you find to the right a
2239 part containing two tabs named Atom and Molecule. Look at where the
2240 mouse pointer is. It has colored the atom underneath in cyan
2241 (although it&apos;s also an oxygen atom and should be colored in rose
2242 as the rest). You can inspect its properties in the tab Atom: Name,
2243 element, mass, charge, position and number of bonds. If you switch
2244 to the Molecule tab, you would see the properties of the water
2245 molecule this specific atom belongs to.</para>
2246 </section>
2247 <section xml:id="graphical-user-interface.shape">
2248 <title xml:id="graphical-user-interface.shape.title">Shape section </title>
2249 <para>Beneath these information tabs you find the shape sections.
2250 There you find a list of all currently created shapes and you can
2251select them by clicking on them, which lets their surface appear in the 3D view, and manipulate them via the buttons beneath this list. Note that the calculation of the shape&apos;s surface may take up to a few seconds, so don&apos;t get itchy right away when nothing seems to happen for a moment.</para>
2252 </section>
2253 <section xml:id="graphical-user-interface.timeline">
2254 <title xml:id="graphical-user-interface.timeline.title">Timeline </title>
2255 <para>Directly below the 3D view there is a long slider. If a loaded
2256 file has multiple time step entries, this slider allows you to
2257 smoothly select one time frame after another. Sliding it with the
2258 mouse from left to right will reveal the animation that is hidden
2259 behind the distinct snapshots stored in the configuration
2260 file.</para>
2261 </section>
2262 <section xml:id="graphical-user-interface.tables">
2263 <title xml:id="graphical-user-interface.tables.title">Selection tables</title>
2264 <para>Underneath the time line there is another place for
2265 tabs.</para>
2266 <para>The first is on molecules, listing all present molecules of
2267 the molecular system in a tree view. If you click on a specific
2268 molecule, the one will get selected or unselected depending on its
2269 current selection state (see below for details on this with respect
2270 to the GUI). Also, if you tick the box the visibility of the specific molecules is changed: it switches between being displayed as either ball-and-stick, for manipulating its individual atoms, or as a molecular surface for (un)selecting it as a whole.</para>
2271 <para>The next tab enumerates all elements known to MoleCuilder
2272 where the ones are grayed out that are not present in the molecular
2273 system. Clicking on a present element will select all atoms of this
2274 specific element. A subsequent click unselects again.</para>
2275 <para>Subsequently follow tabs on enumerating the fragments and their
2276 fragment energies if calculated and the homologies along with
2277 graphical depiction (via QWT), again if present.</para>
2278 </section>
2279 </section>
2280 <section xml:id="graphical-user-interface.selections">
2281 <title xml:id="graphical-user-interface.selections.title">Selections </title>
2282 <para>Selections work generally always by calling a selection action from the pull-down menu and filling it with required parameters.</para>
2283 <para>With the GUI it may also be accessed directly: The row of icons
2284 above the 3D view has two icons depicting the selection of individual
2285 atoms or molecules. If either of them is selected, clicking with the
2286 left mouse button on an atom will either (un)select the atom or its
2287 associated molecule. Multiple atoms can be selected in this
2288 manner.</para>
2289 <para>Also, the selection tabs may be used by clicking on the name of a
2290 molecule as stated above or at an element.</para>
2291 <para>Similarly, if shapes are present in the shape section, clicking
2292 them will select them and also cause a translucent visualization to
2293 appear in the 3D view. Note that this visualization is quite costly
2294 right now and not suited to complex shapes. (This is in contrast to the molecular surfaces which are actually cheaper than the ball-and-stick presentation).</para>
2295 </section>
2296 <section xml:id="graphical-user-interface.dialogs">
2297 <title xml:id="graphical-user-interface.dialogs.title">Dialogs</title>
2298 <para>Most essential to the GUI are dialogs. Many action
2299 calls forth such a dialog. A dialog consists of a list of queries for a particular option value, one below the other. As each option
2300 value has a specific type, we briefly go into the details of how these
2301 queries look like.</para>
2302 <note>
2303 <para>Each dialog&apos;s okay button is grayed out until all entered option values
2304 are valid.</para>
2305 </note>
2306 <section xml:id="graphical-user-interface.dialogs.domain">
2307 <title xml:id="graphical-user-interface.dialogs.domain.title">Domain query</title>
2308 <figure>
2309 <title>Screenshot of a dialog showing a domain query</title>
2310 <mediaobject>
2311 <imageobject>
2312 <imagedata width="100%" scalefit="1" entityref="dialog_box"/>
2313 </imageobject>
2314 </mediaobject>
2315 <para>In the domain query a 3x3 symmetric matrix has to be
2316 entered. In the above screenshots you notice that the only
2317 non-zero entries are on the main diagonal. Here, we have simply
2318 specified a cube of edge length 8. The okay button will be grayed
2319 out if the matrix is either singular or not symmetric.</para>
2320 </figure>
2321 </section>
2322 <section xml:id="graphical-user-interface.dialogs.element">
2323 <title xml:id="graphical-user-interface.dialogs.element.title"> Element query</title>
2324 <figure>
2325 <title>Screenshot the add atom action containing an element query</title>
2326 <mediaobject>
2327 <imageobject>
2328 <imagedata width="100%" scalefit="1" entityref="dialog_add-atom_tooltip"/>
2329 </imageobject>
2330 </mediaobject>
2331 <para>Elements are picked from a pull-down box where all known
2332 elements are listed.</para>
2333 <para>In this dialog you also notice that a tooltip is given,
2334 briefly explaining what the action does.</para>
2335 </figure>
2336 </section>
2337 <section xml:id="graphical-user-interface.dialogs.action">
2338 <title xml:id="graphical-user-interface.dialogs.action.title"> Complex query</title>
2339 <figure>
2340 <title>Screenshot of a complex dialog consisting of multiple queries</title>
2341 <mediaobject>
2342 <imageobject>
2343 <imagedata width="100%" scalefit="1" entityref="dialog_complex"/>
2344 </imageobject>
2345 </mediaobject>
2346 <para>Here we show a more complex dialog. It queries for strings,
2347 for integer values (see the increase/decrease arrows), for
2348 booleans and for files (the &quot;choose&quot; buttons opens a file
2349 dialog).</para>
2350 </figure>
2351 </section>
2352 <section xml:id="graphical-user-interface.dialogs.exit">
2353 <title xml:id="graphical-user-interface.dialogs.exit.title">Exit query</title>
2354 <figure>
2355 <title>Screenshort showing the exit dialog</title>
2356 <mediaobject>
2357 <imageobject>
2358 <imagedata width="100%" scalefit="1" entityref="dialog_exit"/>
2359 </imageobject>
2360 </mediaobject>
2361 <para>Finally, we show the dialog that will pop up when exiting
2362 the graphical interface. It will ask whether it should store the
2363 current state of the system in the input file or not. You may
2364 cancel the exit, close without saving or save the current
2365 state.</para>
2366 </figure>
2367 </section>
2368 </section>
2369 </section>
2370 <section xml:id="python-interface">
2371 <title xml:id="python-interface.title">Python interface</title>
2372 <para>Last but not least we elaborate on the python interface. We have
2373 already discusses this interface to some extent. The current session,
2374 i.e. the queue of actions you have executed, can be stored as a python
2375 script and subsequently executed independently of the user interface it
2376 was created with. More generally, MoleCuilder&apos;s Actions can be executed within arbitrary python
2377 scripts where prior to its execution a specific module has to be loaded, enabling access to MoleCuilder&apos;s actions from inside the
2378 script.</para>
2379 <para>MoleCuilder&apos;s python module is called <emphasis role="italic">pyMoleCuilder</emphasis>. It is
2380 essentially a library that can be imported into python just as any other
2381 module. Let us assume you have started the python interpreter and you
2382 have added the containing folder of the <filename>pyMoleCuilder</filename>
2383 library to the <varname>PYTHONPATH</varname> variable.</para>
2384 <programlisting>import pyMoleCuilder as mol</programlisting>
2385 <para>Subsequently, you can access the help via</para>
2386 <programlisting>help(mol)</programlisting>
2387 <para>This will list all of MoleCuilder&apos;s actions with their function
2388 signatures within python as contained in the module <emphasis role="italic">pyMoleCuilder</emphasis> named
2389 as <emphasis role="bold">mol</emphasis> in the scope of the currently running interpreter. Note that the
2390 function names are not the names you know from the command-line
2391 interface, they might be called
2392 <computeroutput>WorldChangeBox(...)</computeroutput> or alike. However, they are related by a certain naming system. The first word is identical to the menu name it resides in the text or graphical interface. Then its followed by the actual name of the action that is similar to the command-line token.</para>
2393 <para>Let&apos;s try it out.</para>
2394 <programlisting>print mol.CommandVersion()</programlisting>
2395 <para>This will state the current version of the library.</para>
2396 <para>Go ahead and try out other commands. Refer to the documentation
2397 under the command-line interface and look up the function name via
2398 help.</para>
2399 </section>
2400 </chapter>
2401 <chapter>
2402 <title>Conclusions</title>
2403 <para>This ends this user guide.</para>
2404 <para>We have given you a brief introduction to the aim of the program and
2405 how each of the four interfaces are to be used. The rest is up to
2406 you.</para>
2407 <para>Tutorials and more information is available online, see <link xlink:href="http://www.molecuilder.com/">MoleCuilder&apos;s website</link>.
2408 </para>
2409 <para>Be aware that in general knowing how the code works allows you to
2410 understand what&apos;s going wrong if something&apos;s going wrong.</para>
2411 <section>
2412 <title>Thanks</title>
2413 <para>Huge thanks go out to Saskia Metzler who was patient enough to let
2414 me sit next to her while riding ten hours in a bus to Berlin as I was writing the very first version of this guide.</para>
2415 </section>
2416 </chapter>
2417</book>
Note: See TracBrowser for help on using the repository browser.