4.9. SIC calculationsΒΆ

This example is about self-interaction correction (SIC) calculations using different sets of orbitals.


from eminus import Atoms, SCF
from eminus.energies import get_Esic
from eminus.orbitals import FLO

Start with a DFT calculation for neon including a SIC calculation

atoms = Atoms("Be", [0, 0, 0], ecut=10)
scf = SCF(atoms, sic=True)
scf.run(cgform=3)

Generate Kohn-Sham and Fermi-Loewdin orbitals

flo = FLO(scf)

Print the self-interaction energy from the SCF object

print(f"\nKSO-SIC energy = {scf.energies.Esic} Eh")

The quality of the FLO-SIC energy will vary with the FOD guess

The one-shot FLO-SIC energy should be lower than the KSO-SIC one

esic = get_Esic(scf, atoms.J(flo))
print(f"FLO-SIC energy = {esic} Eh")

The SIC energy will also be saved in the SCF object

print(f"\nAll energies:\n{scf.energies}")

Downloads: 09_sic_calculations.py