Skip to main content

Tight-binding models (interface to NEGF calculator TBtrans) and generic DFT output manipulation

Project description

Documentation of sisl may be found here:

# sisl #

[![Build Status](](
[![DOI for citation](](
[![License: LGPL v3](](
[![Join the chat at](](
<!--- [![Documentation on RTD](]( -->
[![Install sisl using PyPI](](
[![Install sisl using conda](](
[![Checkout sisl code coverage](](
[![sisl Codacy](](;utm_medium=referral&amp;utm_content=zerothi/sisl&amp;utm_campaign=Badge_Grade)
[![Donate money to support development of sisl](](

The [API documentation][sisl-api] can be found [here][sisl-api].

The sisl toolbox provides a simple API for manipulating, constructing and creating tight-binding matrices
in a standard and uniform way.
Secondly, it provides easy interfaces for creating and calculating band-structures of
simple tight-binding models as well as interfacing to more advanced DFT utilities.

sisl may also be used together with the [ASE][ase] environment.

sisl provides an interface to [TBtrans][tbtrans] and enables the calculation of
transport using the non-equilibrium Green function method and easily allows calculation of tight-binding
systems of millions of atoms.

## Downloading and installation ##

Installing sisl using PyPi or Conda is the easiest:

pip install sisl
# or
conda install -c zerothi sisl

If performing a manual installation, these packages are required:

- __six__
- __numpy__
- __scipy__
- __netCDF4__, this module is only required if you need interface to construct
the transport tight-binding model for `TBtrans`
- __setuptools__
- A fortran compiler

Subsequently manual installation may be done using this command:

python install --prefix=<prefix>

### Testing installation ###

After installation it may be a good idea to check that the tests shipped with sisl pass.
To do this the `pytest` package is necessary. Then run

pytest --pyargs sisl

which will run the shipped sisl test-suite.

## Usage ##

If used to produce scientific contributions, please use this [DOI][doi] for citation. It is recommend to specify the version of sisl in combination of this citation:

author = {Papior, Nick R.},
title = {sisl: v<fill-version>},
doi = {10.5281/zenodo.597181},
url = {}

### Scripts ###

sisl contain a utility to easily convert geometries from existing files
to other formats. After installing the executable `sgeom` is available which
enables the conversion between all formats accessible as `Sile` objects.

To convert a SIESTA FDF file to `xyz` _and_ an `XV` file one does

sgeom siesta.fdf geom.XV

Try `sgeom -h` for additional features such as repeating the structure.

### Geometry manipulation ###

sisl contain a class for manipulating geometries in a consistent and easy
way. Without using any other feature this enables you to easily create and
manipulate structures in a consistent manner.

For instance to create a huge graphene flake

sq3h = 3.**.5 * 0.5
sc = SuperCell(np.array([[1.5, sq3h, 0.],
[1.5,-sq3h, 0.],
[ 0., 0., 10.]],np.float64) * 1.42,
gr = Geometry(np.array([[ 0., 0., 0.],
[ 1., 0., 0.]],np.float64) * 1.42,
atom=Atom(Z=6, R=1.42), sc=sc)
huge = gr.tile(100, axis=0).tile(100, axis=1)

Which results in a 20,000 atom big graphene flake.

Several basic geometries are intrinsically available

from sisl.geom import *

# Graphene basic unit-cell
g = graphene()
# SC crystal structure
g = sc(<lattice constant>, <Atom>)
# BCC crystal structure
g = bcc(<lattice constant>, <Atom>)
# FCC crystal structure
g = fcc(<lattice constant>, <Atom>)
# HCP crystal structure
g = hcp(<lattice constant>, <Atom>)

The `Graphene`, `BCC`, `FCC` and `HCP` structures can be created in
an orthogonal unit-cell by adding the flag `orthogonal=True` in the call:

g = graphene(orthogonal=True)

#### IO-manipulation ####

sisl employs a variety of IO interfaces for managing geometries.

The hard-coded file formats are:

1. ___xyz___, standard coordinate format
Note that the the _xyz_ file format does not _per see_ contain the cell size.
The `XYZSile` writes the cell information in the `xyz` file comment section (2nd line). Hence if the file was written with sisl you retain the cell information.
2. ___gout___, reads geometries from GULP output
3. ___nc___, reads/writes NetCDF4 files created by SIESTA
4. ___TBT.nc___/___PHT.nc___, reads NetCDF4 files created by TBtrans/PHtrans
5. ___tb___, intrinsic file format for geometry/tight-binding models
6. ___fdf___, SIESTA native format
7. ___XV___, SIESTA coordinate format with velocities
8. ___POSCAR___/___CONTCAR___, VASP coordinate format
9. ___ASCII___, BigDFT coordinate format
10. ___win___, Wannier90 Hamiltonian and Wannier centres
11. ___xsf___, XCrySDen file format
12. ScaleUP file formats

All text files can also be read from their gzipped file formats with transparency.

All file formats in sisl are called a _Sile_ (sisl file). This small difference
prohibits name clashes with other implementations.

To read geometries from content you may do

import sisl
geom ='')

which will read the geometry in `` and return a `Geometry` object.

If you want to read several different objects from a single file you should
use the specific `get_sile` routine to retrieve the `Sile` object:

import sisl
fxyz = sisl.get_sile('')

which returns an `XYZSile` file object that enables reading the geometry in
``. Subsequently you may read the geometry and obtain a geometry object

geom = fxyz.read_geometry()

The above two methods are equivalent.

Even though these are hard coded you can easily extend your own file format

sisl.add_sile(<file ending>, <SileObject>)

for instance the `XYZSile` is hooked using:

sisl.add_sile('xyz', XYZSile, case=False)

which means that `sisl.get_sile` understands files `*.xyz` and `*.XYZ` files as
an `XYZSile` object. You can put whatever file-endings here and classes to retain API
compatibility. See the `` package for more information. Note that a call to
`add_sile` with an already existing file ending results in overwriting the initial
meaning of that file object.

__NOTE__: if you know the file is in _xyz_ file format but the ending is erroneous, you can force the `XYZSile` by instantiating using that class<filename>)

which disregards the ending check.

### Tight-binding ###

To create a tight-binding model you _extend_ a geometry to a `Hamiltonian` class which
contains the required sparse pattern.

To create the nearest neighbour tight-binding model for graphene you simply do

# Create nearest-neighbour tight-binding
# graphene lattice constant 1.42
R = ( 0.1 , 1.5 )

# Ensure that graphene has supercell connections[3, 3, 1])
tb = Hamiltonian(gr)
for ia in tb.geom:
idx_a = tb.close(ia, R=R)
tb[ia,idx_a[0]] = 0. # on-site
tb[ia,idx_a[1]] = -2.7 # nearest neighbour

at this point you have the tight-binding model for graphene and you can easily create
the Hamiltonian using this construct:

Hk = tb.Hk(k=[0., 0.5, 0])

which returns the Hamiltonian in the `scipy.sparse.csr_matrix`
format. To calculate the dispersion you diagonalize and plot the eigenvalues

import matplotlib.pyplot as plt
klist = ... # dispersion curve
eigs = np.empty([len(klist),])
for ik, k in enumerate(klist):
eigs[ik,:] = tb.eigh(k, eigvals_only=True)
# Or equivalently:
# Hk = tb.Hk(k)
# eigs[ik,:] = sli.eigh(Hk.todense(), eigvals_only=True)
for i in range(

Very large tight-binding models are notoriously slow to create, however, sisl
implement a much faster method to loop over huge geometries

for ias, idxs in tb.geom.iter_block(iR = 10):
for ia in ias:
idx_a = tb.geom.close(ia, R, idx = idxs)
tb[ia,idx_a[0]] = 0.
tb[ia,idx_a[1]] = -2.7

which accomplishes the same thing, but at much faster execution. `iR` should be a
number such that `tb.geom.close(<any index>,R = tb.geom.maxR() * iR)` is approximately
1,000 atoms.

The above example is for the default orthogonal Hamiltonian. However, sisl is
not limited to orthogonal basis functions. To construct the same example using
explicit overlap matrix the following procedure is necessary:

# Create nearest-neighbour tight-binding
# graphene lattice constant 1.42
R = ( 0.1 , 1.5 )

tb = Hamiltonian(gr, orthogonal=False)
for ia in tb.geom:
idx_a = tb.close(ia, R)
tb.H[ia,idx_a[0]] = 0.
tb.S[ia,idx_a[0]] = 1.
tb.H[ia,idx_a[1]] = 0. # still orthogonal (fake overlap matrix)
tb.S[ia,idx_a[1]] = -2.7
Hk = tb.Hk(k=[0., 0.5, 0])
Sk = tb.Sk(k=[0., 0.5, 0])
eigs = sli.eigh(Hk.todense(), Sk.todense(), eigvals_only=True)

## Contributions, issues and bugs ##

I would advice any users to contribute as much feedback and/or PRs to further
maintain and expand this library.

Please do not hesitate to contribute!

If you find any bugs please form a [bug report/issue][issue].

If you have a fix please consider adding a [pull request][pr].

## License ##

The sisl license is [LGPL][lgpl], please see the LICENSE file.

Links to external and internal sites.

Local variables for emacs to turn on flyspell-mode
% Local Variables:
% mode: flyspell
% tab-width: 4
% indent-tabs-mode: nil
% End:

Project details

Release history Release notifications

This version
History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


History Node


Download files

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

Filename, size & hash SHA256 hash help File type Python version Upload date
sisl-0.9.2.tar.gz (235.9 kB) Copy SHA256 hash SHA256 Source None Oct 25, 2017

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging CloudAMQP CloudAMQP RabbitMQ AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page