Skip to main content

A library for reading/writting Hamiltonian with localized basis set.

Project description

HamiltonIO

A library for reading and analyzing Hamiltonian files from various DFT codes (ABACUS, SIESTA, EPW/Quantum ESPRESSO, Wannier90).

Features

  • Multi-code support: ABACUS, SIESTA, EPW, Wannier90
  • Spin configurations: Non-polarized, collinear, non-collinear, spin-orbit coupling
  • Real and k-space analysis: Band structures, DOS, Hamiltonian decomposition
  • Command-line tools: Easy-to-use CLI for common analysis tasks
  • Python API: Full programmatic access for custom workflows

Installation

pip install hamiltonIO

Or install from source:

git clone https://github.com/mailhexu/HamiltonIO.git
cd HamiltonIO
pip install .

Quick Start

Command Line Tools

HamiltonIO provides CLI tools for quick analysis:

# Convert EPW files to NetCDF
hamiltonio-epw epw_to_nc --path ./data --prefix material --output epmat.nc

# Analyze ABACUS intra-atomic Hamiltonians
hamiltonio-abacus intra-atomic --outpath OUT.ABACUS

# Analyze SIESTA intra-atomic Hamiltonians  
hamiltonio-siesta intra-atomic siesta.fdf

For detailed CLI usage, see CLI Documentation.

Python Library

# ABACUS
from HamiltonIO.abacus import AbacusParser
parser = AbacusParser(outpath="./OUT.material/")
model = parser.get_models()
evals, evecs = model.solve([0, 0, 0])  # Solve at Gamma point

# SIESTA
from HamiltonIO.siesta import SiestaHam
model = SiestaHam("siesta.fdf")
evals, evecs = model.solve([0, 0, 0])

# EPW
from HamiltonIO.epw import Epmat
epmat = Epmat()
epmat.read(path="./", prefix="material", epmat_ncfile="epmat.nc")

# Wannier90
from HamiltonIO.wannier import Wannier90Hamiltonian
model = Wannier90Hamiltonian("wannier90_hr.dat")
evals, evecs = model.solve([0, 0, 0])

Documentation

Detailed documentation for each interface:

Key Features by Code

ABACUS

  • Automatic spin detection (non-polarized, collinear, noncollinear)
  • Binary and text CSR format support
  • Split-SOC analysis via finite difference
  • Intra-atomic Hamiltonian decomposition

SIESTA

  • NetCDF and HSX format support
  • Split-SOC from native SIESTA output
  • Collinear and non-collinear calculations
  • Integration with sisl library

EPW (Quantum ESPRESSO)

  • Binary to NetCDF conversion
  • Wigner-Seitz grid handling
  • Electron-phonon coupling matrices
  • Crystal structure from EPW data

Wannier90

  • HR format parsing
  • Distance-resolved hopping analysis
  • Band interpolation
  • Orbital projections

Common Workflows

Intra-Atomic Analysis

# ABACUS: Analyze atoms 0, 1, 2 with full matrices
hamiltonio-abacus intra-atomic --outpath OUT.Fe \
    --atoms 0,1,2 --show-matrix -o analysis.txt

# SIESTA: Split-SOC analysis
hamiltonio-siesta intra-atomic siesta.fdf \
    --split-soc --show-matrix -o soc_analysis.txt

File Conversion

# EPW: Convert binary to NetCDF (faster I/O)
hamiltonio-epw epw_to_nc --path ./epw_data \
    --prefix material --output epmat.nc

Band Structure

import numpy as np
from HamiltonIO.abacus import AbacusParser

# Load model
parser = AbacusParser(outpath="./OUT.material/")
model = parser.get_models()

# High-symmetry path
k_path = np.array([
    [0.0, 0.0, 0.0],  # Gamma
    [0.5, 0.0, 0.0],  # X
    [0.5, 0.5, 0.0],  # M
])

# Calculate bands
bands = []
for k in k_path:
    evals, _ = model.solve(k)
    bands.append(evals)

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the terms specified in the LICENSE file.

Citation

If you use HamiltonIO in your research, please cite:

@software{hamiltonIO,
  author = {Xu, He},
  title = {HamiltonIO: A Library for DFT Hamiltonian I/O},
  url = {https://github.com/mailhexu/HamiltonIO},
  year = {2024}
}

Contact

For questions, bug reports, or feature requests:

Acknowledgments

HamiltonIO builds upon and integrates with:

  • sisl - SIESTA interface
  • ASE - Atomic simulation environment
  • NumPy - Numerical computing

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hamiltonio-0.3.6.tar.gz (120.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hamiltonio-0.3.6-py3-none-any.whl (131.6 kB view details)

Uploaded Python 3

File details

Details for the file hamiltonio-0.3.6.tar.gz.

File metadata

  • Download URL: hamiltonio-0.3.6.tar.gz
  • Upload date:
  • Size: 120.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.11

File hashes

Hashes for hamiltonio-0.3.6.tar.gz
Algorithm Hash digest
SHA256 c3314a3960b78dc64b99f31c4aebe28fa2b628d43419c524df63f11314217c84
MD5 11b0eae0dbe85239819109b4e3a8c2e9
BLAKE2b-256 c78550039216d8caf30bb37c2069d0da47469488b9af6ac2165800b1fd7483fd

See more details on using hashes here.

File details

Details for the file hamiltonio-0.3.6-py3-none-any.whl.

File metadata

  • Download URL: hamiltonio-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 131.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.11

File hashes

Hashes for hamiltonio-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 8a8f378949754565c29e553ae80d5b4eb40473fcb09b887f4e4285d3e3057ee0
MD5 5da3d3173436fd6b745723d432f17418
BLAKE2b-256 62587622b5d4a1b4c166aa72d5b425a9abc94a7d4c875ec365db0ecde9e93200

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page