Symmetry groups¶
This is an introduction to group theoretical concepts for symmetry in Mantid. It is the basis for further descriptions covering point groups and space groups.
Introduction¶
Symmetry in space of any dimensionality can be described by symmetry groups. This and the following guides cover symmetry in three dimensions, as it is most commonly used in crystallography and how it is integrated into Mantid. All code samples are given as Python code and can be executed directly in the program.
Groups¶
A group
Closure: For all
in the result of is also in . Associativity: For all
in , is equal to . Identity element: There exists an element
in such that . Inverse element: For each
in there exists an element in such that .
There are many examples for groups, for example the group defined by the set of signed integer numbers and the addition operation. Any two integers added result again in an integer, integer addition is associative, there is an identity element (the number 0) and for each integer there is an inverse element (the number with the same magnitude, but opposite sign). For describing symmetry, groups are required that consist of a set of symmetry operations and a binary operation that combines them. The next section describes how symmetry operations can be represented and how to work with them in Mantid.
Symmetry operations¶
Theory¶
As symmetry operations are used for the definition of space groups, the mathematics behind this are covered in depth in the International Tables for Crystallography A (ITA), namely part 11 [ITASymmetry]. A symmetry operation describes the transformation of an object
For a coordinate
Coordinates
Of course it is also possible to transform vectors (such as reciprocal vectors
For the definition of the group
While matrix and vector pairs are very well suited for modelling symmetry operaitions in a computer language, they are not very convenient for human language. A very common notation is the “Jones-faithful” system, which is for example used in the symmetry operations section in the space group descriptions in ITA. It uses
Symbol |
Symmetry operation |
---|---|
|
Identity |
|
Inversion |
|
2-fold rotation around |
|
Mirror plane perpendicular to |
|
There are several advantages to this notation. First of all it’s very concise and secondly it directly shows how a point
Last but not least, each symmetry operation has a so called order
The same is true for transforming coordinates as well. Applying a symmetry operation of order
Symmetry operations in Mantid¶
Symmetry operations are implemented in Mantid following the scheme described above with matrix and vector pairs, it is written in C++ and resides in the Geometry library. How to use this code is described in the doxygen documentation and shall not be covered at this point. Instead this section describes how symmetry operations can be used in the Python environment of Mantid.
As described above, the operations are represented using the Jones-faithful notation, so they can be created by a factory that parses these strings. It returns a SymmetryOperation-object which can be queried for certain characteristics. The most obvious one is the identifier string. It may differ from the one used to create the operation, because the strings are normalized internally so that a specific matrix and vector pair always has the same identifier.
from mantid.geometry import SymmetryOperationFactory
# This time the identifier is already normalized
symOp = SymmetryOperationFactory.createSymOp("x,y,-z")
print(symOp.getIdentifier())
# This is an example for an identifier that changes
symOp = SymmetryOperationFactory.createSymOp("1/2+x,y,z")
print(symOp.getIdentifier())
Executing the above code yields the following output, which shows how the operation identifier is modified in some cases:
x,y,-z
x+1/2,y,z
For ease of use with multiple symmetry operations it’s also possible to create multiple operations at once, using a semi-colon separated string of identifiers:
from mantid.geometry import SymmetryOperationFactory
# Create a list of symmetry operations
symOps = SymmetryOperationFactory.createSymOps("x,y,-z; -x,-y,-z; z,x,y")
print("Number of operations: " + str(len(symOps)))
print("Operations:")
for op in symOps:
print(op.getIdentifier())
This prints each identifier on a new line:
Number of operations: 3
Operations:
x,y,-z
-x,-y,-z
z,x,y
Symmetry operation objects can be used to transform coordinates or Miller indices, which are handled differently as detailed in the theory section above, so different methods exists for each of the two tasks.
from mantid.geometry import SymmetryOperationFactory
symOp = SymmetryOperationFactory.createSymOp("x-y,x,z")
coordinates = [0.3, 0.4, 0.5]
coordinatesPrime = symOp.transformCoordinates(coordinates)
print("Transformed coordinates: " + str(coordinatesPrime))
This script generates a symmetry operation that is used in hexagonal coordinate systems and uses it to transform the given coordinates:
Transformed coordinates: [-0.1,0.3,0.5]
As transforming HKLs requires slightly different math, there is a special method for this as well:
from mantid.geometry import SymmetryOperationFactory
symOp = SymmetryOperationFactory.createSymOp("x,y,-z")
hkl = [1, -1, 3]
hklPrime = symOp.transformHKL(hkl)
print("Transformed hkl: " + str(hklPrime))
The above code will print the transformed Miller index triplet:
Transformed hkl: [1,-1,-3]
It’s also possible to query the order of a symmetry operation. The next example generates a fourfold rotation around the
from mantid.geometry import SymmetryOperationFactory
symOp = SymmetryOperationFactory.createSymOp("-y,x,z")
k = symOp.getOrder()
print("Order of the symmetry operation: " + str(k))
x = [0.3, 0.4, 0.5]
print("Original point: ["+(','.join(" %.1f"%c for c in x)).strip()+"]")
for i in range(k):
x = symOp.transformCoordinates(x)
print("After {0} application(s): {1}".format(i + 1, x))
Order of the symmetry operation: 4
Original point: [0.3, 0.4, 0.5]
After 1 application(s): [-0.4,0.3,0.5]
After 2 application(s): [-0.3,-0.4,0.5]
After 3 application(s): [0.4,-0.3,0.5]
After 4 application(s): [0.3,0.4,0.5]
Symmetry elements¶
Sometimes it’s easier to describe symmetry in terms of the symmetry element that is associated to an operation. Several notation systems exist for these elements, but Hermann-Mauguin symbols are most commonly used in crystallography. Information on how to read these symbols can be found in ITA. Except identity, inversions and translations, all symmetry elements have a characteristic axis. In case of mirror and glide planes, this axis is perpendicular to the plane.
Section 11.2 in the same book describes how to derive symmetry elements from matrix and vector pairs. The algorithms from that text are implemented in Mantid as well, so after a symmetry operation has been created using the factory, another factory can be used to generate the symmetry element corresponding to the operation. The resulting object can be queried for its Hermann-Mauguin symbol, its axis and its rotation sense (only for rotation axes). For identity, inversion and translation this returns [0, 0, 0]
.
from mantid.geometry import SymmetryOperationFactory, SymmetryElementFactory
symOp = SymmetryOperationFactory.createSymOp("x,y,-z")
element = SymmetryElementFactory.createSymElement(symOp)
print("The element corresponding to 'x,y,-z' has the following symbol: " + str(element.getHMSymbol()))
print("The mirror plane is perpendicular to: " + str(element.getAxis()))
print("Sense of rotation (or NoRotation): " + str(element.getRotationSense()))
In this case, it’s a mirror plane perpendicular to the
The element corresponding to 'x,y,-z' has the following symbol: m
The mirror plane is perpendicular to: [0,0,1]
Sense of rotation (or NoRotation): NoRotation
Symmetry groups¶
In the previous section, symmetry operations and a binary operation combining them were introduced, which is finally sufficient to define symmetry groups. For the purpose of defining groups, it is assumed that coordinates
This group fulfills all four group axioms. The identity matrix multiplied with itself is again identity, so the group is closed. Associativity holds as well, since it does not matter in which order multiple identical operations are performed. Since the only element of the group is the identity, the third axiom is fulfilled as well. So is the fourth, since the inverse of the identity is again identity. This group exists as the point group
As more operations are added to a group, it can be useful to display the group in terms of a group table, which makes it easy to check the group axioms. The following example group contains the symmetry operations
Combining the symmetry operations does not result into any new operations, so the group is closed. Each element has an inverse (in this case, each element is its own inverse). :math:` and an identity element exists (all elements in the first row are the same as in the header row). Groups are available through the Python interface of Mantid. The following code generates the group in the table above (with the y-axis being characteristic for rotation and mirror symmetry) and checks whether this set of symmetry operations is indeed a Group:
from mantid.geometry import Group
group = Group("x,y,z; -x,-y,-z; -x,y,-z; x,-y,z")
print("Order of group: " + str(group.getOrder()))
print("Fulfills group axioms: " + str(group.isGroup()))
This code confirms what was demonstrated by the group table above, the specified set of symmetry operations fulfills the group axioms:
Order of group: 4
Fulfills group axioms: True
For more fine-grained information, the four axioms can also be checked separately. Please note that the associativity axiom is always fulfilled due to the way the binary operation for symmetry operations is defined, it’s included for completeness reasons. In the next example, the inversion operation is removed and the four axioms are checked:
from mantid.geometry import Group, GroupAxiom
group = Group("x,y,z; -x,y,-z; x,-y,z")
print("Group axioms fulfilled:")
print(" 1. Closure: " + str(group.fulfillsAxiom(GroupAxiom.Closure)))
print(" 2. Associativity: " + str(group.fulfillsAxiom(GroupAxiom.Associativity)))
print(" 3. Identity: " + str(group.fulfillsAxiom(GroupAxiom.Identity)))
print(" 4. Inversion: " + str(group.fulfillsAxiom(GroupAxiom.Inversion)))
The code reveals that axioms 2 - 4 are fulfilled, but that the group is not closed:
Group axioms fulfilled:
1. Closure: False
2. Associativity: True
3. Identity: True
4. Inversion: True
Looking into the group table above shows the reason: The combination of a mirror plane and a two-fold rotation axis implies the presence of an inversion center. Similarly, the identity can be removed:
from mantid.geometry import Group, GroupAxiom
group = Group("-x,-y,-z; -x,y,-z; x,-y,z")
print("Group axioms fulfilled:")
print(" 1. Closure: " + str(group.fulfillsAxiom(GroupAxiom.Closure)))
print(" 2. Associativity: " + str(group.fulfillsAxiom(GroupAxiom.Associativity)))
print(" 3. Identity: " + str(group.fulfillsAxiom(GroupAxiom.Identity)))
print(" 4. Inversion: " + str(group.fulfillsAxiom(GroupAxiom.Inversion)))
In contrast to removing the inversion, the group now also lacks an identity element:
Group axioms fulfilled:
1. Closure: False
2. Associativity: True
3. Identity: False
4. Inversion: True
Using these specific checks can be helpful for finding out why a certain set of symmetry operations is not a group.
Some groups are so called cyclic groups, all elements of the group can be expressed as powers of one symmetry operation (which are explained above) from 0 to
Just like in the case of symmetry operations, it’s also possible to define a binary operation that combines two groups. For this, each symmetry operation of the first group is multiplied with each symmetry operation of the second group. If the resulting new set of operations fulfills the group axioms, the product of the two groups is again a group.
These general group concepts are available in the C++ library of Mantid and are described in the API documentation (Mantid::Geometry::SymmetryOperation, Mantid::Geometry::SymmetryElement, Mantid::Geometry::Group). The most important specializations of symmetry groups implemented in Mantid are point- and space groups. They are explained in an additional document.
Wikipedia article on groups. Can be found in different formulations in various places such as Wolfram MathWorld.
International Tables for Crystallography (2006). Vol. A, part 11, p. 810 (chapters 11.1 and 11.2).
Category: Concepts