lammps/doc/html/_sources/compute_saed.txt

212 lines
7.4 KiB
Plaintext

.. index:: compute saed
compute saed command
====================
Syntax
""""""
.. parsed-literal::
compute ID group-ID saed lambda type1 type2 ... typeN keyword value ...
* ID, group-ID are documented in :doc:`compute <compute>` command
* saed = style name of this compute command
* lambda = wavelength of incident radiation (length units)
* type1 type2 ... typeN = chemical symbol of each atom type (see valid options below)
* zero or more keyword/value pairs may be appended
* keyword = *Kmax* or *Zone* or *dR_Ewald* or *c* or *manual* or *echo*
.. parsed-literal::
*Kmax* value = Maximum distance explored from reciprocal space origin
(inverse length units)
*Zone* values = z1 z2 z3
z1,z2,z3 = Zone axis of incident radiation. If z1=z2=z3=0 all
reciprocal space will be meshed up to *Kmax*
*dR_Ewald* value = Thickness of Ewald sphere slice intercepting
reciprocal space (inverse length units)
*c* values = c1 c2 c3
c1,c2,c3 = parameters to adjust the spacing of the reciprocal
lattice nodes in the h, k, and l directions respectively
*manual* = flag to use manual spacing of reciprocal lattice points
based on the values of the *c* parameters
*echo* = flag to provide extra output for debugging purposes
Examples
""""""""
.. parsed-literal::
compute 1 all saed 0.0251 Al O Kmax 1.70 Zone 0 0 1 dR_Ewald 0.01 c 0.5 0.5 0.5
compute 2 all saed 0.0251 Ni Kmax 1.70 Zone 0 0 0 c 0.05 0.05 0.05 manual echo
.. parsed-literal::
fix saed/vtk 1 1 1 c_1 file Al2O3_001.saed
fix saed/vtk 1 1 1 c_2 file Ni_000.saed
Description
"""""""""""
Define a computation that calculates electron diffraction intensity as
described in :ref:`(Coleman) <saed-Coleman>` on a mesh of reciprocal lattice nodes
defined by the entire simulation domain (or manually) using simulated
radiation of wavelength lambda.
The electron diffraction intensity I at each reciprocal lattice point
is computed from the structure factor F using the equations:
.. image:: Eqs/compute_saed1.jpg
:align: center
.. image:: Eqs/compute_saed2.jpg
:align: center
Here, K is the location of the reciprocal lattice node, rj is the
position of each atom, fj are atomic scattering factors.
Diffraction intensities are calculated on a three-dimensional mesh of
reciprocal lattice nodes. The mesh spacing is defined either (a) by
the entire simulation domain or (b) manually using selected values as
shown in the 2D diagram below.
.. thumbnail:: JPG/saed_mesh.jpg
:align: center
For a mesh defined by the simulation domain, a rectilinear grid is
constructed with spacing *c*\ *inv(A) along each reciprocal lattice
axis. Where A are the vectors corresponding to the edges of the
simulation cell. If one or two directions has non-periodic boundary
conditions, then the spacing in these directions is defined from the
average of the (inversed) box lengths with periodic boundary conditions.
Meshes defined by the simulation domain must contain at least one periodic
boundary.
If the *manual* flag is included, the mesh of reciprocal lattice nodes
will defined using the *c* values for the spacing along each reciprocal
lattice axis. Note that manual mapping of the reciprocal space mesh is
good for comparing diffraction results from multiple simulations; however
it can reduce the likelihood that Bragg reflections will be satisfied
unless small spacing parameters <0.05 Angstrom^(-1) are implemented.
Meshes with manual spacing do not require a periodic boundary.
The limits of the reciprocal lattice mesh are determined by the use of
the *Kmax*\ , *Zone*\ , and *dR_Ewald* parameters. The rectilinear mesh
created about the origin of reciprocal space is terminated at the
boundary of a sphere of radius *Kmax* centered at the origin. If
*Zone* parameters z1=z2=z3=0 are used, diffraction intensities are
computed throughout the entire spherical volume - note this can
greatly increase the cost of computation. Otherwise, *Zone*
parameters will denote the z1=h, z2=k, and z3=l (in a global since)
zone axis of an intersecting Ewald sphere. Diffraction intensities
will only be computed at the intersection of the reciprocal lattice
mesh and a *dR_Ewald* thick surface of the Ewald sphere. See the
example 3D intestiety data and the intersection of a [010] zone axis
in the below image.
.. thumbnail:: JPG/saed_ewald_intersect.jpg
:align: center
The atomic scattering factors, fj, accounts for the reduction in
diffraction intensity due to Compton scattering. Compute saed uses
analytical approximations of the atomic scattering factors that vary
for each atom type (type1 type2 ... typeN) and angle of diffraction.
The analytic approximation is computed using the formula
:ref:`(Brown) <Brown>`:
.. image:: Eqs/compute_saed3.jpg
:align: center
Coefficients parameterized by :ref:`(Fox) <Fox>` are assigned for each
atom type designating the chemical symbol and charge of each atom
type. Valid chemical symbols for compute saed are:
H: He: Li: Be: B:
C: N: O: F: Ne:
Na: Mg: Al: Si: P:
S: Cl: Ar: K: Ca:
Sc: Ti: V: Cr: Mn:
Fe: Co: Ni: Cu: Zn:
Ga: Ge: As: Se: Br:
Kr: Rb: Sr: Y: Zr:
Nb: Mo: Tc: Ru: Rh:
Pd: Ag: Cd: In: Sn:
Sb: Te: I: Xe: Cs:
Ba: La: Ce: Pr: Nd:
Pm: Sm: Eu: Gd: Tb:
Dy: Ho: Er: Tm: Yb:
Lu: Hf: Ta: W: Re:
Os: Ir: Pt: Au: Hg:
Tl: Pb: Bi: Po: At:
Rn: Fr: Ra: Ac: Th:
Pa: U: Np: Pu: Am:
Cm: Bk: Cf:tb(c=5,s=:)
If the *echo* keyword is specified, compute saed will provide extra
reporting information to the screen.
**Output info:**
This compute calculates a global vector. The length of the vector is
the number of reciprocal lattice nodes that are explored by the mesh.
The entries of the global vector are the computed diffraction
intensities as described above.
The vector can be accessed by any command that uses global values
from a compute as input. See :ref:`this section <howto_15>` for an overview of LAMMPS output
options.
All array values calculated by this compute are "intensive".
Restrictions
""""""""""""
This compute is part of the USER-DIFFRACTION package. It is only
enabled if LAMMPS was built with that package. See the :ref:`Making LAMMPS <start_3>` section for more info.
The compute_saed command does not work for triclinic cells.
Related commands
""""""""""""""""
:doc:`fix saed_vtk <fix_saed_vtk>`, :doc:`compute xrd <compute_xrd>`
Default
"""""""
The option defaults are Kmax = 1.70, Zone 1 0 0, c 1 1 1, dR_Ewald =
0.01.
----------
.. _saed-Coleman:
**(Coleman)** Coleman, Spearot, Capolungo, MSMSE, 21, 055020
(2013).
.. _Brown:
**(Brown)** Brown et al. International Tables for Crystallography
Volume C: Mathematical and Chemical Tables, 554-95 (2004).
.. _Fox:
**(Fox)** Fox, O'Keefe, Tabbernor, Acta Crystallogr. A, 45, 786-93
(1989).
.. _lws: http://lammps.sandia.gov
.. _ld: Manual.html
.. _lc: Section_commands.html#comm