Source code for pyiron_atomistics.atomistics.structure.factories.aimsgb
# coding: utf-8
# Copyright (c) Max-Planck-Institut für Eisenforschung GmbH - Computational Materials Design (CM) Department
# Distributed under the terms of "New BSD License", see the LICENSE file.
from structuretoolkit.build import get_grainboundary_info, grainboundary
from pyiron_atomistics.atomistics.structure.atoms import ase_to_pyiron
__author__ = "Ujjal Saikia"
__copyright__ = (
"Copyright 2021, Max-Planck-Institut für Eisenforschung GmbH - "
"Computational Materials Design (CM) Department"
)
__version__ = "1.0"
__maintainer__ = "Liam Huber"
__email__ = "huber@mpie.de"
__status__ = "production"
__date__ = "Feb 26, 2021"
[docs]
class AimsgbFactory:
[docs]
@staticmethod
def info(axis, max_sigma):
"""
Provides a list of possible GB structures for a given rotational axis and upto the given maximum sigma value.
Args:
axis : Rotational axis for the GB you want to construct (for example, axis=[1,0,0])
max_sigma (int) : The maximum value of sigma upto which you want to consider for your
GB (for example, sigma=5)
Returns:
A list of possible GB structures in the format:
{sigma value: {'theta': [theta value],
'plane': the GB planes")
'rot_matrix': array([the rotational matrix]),
'csl': [array([the csl matrix])]}}
To construct the grain boundary select a GB plane and sigma value from the list and pass it to the
GBBuilder.gb_build() function along with the rotational axis and initial bulk structure.
"""
return get_grainboundary_info(axis=axis, max_sigma=max_sigma)
[docs]
@staticmethod
def build(
axis,
sigma,
plane,
initial_struct,
to_primitive=False,
delete_layer="0b0t0b0t",
add_if_dist=0.0,
uc_a=1,
uc_b=1,
):
"""
Generate a grain boundary structure based on the aimsgb.GrainBoundary module.
Args:
axis : Rotational axis for the GB you want to construct (for example, axis=[1,0,0])
sigma (int) : The sigma value of the GB you want to construct (for example, sigma=5)
plane: The grain boundary plane of the GB you want to construct (for example, plane=[2,1,0])
initial_struct : Initial bulk structure from which you want to construct the GB (a pyiron
structure object).
delete_layer : To delete layers of the GB. For example, delete_layer='1b0t1b0t'. The first
4 characters is for first grain and the other 4 is for second grain. b means
bottom layer and t means top layer. Integer represents the number of layers
to be deleted. The first t and second b from the left hand side represents
the layers at the GB interface. Default value is delete_layer='0b0t0b0t', which
means no deletion of layers.
add_if_dist : If you want to add extra interface distance, you can specify add_if_dist.
Default value is add_if_dist=0.0
to_primitive : To generate primitive or non-primitive GB structure. Default value is
to_primitive=False
uc_a (int): Number of unit cell of grain A. Default to 1.
uc_b (int): Number of unit cell of grain B. Default to 1.
Returns:
:class:`.Atoms`: final grain boundary structure
"""
return ase_to_pyiron(
grainboundary(
axis=axis,
sigma=sigma,
plane=plane,
initial_struct=initial_struct,
to_primitive=to_primitive,
delete_layer=delete_layer,
add_if_dist=add_if_dist,
uc_a=uc_a,
uc_b=uc_b,
)
)