File: cluster.rst

package info (click to toggle)
python-ase 3.26.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 15,484 kB
  • sloc: python: 148,112; xml: 2,728; makefile: 110; javascript: 47
file content (128 lines) | stat: -rw-r--r-- 4,249 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128

==========================
Nanoparticles and clusters
==========================

There are modules for creating nanoparticles (clusters) with a given crystal
structure by specifying either the number of layers in different directions,
or by making a Wulff construction.

Examples
========

Layer specification
-------------------

This example sets up a nanoparticle of copper in the FCC crystal structure,
by specifying 6 layers in the (100) directions, 9 in the (110) directions and
5 in the (111) directions::

  import ase
  from ase.cluster.cubic import FaceCenteredCubic

  surfaces = [(1, 0, 0), (1, 1, 0), (1, 1, 1)]
  layers = [6, 9, 5]
  lc = 3.61000
  atoms = FaceCenteredCubic('Cu', surfaces, layers, latticeconstant=lc)

|culayer|

.. |culayer| image:: culayer.png


Wulff construction
------------------

To set up a Wulff construction, the surface energies should be
specified, in units of energy per area (*not* energy per atom).  The
actual unit used does not matter, as only the ratio between surface
energies is important.  In addition, the approximate size of the
nanoparticle should be given.  As the Wulff construction is build from
whole layers, it is not possible to hit the desired particles size
exactly::

  from ase.cluster import wulff_construction

  surfaces = [(1, 0, 0), (1, 1, 0), (1, 1, 1)]
  esurf = [1.0, 1.1, 0.9]   # Surface energies.
  lc = 3.61000
  size = 1000  # Number of atoms
  atoms = wulff_construction('Cu', surfaces, esurf,
                             size, 'fcc',
                             rounding='above', latticeconstant=lc)

Note that the Wulff construction currently only work with cubic
lattices.


Creating a nanoparticle
=======================

The :mod:`ase.cluster` module contains a number of sub-modules for
defining clusters, one for each crystal structure.  They are all
called the same way, by specifying the element, the number of layers
in different directions, and optionally the lattice constant.

The layer specification is the only part that may not be intuitive.
It is given as two arrays, one specifying the Miller indices of the
surfaces, and one specifying the number of layers from the center of
the cluster to the respective surfaces.

The surface specification allows for one or more surfaces of a given
family of surfaces to be different from the other surfaces.  This can
be used e.g. to create a cluster where one part has been truncated by
a substrate.  This is done by *first* specifying the number of layers
for the family of surfaces, and *later* specifying the number of
layers for a given surface.  Consider the surface specification

::

   surfaces = [(1, 0, 0), (1, 1, 1), (1, -1, 1)]
   layers = [6, 5, -1]
   atoms = FaceCenteredCubic('Cu', surfaces, layers)

Here we first ask for 6 layers for the {100} surface family, i.e. the
directions (100), (010), (001), (-1,0,0), etc.  Then we ask for 5
layers for the {111} family of surfaces.  Finally, we change the
number of layers for the (-1,1,1) surface.  This is interpreted as a
single surface, since it is part of a family that has already been
specified.  Asking for a negative number of layers is allowed, this
cause the particle to be truncated *before* its center point.  The
result is seen below.

|truncated|

.. |truncated| image:: truncated.png



The functions for creating nanoparticles take the following
arguments:

  ``symbols``: A string specifying the element (or a tuple of strings
  for compounds).

  ``surfaces``: A list of surfaces, as explained above.

  ``layers``:  A corresponding list of the number of layers to be
  included.

  ``vacuum=0.0``:  The amount of vacuum to include around the particle.
  Defaults to 0.

  ``latticeconstant=None``:  The lattice constant of the lattice.  If
  not specified, the experimental value from :mod:`ase.data` is used.


Possible crystal structures
---------------------------

You select the crystal structure by selecting the right function for
creating the nanoparticle.  Currently, these modules only work for the
three cubic crystal structures: FaceCenteredCubic, BodyCenteredCubic,
and SimpleCubic.  Other structures are implemented, but do currently
not work correctly.


.. automodule:: ase.cluster
                :members: