Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Parser for waves.sxb files from SPHInX #1224

Merged
merged 38 commits into from
Jan 25, 2024
Merged
Changes from 2 commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
9464eea
Parser for waves.sxb files from Sphimnx
skatnagallu Nov 29, 2023
e755fb6
Format black
pyiron-runner Nov 29, 2023
c41a869
added missing modules
skatnagallu Nov 29, 2023
ceb0c2f
Update pyiron_atomistics/sphinx/output_parser.py
skatnagallu Nov 29, 2023
d439265
Changes according to sam's suggestions. Created properties
skatnagallu Nov 29, 2023
59f544e
SphinxWavesParser now uses a file name, and removed the _check_loaded…
skatnagallu Nov 29, 2023
71fac6c
added mesh as property
skatnagallu Nov 29, 2023
27cf39c
removed if cwd=none:
skatnagallu Nov 29, 2023
752ccdd
If the file_name is absolute path, cwd is ignored
skatnagallu Nov 29, 2023
293aa10
small syntax changes
skatnagallu Nov 29, 2023
4d075a7
Update pyiron_atomistics/sphinx/output_parser.py
skatnagallu Nov 29, 2023
a61eabf
Removed load function. Defined all variables in __init__()
skatnagallu Nov 29, 2023
cdb9a20
bug fix for _n_gk and implemented numpy version for _fillin()
skatnagallu Nov 29, 2023
a849b98
removed the _fillin static method.
skatnagallu Nov 29, 2023
c981207
removed numba import
skatnagallu Nov 29, 2023
0f62517
Format black
pyiron-runner Nov 29, 2023
9ecb56f
make a file for sphinx parsers
samwaseda Nov 30, 2023
bb32971
update path
samwaseda Nov 30, 2023
2355069
update path
samwaseda Nov 30, 2023
d6129dd
removed _fft_idx property and changed get_psi_rec() function
skatnagallu Nov 30, 2023
c98d101
Merge branch 'spx_output_parser_wavefunction' of https://github.com/p…
skatnagallu Nov 30, 2023
251b066
Merge branch 'main' into spx_output_parser_wavefunction
samwaseda Nov 30, 2023
63bbdef
Changed back to _fft_idx, and made it cached_property
skatnagallu Dec 1, 2023
4df58f0
Merge pull request #1236 from pyiron/main
jan-janssen Dec 2, 2023
c526ddf
Changed some properties to cached properties. removed _eps variable. …
skatnagallu Dec 6, 2023
6e0d5cf
Update pyiron_atomistics/sphinx/output_parser.py
samwaseda Dec 6, 2023
1090aff
Restore a line that I deleted accidentally.
samwaseda Dec 6, 2023
73894b1
add the doc string
skatnagallu Dec 6, 2023
48dd3ad
Translate indices to pythonic way.
skatnagallu Dec 6, 2023
a2e2b13
Modiefied get_psi_rec() to have an option to get compact wavefunctions
skatnagallu Dec 6, 2023
2303421
Update pyiron_atomistics/sphinx/output_parser.py
skatnagallu Dec 7, 2023
e73c0e9
Merge pull request #1250 from pyiron/spx_add_tests
skatnagallu Dec 8, 2023
f60648c
added waves.sxb for sphinx_test_waves
skatnagallu Dec 11, 2023
9963e4f
added a test for SphinxWavesReader
skatnagallu Dec 15, 2023
82e4198
added a proper waves.sxb file for test
skatnagallu Dec 18, 2023
d7ac87a
Format black
pyiron-runner Jan 23, 2024
adc140a
take absolute value before taking the mean for test_waves()
skatnagallu Jan 23, 2024
f0c59e7
Update tests/sphinx/test_parsers.py
samwaseda Jan 24, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
86 changes: 86 additions & 0 deletions pyiron_atomistics/sphinx/output_parser.py
Original file line number Diff line number Diff line change
Expand Up @@ -386,3 +386,89 @@ def get_convergence(self):
def get_fermi(self):
pattern = r"Fermi energy:\s+(\d+\.\d+)\s+eV"
return np.array(re.findall(pattern, self.log_main)).astype(float)


class SphinxWavesParser:
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved
"""Class to read SPHInX waves.sxb files (HDF5 format)

Initialize with waves.sxb filename, or use load ()

"""

def __init__(self, fname=None):
if fname is not None:
self.load(fname)

def load(self, filename):
"""Load a waves.sxb file (HDF5 format)

filename: file name
"""
self.wfile = h5py.File(filename)
self._eps = None
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved
self._read()

# Internal: check that wfile is set
def _check_loaded(self):
if not isinstance(self.wfile, h5py.File):
raise "No waves file loaded"
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved

def _read(self):
self._check_loaded()
# load various dimensions
self.mesh = self.wfile["meshDim"][:]
self.Nx, self.Ny, self.Nz = self.mesh
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved

self.n_states = self.wfile["nPerK"][0]
self.n_spin = self.wfile["nSpin"].shape[0]
self.k_weights = self.wfile["kWeights"][:]
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved

# load the fft_idx to map from condensed psi to FFT mesh
# (different mapping per k)
self._fft_idx = []
self._n_gk = self.wfile["nGk"][:]
off = 0
for ngk in self._n_gk:
self._fft_idx.append(self.wfile["fftIdx"][off : off + ngk])
off += ngk

self.k_vec = self.wfile["kVec"][:]
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved

@property
def eps(self):
"""All eigenvalues (in Hartree) as (nk,n_states) block"""
if self._eps is None:
self._check_loaded()
self._eps = self.wfile["eps"][:].reshape(-1, self.n_spin, self.n_states)
return self._eps.T # change

# Define as separate method and speed it up with numba
@staticmethod
@numba.jit
def _fillin(res, psire, psiim, fft_idx):
"""Distributes condensed psi (real, imag) on full FFT mesh"""
rflat = res.flat
for ig in range(fft_idx.shape[0]):
rflat[fft_idx[ig]] = complex(psire[ig], psiim[ig])

def get_psi_rec(self, i, ispin, ik):
"""Loads a single wavefunction on full FFT mesh"""
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved
if i < 0 or i >= self.n_states:
raise IndexError(f"i={i} fails 0 <= i < n_states={self.n_states}")
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved
if ispin < 0 or ispin >= self.n_spin:
raise IndexError(f"ispin={ispin} fails 0 <= ispin < n_spin={self.n_spin}")
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved
if ik < 0 or ik >= self.nk:
raise IndexError(f"ik={ik} fails 0 <= ik < nk={self.nk}")
skatnagallu marked this conversation as resolved.
Show resolved Hide resolved

res = np.zeros(shape=self.mesh, dtype=np.complex128)
off = self._n_gk[ik] * (i + ispin * self.n_states)
psire = self.wfile[f"psi-{ik+1}.re"][off : off + self._n_gk[ik]]
psiim = self.wfile[f"psi-{ik+1}.im"][off : off + self._n_gk[ik]]
samwaseda marked this conversation as resolved.
Show resolved Hide resolved
self._fillin(res, psire, psiim, self._fft_idx[ik])
return res

@property
def nk(self):
"""Number of k-points"""
self._check_loaded()
return self.k_weights.shape[0]
Loading