Affine transformation

This modifier applies an affine transformation to the system or specific parts of it. It may be used to translate, scale, rotate or shear the particles, the simulation cell and/or other elements. The transformation can either be specified explicitly in terms of a 3-by-3 matrix plus a translation vector, or implicitly by prescribing a constant target shape for the simulation cell.
Given a 3-by-3 linear transformation matrix \(\mathbf{M}\) and a translation vector \(\mathbf{t}\), which together describe a general affine transformation, the transformed position of a particle at the original Cartesian position \(\mathbf{x}\) is computed as \(\mathbf{x}' = \mathbf{M} \cdot \mathbf{x} + \mathbf{t}\). This notation uses column vectors.
The button Enter rotation opens a dialog box which lets you specify a 3D rotation axis, a rotation angle and a center of rotation. Based on these inputs, OVITO computes the corresponding affine transformation for you.
Translation in reduced coordinates
The option In reduced cell coordinates changes the affine transformation method such that the translation vector \(\mathbf{t}\) is specified in reduced cell coordinates instead of Cartesian coordinates, i.e. in terms of the three vectors that span the simulation cell (after they have been transformed by the linear matrix \(\mathbf{M}\)).
In other words, activating this option changes the affine transformation equation to \(\mathbf{x}' = \mathbf{M} \cdot (\mathbf{x} + \mathbf{H} \cdot \mathbf{t})\) with \(\mathbf{H}\) being the 3-by-3 cell matrix formed by the three edge vectors of the original simulation cell.
Transform to target cell
In Target cell mode, the modifier dynamically computes the affine transformation to be applied to the system from the current shape of the simulation cell and the specified target shape. The contents of the simulation box (e.g. particles, surface meshes, etc.) will be mapped to the new cell shape accordingly, unless you turn off their transformation (see next section).
Tip
Use this option to replace a time-varying cell, e.g. from a constant-pressure simulation, with a constant cell shape of your choice.
Transformed elements
You can select the types of data elements the modifier should touch:
Element type |
Description |
---|---|
Applies the transformation to the coordinates of particles ( |
|
Applies the linear part \(\mathbf{M}\) of the affine transformation to vectorial properties, e.g. the particle properties |
|
Applies the transformation to the origin of the simulation cell and the linear part to the three cell vectors. |
|
Applies the transformation to the vertices of surface meshes and triangle meshes. |
|
Applies the transformation to the domain shape of a voxel grid. |
|
Applies the transformation to all lines. |
|
Applies the transformation to all vector objects. |
|
Applies the transformation to dislocation lines and their Burgers vectors. |
The option Transform only selected particles/vertices restricts the function to the subset of currently selected particles or vertices of meshes and lines.
See also
ovito.modifiers.AffineTransformationModifier
(Python API)