The Fermion models supported include Fermi-Hubbard systems and spinless Fermions with nearest-neighbor interactions. The spin models supported include the Heisenberg model, Ising model, and an extended Rydberg Ising model relevant to rydberg atoms.
This project also includes tools for reducing the size of the matrices which must be diagonalized by taking advantage of symmetries of the Hamiltonians. The approach adopted here is described in detail in ed-symmetries.tex and many useful references can be found both here and in bibliography.bib.
git clone https://github.com/ptbrown1729/exact_diag.git
cd exact_diag
pip install .
If you would like to modify the code, then use the -e
option so it is not necessary to reinstall
the package for your changes to take effect
pip install -e .
This file defines a base class for use with different exact diagonalization models. This class defines basic functions such as taking expectation values, calculating partition functions, calculating Green's functions, etc.
This file defines a class for working with Fermion systems, including spinless fermions of Fermi-Hubbard type models. This class inherits from ed_base.py.
This file defines a class for working with spin systems, including Heisenberg, Ising, and Rydberg Ising. This class inherits from ed_base.py
This file implements a class for defining clusters of sites, either using a specific lattice setup or an arbitrary geometry
This file implements symmetry operations and functions for creating projectors for reducing the Hamiltonians using these symmetry operations. This can allow diagonalization of much larger systems.
This file implements cluster generation tools. Combining these clusters with the exact diagonalization code allows an easy implementation of the numerical linked cluster expansion (NLCE)
functions for evaluating properties of a non-interacting Fermi gas, including equation of state, compressibility, spin correlations (for a two component gas), etc. Useful for comparing with Fermi-Hubbard model results.
Some tools for working with Green's functions, and transforming between various representations
This directory contains various examples which make use of the exact diagonalization code
sphinx documentation
describing the exact_diag
project. To build the documentation locally
first ensure sphinx is installed (pip install sphinx
). Then navigate to
this folder and run make html
. Open the html documentation
by double clicking on docs/_build/html/index.html
This directory contains various unittests for comparing exact diagonalization results with published data,
and checking that the symmetry operators work appropriately. To test
the code in ed_geometry.py
, navigate to the unittests
folder and run
python -m unittest geom_unittest.py
This directory contains code that was used run exact diagonalizations scripts on Princeton Physics Feynman cluster using Slurm