4.7. FOD and FLO generation¶
This example is about the generation of Fermi orbital descriptors (FODs).
Afterward, Fermi-Löwdin orbitals (FLOs) can be generated as well.
from eminus import Atoms, read, SCF
from eminus.dft import get_psi
from eminus.extras import get_fods, remove_core_fods
from eminus.localizer import get_FLO
Start by with a DFT calculation for methane
atom, pos = read("CH4.xyz")
atoms = Atoms(atom, pos, ecut=10, center=True)
scf = SCF(atoms)
scf.run()
Calculate all FODs
fods_all = get_fods(atoms)
print(f"\nAll FODs:\n{fods_all}")
Remove core FODs, since the calculation uses a GTH pseudopotential
fods = remove_core_fods(atoms, fods_all)
print(f"\nCore FODs:\n{fods}")
The quality from the FOD guess can vary, but you can use these as a decent guess
# import numpy as np
# fods = [np.array([[10.71617803, 10.75510917, 10.73689087],
# [10.82635834, 9.25127336, 9.25068483],
# [ 9.24857483, 10.79169744, 9.24052496],
# [ 9.25441172, 9.25005662, 10.82402898]]),
# np.array([])]
Write the FODs to an XYZ file to view them
atoms.write("CH4_fods.xyz", fods)
Generate the Kohn-Sham orbitals
psi = get_psi(scf, scf.W)
Calculate the FLOs
FLO = get_FLO(atoms, psi, fods)
Write all FLOs to CUBE files
print("\nWrite cube files:")
for i in range(atoms.occ.Nstate):
print(f"{i + 1} of {atoms.occ.Nstate}")
atoms.write(f"CH4_FLO_{i + 1}.cube", FLO[0][0, :, i])
All of the functionality above can be achieved with the following workflow function
# from eminus.orbitals import FLO
# FLO = FLO(scf, write_cubes=True)
Downloads: 07_fod_extra.py
CH4.xyz