pymatgen.analysis.interfaces package
Module that implements various algorithms related to interface construction and analysis.
Submodules
pymatgen.analysis.interfaces.coherent_interfaces module
This module provides classes to store, generate, and manipulate material interfaces.
- class CoherentInterfaceBuilder(substrate_structure: Structure, film_structure: Structure, film_miller: Tuple3Ints, substrate_miller: Tuple3Ints, zslgen: ZSLGenerator | None = None, termination_ftol: float = 0.25, label_index: bool = False, filter_out_sym_slabs: bool = True)[source]
Bases:
object
This class constructs the coherent interfaces between two crystalline slabs Coherency is defined by matching lattices not sub-planes.
- Parameters:
substrate_structure (Structure) – substrate structure
film_structure (Structure) – film structure
film_miller (tuple[int, int, int]) – miller index for the film layer
substrate_miller (tuple[int, int, int]) – miller index for the substrate layer
zslgen (ZSLGenerator | None) – BiDirectionalZSL if you want custom lattice matching tolerances for coherency.
termination_ftol (float) – tolerance to distinguish different terminating atomic planes.
label_index (bool) – If True add an extra index at the beginning of the termination label.
filter_out_sym_slabs (bool) – If True filter out identical slabs with different terminations. This might need to be set as False to find more non-identical terminations because slab identity separately does not mean combinational identity.
- get_interfaces(termination: tuple[str, str], gap: float = 2.0, vacuum_over_film: float = 20.0, film_thickness: float = 1, substrate_thickness: float = 1, in_layers: bool = True) Iterator[Interface] [source]
Generate interface structures given the film and substrate structure as well as the desired terminations.
- Parameters:
termination (tuple[str, str]) – termination from self.termination list
gap (float, optional) – gap between film and substrate. Defaults to 2.0.
vacuum_over_film (float, optional) – vacuum over the top of the film. Defaults to 20.0.
film_thickness (float, optional) – the film thickness. Defaults to 1.
substrate_thickness (float, optional) – substrate thickness. Defaults to 1.
in_layers (bool, optional) – set the thickness in layer units. Defaults to True.
- Yields:
Iterator[Interface] – interfaces from slabs
pymatgen.analysis.interfaces.substrate_analyzer module
This module provides classes to identify optimal substrates for film growth.
- class SubstrateAnalyzer(film_max_miller=1, substrate_max_miller=1, **kwargs)[source]
Bases:
ZSLGenerator
This class applies a set of search criteria to identify suitable substrates for film growth. It first uses a topological search by Zur and McGill to identify matching super-lattices on various faces of the two materials. Additional criteria can then be used to identify the most suitable substrate. Currently, the only additional criteria is the elastic strain energy of the super-lattices.
Initialize the substrate analyzer.
- Parameters:
zslgen (ZSLGenerator) – Defaults to a ZSLGenerator with standard tolerances, but can be fed one with custom tolerances
film_max_miller (int) – maximum miller index to generate for film surfaces
substrate_max_miller (int) – maximum miller index to generate for substrate surfaces.
- calculate(film: Structure, substrate: Structure, elasticity_tensor=None, film_millers: ArrayLike = None, substrate_millers: ArrayLike = None, ground_state_energy=0, lowest=False)[source]
Find all topological matches for the substrate and calculates elastic strain energy and total energy for the film if elasticity tensor and ground state energy are provided:
- Parameters:
film (Structure) – conventional standard structure for the film
substrate (Structure) – conventional standard structure for the substrate
elasticity_tensor (ElasticTensor) – elasticity tensor for the film in the IEEE orientation
film_millers (array) – film facets to consider in search as defined by miller indices
substrate_millers (array) – substrate facets to consider in search as defined by miller indices
ground_state_energy (float) – ground state energy for the film
lowest (bool) – only consider lowest matching area for each surface
- class SubstrateMatch(film_sl_vectors: list, substrate_sl_vectors: list, film_vectors: list, substrate_vectors: list, film_transformation: list, substrate_transformation: list, film_miller: Tuple3Ints, substrate_miller: Tuple3Ints, strain: Strain, von_mises_strain: float, ground_state_energy: float, elastic_energy: float)[source]
Bases:
ZSLMatch
A substrate match building on the Zur and McGill algorithm. This match class includes the miller planes of the film and substrate the full strain tensor, the Von Mises strain, the ground state energy if provided, and the elastic energy.
pymatgen.analysis.interfaces.zsl module
This module implements the Zur and McGill lattice matching algorithm.
- class ZSLGenerator(max_area_ratio_tol=0.09, max_area=400, max_length_tol=0.03, max_angle_tol=0.01, bidirectional=False)[source]
Bases:
MSONable
This class generate matching interface super lattices based on the methodology of lattice vector matching for heterostructural interfaces proposed by Zur and McGill: Journal of Applied Physics 55 (1984), 378 ; doi: 10.1063/1.333084 The process of generating all possible matching super lattices is: 1.) Reduce the surface lattice vectors and calculate area for the surfaces 2.) Generate all super lattice transformations within a maximum allowed area
limit that give nearly equal area super-lattices for the two surfaces - generate_sl_transformation_sets
- 3.) For each superlattice set:
1.) Reduce super lattice vectors 2.) Check length and angle between film and substrate super lattice
vectors to determine if the super lattices are the nearly same and therefore coincident - get_equiv_transformations.
- Initialize a Zur Super Lattice Generator for a specific film and
substrate.
- Parameters:
max_area_ratio_tol (float) – Max tolerance on ratio of super-lattices to consider equal
max_area (float) – max super lattice area to generate in search
max_length_tol – maximum length tolerance in checking if two vectors are of nearly the same length
max_angle_tol – maximum angle tolerance in checking of two sets of vectors have nearly the same angle between them.
- generate_sl_transformation_sets(film_area: int, substrate_area: int) Iterator[tuple] [source]
Generate transformation sets for film/substrate pair given the area of the unit cell area for the film and substrate. The transformation sets map the film and substrate unit cells to super lattices with a maximum area.
- Parameters:
film_area (int) – the unit cell area for the film
substrate_area (int) – the unit cell area for the substrate
- Yields:
transformation_sets –
- a set of transformation_sets defined as:
1.) the transformation matrices for the film to create a super lattice of area i*film area 2.) the transformation matrices for the substrate to create a super lattice of area j*film area.
- get_equiv_transformations(transformation_sets, film_vectors, substrate_vectors)[source]
Applies the transformation_sets to the film and substrate vectors to generate super-lattices and checks if they matches. Returns all matching vectors sets.
- Parameters:
transformation_sets (array) – an array of transformation sets: each transformation set is an array with the (i,j) indicating the area multiples of the film and substrate it corresponds to, an array with all possible transformations for the film area multiple i and another array for the substrate area multiple j.
film_vectors (array) – film vectors to generate super lattices
substrate_vectors (array) – substrate vectors to generate super lattices
- class ZSLMatch(film_sl_vectors: list, substrate_sl_vectors: list, film_vectors: list, substrate_vectors: list, film_transformation: list, substrate_transformation: list)[source]
Bases:
MSONable
A match from the Zur and McGill Algorithm. The super_lattice vectors are listed as _sl_vectors. These are reduced according to the algorithm in the paper which effectively a rotation in 3D space. Use the match_transformation property to get the appropriate transformation matrix.
- property match_area[source]
The area of the match between the substrate and film super lattice vectors.
- gen_sl_transform_matrices(area_multiple)[source]
Generates the transformation matrices that convert a set of 2D vectors into a super lattice of integer area multiple as proven in Cassels:
Cassels, John William Scott. An introduction to the geometry of numbers. Springer Science & Business Media, 2012.
- Parameters:
area_multiple (int) – integer multiple of unit cell area for super
area (lattice)
- Returns:
transformation matrices to convert unit vectors to super lattice vectors
- Return type:
matrix_list
- is_same_vectors(vec_set1, vec_set2, bidirectional=False, max_length_tol=0.03, max_angle_tol=0.01) bool [source]
Determine if two sets of vectors are the same within length and angle tolerances :param vec_set1: an array of two vectors :type vec_set1: array[array] :param vec_set2: second array of two vectors. :type vec_set2: array[array]
- reduce_vectors(a, b)[source]
Generate independent and unique basis vectors based on the methodology of Zur and McGill.