A C++ library for symmetry operations and linear interpolation within an irreducible part of the first Brillouin zone. Wrapped for use in python using pybind11.
When provided with the lattice parameters or basis vectors of a real space spacegroup and its Hall symbol or number as determined by, e.g., Spglib
,
brille
can
Constructing and irreducible Brillouin zone polyhedron for a face centered cubic lattice can be accomplished with, e.g.,
import brille
direct_lattice = brille.Direct((4.96, 4.96, 4.96), (90, 90, 90), 'Fd-3m')
brillouin_zone = brille.BrillouinZone(direct_lattice.star)
Interpolating eigenvalues and eigenvectors across a degenerate point could lead to misidentified equivalent modes. Since the eigenvectors are distinguishable at all points away from the high-symmetry directions, a hybrid orthogonal/triangulated grid defined in an irreducible part of the Brillouin zone can be used to avoid mode misidentification.
brille
can construct
Of these options the third is most appropriate for the interpolation of models used in the analysis of inelastic neutron scattering data is the hybrid grid.
A modified version of TetGen is used to create refined tetrahedral meshes in the irreducible portion of the first Brillouin zone.
The modified version is included as part of this repository.
From the root folder of this repository use Python 3 to build and install this library.
python setup.py install
Alternatively, the python module, C++ library, and catch2 based tests can be built directly using cmake
.