mirror of
https://github.com/triqs/dft_tools
synced 2025-01-03 18:16:03 +01:00
This fix in the Wannier90Converter makes the function find_rot_mat
safer to use in case there are errors in finding the correct mapping. The converter will now abort if the agreement in mapping is below a user-definable threshold.
This commit is contained in:
parent
b8b1b6b77d
commit
e06653d7bb
@ -61,7 +61,8 @@ class Wannier90Converter(ConverterTools):
|
||||
|
||||
def __init__(self, seedname, hdf_filename=None, dft_subgrp='dft_input',
|
||||
symmcorr_subgrp='dft_symmcorr_input', misc_subgrp='dft_misc_input',
|
||||
repacking=False, rot_mat_type='hloc_diag', bloch_basis=False, add_lambda=None):
|
||||
repacking=False, rot_mat_type='hloc_diag', bloch_basis=False, add_lambda=None,
|
||||
w90zero=2.e-6):
|
||||
"""
|
||||
Initialise the class.
|
||||
|
||||
@ -86,6 +87,8 @@ class Wannier90Converter(ConverterTools):
|
||||
Should the Hamiltonian be written in Bloch rather than Wannier basis?
|
||||
add_lambda : list of floats, optional
|
||||
add local spin-orbit term
|
||||
w90zero : float, optional
|
||||
threshold on symmetry checks of Hamiltonian and rot_mat
|
||||
"""
|
||||
|
||||
self._name = "Wannier90Converter"
|
||||
@ -104,7 +107,7 @@ class Wannier90Converter(ConverterTools):
|
||||
self.fortran_to_replace = {'D': 'E'}
|
||||
# threshold below which matrix elements from wannier90 should be
|
||||
# considered equal
|
||||
self._w90zero = 2.e-6
|
||||
self._w90zero = w90zero
|
||||
self.rot_mat_type = rot_mat_type
|
||||
self.bloch_basis = bloch_basis
|
||||
self.add_lambda = add_lambda
|
||||
@ -821,10 +824,10 @@ class Wannier90Converter(ConverterTools):
|
||||
# equivalent shells
|
||||
if not numpy.allclose(eigval_lst[ish], eigval_lst[sh_map[ish]],
|
||||
atol=self._w90zero, rtol=0):
|
||||
mpi.report(
|
||||
"ERROR: eigenvalue mismatch between equivalent shells! %d" % ish)
|
||||
mpi.report(f'ERROR: eigenvalue mismatch between equivalent shells! {ish:d}')
|
||||
eigval_diff = eigval_lst[ish] - eigval_lst[sh_map[ish]]
|
||||
mpi.report("Eigenvalue difference: " + format(eigval_diff))
|
||||
mpi.report(f'Eigenvalue difference {eigval_diff}, but threshold set to {self._w90zero:.1e}.')
|
||||
mpi.report('Consider lowering threshold if you are certain the mapping is correct.')
|
||||
succeeded = False
|
||||
|
||||
# check that rotation matrices are unitary
|
||||
@ -833,7 +836,7 @@ class Wannier90Converter(ConverterTools):
|
||||
tmp_mat = numpy.dot(rot_mat[ish],rot_mat[ish].conjugate().transpose())
|
||||
if not numpy.allclose(tmp_mat, numpy.identity(nw),
|
||||
atol=self._w90zero, rtol=0):
|
||||
mpi.report("ERROR: rot_mat for shell %d is not unitary!"%(ish))
|
||||
mpi.report(f'ERROR: rot_mat for shell {ish:d} is not unitary!')
|
||||
succeeded = False
|
||||
|
||||
# check that rotation matrices map equivalent H(0) blocks as they should
|
||||
@ -847,9 +850,12 @@ class Wannier90Converter(ConverterTools):
|
||||
numpy.dot(ham0_lst[ish],tmp_mat))
|
||||
if not numpy.allclose(tmp_mat, ham0_lst[sh_map[ish]],
|
||||
atol=self._w90zero, rtol=0):
|
||||
mpi.report("ERROR: rot_mat does not map H(0) correctly! %d"%(ish))
|
||||
mpi.report(f'ERROR: rot_mat does not map H(0) correctly! {ish:d}')
|
||||
succeeded = False
|
||||
|
||||
# abort in case the rot_mat was not found correctly to avoid the user to ignore ERRORS
|
||||
if not succeeded: mpi.MPI.COMM_WORLD.Abort(1)
|
||||
|
||||
return succeeded, rot_mat
|
||||
|
||||
def kmesh_build(self, msize, mmode=0):
|
||||
|
Loading…
Reference in New Issue
Block a user