[b380ed] | 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 filling.dox
|
---|
| 10 | *
|
---|
| 11 | * Created on: Jan 16, 2012
|
---|
| 12 | * Author: heber
|
---|
| 13 | */
|
---|
| 14 |
|
---|
| 15 | /** \page filling Filling a domain
|
---|
| 16 | *
|
---|
[caece4] | 17 | * The idea behind filling a domain is to cluster it with a set of \b nodes,
|
---|
| 18 | * i.e. a position in space in such a way that e.g. around a node is sufficient
|
---|
[b380ed] | 19 | * space to fill in the desired molecule. The logic of generating the nodes
|
---|
| 20 | * is responsible to create them in such a way as to allow for dense (or
|
---|
| 21 | * whatever specific) filling is desired. However, we must not make it too
|
---|
| 22 | * complicated. The generation logic for these nodes should concentrate on
|
---|
| 23 | * filling the specific domain (sphere, ellipsoid, cuboid, pyramid, ...)
|
---|
| 24 | * in the best possible way.
|
---|
[caece4] | 25 | * Whether each node can be filled is then to be decided by a \b predicate.
|
---|
[b380ed] | 26 | *
|
---|
| 27 | * The filling routine uses then both to traverse the given nodes and
|
---|
| 28 | * evaluate the predicate at each.
|
---|
| 29 | *
|
---|
| 30 | * Hence, the filling of a domain is abstracted into the following parts:
|
---|
| 31 | *
|
---|
[dba7b0] | 32 | * -# \ref Mesh - node containers
|
---|
| 33 | * -# \ref FillPredicate - predicates
|
---|
| 34 | * -# \ref Filler - a filling routine which itself requires
|
---|
| 35 | * -# \ref Cluster - a set of atoms alone(!) inside a specific Shape
|
---|
| 36 | * -# \ref CopyAtomsInterface - copy Method for atoms used by Cluster::clone
|
---|
| 37 | * -# \ref Inserter - an insertion routine for the cloned cluster
|
---|
[b380ed] | 38 | *
|
---|
| 39 | * \section filling-node-generation Node generation
|
---|
| 40 | *
|
---|
| 41 | * The node generation is basically just a point or mesh generator that fills
|
---|
[caece4] | 42 | * a specified region based on the class Shape with a mesh in such a way as to
|
---|
| 43 | * fulfill certain criteria:
|
---|
[b380ed] | 44 | *
|
---|
| 45 | * -# equidistant
|
---|
| 46 | * -# containing certain primitive volumes (e.g. for fitting polymers)
|
---|
| 47 | * -# ...
|
---|
| 48 | *
|
---|
| 49 | * \section filling-predicate Predicates
|
---|
| 50 | *
|
---|
| 51 | * The Predicate pattern has already been used with Descriptors and Shapes.
|
---|
| 52 | * These are simply function objects that return a boolean value. I.e. they
|
---|
| 53 | * decide whether the current node in the mesh is vacant and can be filled or
|
---|
| 54 | * not. As with the predicate() function in the class Descriptor, these should
|
---|
[dba7b0] | 55 | * be composable via logic operators such as || (or), && (and), ! (not), ...
|
---|
[b380ed] | 56 | *
|
---|
[caece4] | 57 | * \note each predicate receives on construction all the required
|
---|
[b380ed] | 58 | * information, e.g. LinkedCell_View or Tesselation references or objects, ...
|
---|
| 59 | *
|
---|
| 60 | * \section filling-filling-routine Filling routine
|
---|
| 61 | *
|
---|
| 62 | * The filling routine is then simply a function that goes through the given
|
---|
| 63 | * number of nodes (completely unaware of the geometry) and evaluates for each
|
---|
| 64 | * point the given predicates (which might be a composition of other predicates).
|
---|
| 65 | *
|
---|
| 66 | * It rejects all nodes that evaluate to false, the list of valid points is
|
---|
[caece4] | 67 | * then traversed again and at each node a Cluster is created by the copy method.
|
---|
[dba7b0] | 68 | *
|
---|
| 69 | * Note that we rely on \ref Cluster's, objects containing a set of atomicId_t
|
---|
[caece4] | 70 | * and a \ref Shape, containing all of these atoms, to fill at each node. We use
|
---|
[dba7b0] | 71 | * Cluster::clone() to create a copy that is subsequently placed at the desired
|
---|
| 72 | * node via an \ref Inserter functor. This allows to either simply shift the
|
---|
| 73 | * Cluster or even to perform some random translations and rotations on it, see
|
---|
| 74 | * the specific implementations of the class \ref Inserter.
|
---|
[b380ed] | 75 | *
|
---|
[cae614] | 76 | * \section filling-preparators Filling Preparators
|
---|
[b380ed] | 77 | *
|
---|
[cae614] | 78 | * The filling function depends on quite a number of other instances. In order
|
---|
| 79 | * to make this a little easier to use, there are so called FillerPreparators
|
---|
| 80 | * for various purposes:
|
---|
| 81 | * -# BoxFillerPreparator - fills the simulation domain
|
---|
| 82 | * -# ShapeSurfaceFillerPreparator - fills on the surface of a selected shape
|
---|
| 83 | * -# ShapeVolumeFillerPreparator - fills the volume of a selected shape
|
---|
| 84 | *
|
---|
| 85 | * These offer various functions to easily install an Inserter, a Mesh, and
|
---|
| 86 | * necessary FillPredicates. See the Filling Actions such as
|
---|
| 87 | * MoleCuilder::FillVolumeAction as example.
|
---|
| 88 | *
|
---|
| 89 | * \date 2014-09-04
|
---|
[b380ed] | 90 | */
|
---|