1 | /*
|
---|
2 | * Project: MoleCuilder
|
---|
3 | * Description: creates and alters molecular systems
|
---|
4 | * Copyright (C) 2010 University of Bonn. All rights reserved.
|
---|
5 | * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
|
---|
6 | */
|
---|
7 |
|
---|
8 | /**
|
---|
9 | * \file fragmentation.dox
|
---|
10 | *
|
---|
11 | * Created on: Oct 28, 2011
|
---|
12 | * Author: heber
|
---|
13 | */
|
---|
14 |
|
---|
15 | /** \page fragmentation Fragmentation
|
---|
16 | *
|
---|
17 | * Fragmentation contains all routines that are required to split a given
|
---|
18 | * molecular system into fragments. This is part of the so-called BOSSANOVA
|
---|
19 | * (Bond Order diSSection in an ANOVA-like fashion) approach to get linear
|
---|
20 | * scaling complexity for ab-initio quantum chemistry methods. This method is
|
---|
21 | * explained in the doctoral thesis of Frederik Heber.
|
---|
22 | *
|
---|
23 | * \secton fragmentation-fragmentation Fragmenting molecules
|
---|
24 | *
|
---|
25 | * Everything starts in the Action FragmentationFragmentationAction. We require
|
---|
26 | * a list of selected atoms. These are browsed and we note down all the associated
|
---|
27 | * molecules (fragmentation is molecule-based). Subsequently, we make sure that
|
---|
28 | * the bond degree has correct bond degress with respect to the selected set.
|
---|
29 | * Then, Fragmentation is created for each molecule in the list.
|
---|
30 | * The class Fragmentation contains with Fragmentation::FragmentMolecule()
|
---|
31 | * the main routine that dissect a given molecule
|
---|
32 | * Afterwards, all KeySet's are obtained as a Graph from the Fragmentation
|
---|
33 | * instance and combined into a single graph.
|
---|
34 | * Via a depth first search analysis cycles are detected and added as
|
---|
35 | * cycle fragments to this sets of KeySet.
|
---|
36 | * Finally, all fragments are placed in the FragmentationResultContainer.
|
---|
37 | *
|
---|
38 | * If desired, \b inter-fragments, that fragments are combined if they are only
|
---|
39 | * a certain distance apart from another and their summed fragmentation orders
|
---|
40 | * do not exceed the specified value. This is required for local correlation
|
---|
41 | * calculation. Otherwise correlation is only calculated (if supported by the
|
---|
42 | * solver) within covalently connected fragments, i.e. we do not get any van
|
---|
43 | * der Waals interactions.
|
---|
44 | *
|
---|
45 | * These fragments may be exported to file if output file types \sa fileformats
|
---|
46 | * are given. There, the current FormatParserParameters are used. If none are
|
---|
47 | * given, fragments remain in the FragmentationResultContainer.
|
---|
48 | *
|
---|
49 | * \secton fragmentation-automation Calculating fragments
|
---|
50 | *
|
---|
51 | * If then FragmentationFragmentationAutomationAction is used, these are converted
|
---|
52 | * into MPQCJobs (and VMGJobs) that are passed on via a network connection to a
|
---|
53 | * JobMarket's server as a FragmentJob.
|
---|
54 | * Any idling connected clients will then process each one of the jobs until the
|
---|
55 | * whole bundle is completed. The Action checks on the current tatus of the jobs
|
---|
56 | * and requests any finished jobs (FragmentResult).
|
---|
57 | * After all jobs' results have been received, they are stored in
|
---|
58 | * FragmentationShortRangeResults and FragmentationLongrangeResults.
|
---|
59 | * FragmentationAnalyseFragmentResultsAction will process both these results and
|
---|
60 | * sum up the approximate energy and forces (where these are set as the atoms'
|
---|
61 | * forces for the current time step).
|
---|
62 | *
|
---|
63 | * Alternatively to automation, where everything is done inside MoleCuilder, one
|
---|
64 | * may also use the exported files to calculate an approximation. To this end,
|
---|
65 | * the energies and forces are put together via \b joiner to approximation
|
---|
66 | * to the total energy and forces of the whole molecular system. Later,
|
---|
67 | * \b analyzer additionally gives data on how good this approximation has
|
---|
68 | * worked out in plotable format.
|
---|
69 | *
|
---|
70 | *
|
---|
71 | * \date 2014-03-10
|
---|
72 | *
|
---|
73 | */
|
---|