About kwantSpectrum
===================
kwantSpectrum is an extension to `Kwant `__ that
adaptively analyzes band structures of infinite quasi-1d systems. The
bandstructure is approximated to an arbitrary precision by piecewise cubic
polynomials. Functionality to deal with special points, intervals, and the
periodic nature of the spectrum is provided.
kwantSpectrum is distributed under the `2-clause BSD license `_
Website: https://kwant-project.org/extensions/kwantspectrum
Source code: https://gitlab.kwant-project.org/kwant/kwantspectrum
Conda package: https://github.com/conda-forge/kwantspectrum-feedstock
Installation
############
kwantSpectrum packages are hosted on PyPI and conda.
The installation should work GNU/Linux system as Debian and Ubuntu,
as well as on MacOS and Windows.
**PyPI**::
python3 -m pip install --user kwantspectrum
**conda**::
conda install -c conda-forge kwantspectrum
Installation from source
^^^^^^^^^^^^^^^^^^^^^^^^
kwantSpectrum can be installed directly from the source code repository::
python3 -m pip install --user git+https://gitlab.kwant-project.org/kwant/kwantspectrum.git
For development, kwantSpectrum can be cloned from the official repository with::
git clone https://gitlab.kwant-project.org/kwant/kwantspectrum.git
The requirements listed below must be installed by hand.
Build requirements
------------------
kwantSpectrum has following non-Python dependency:
- `Kwant `__
Kwant can be installed with the following command::
sudo apt-add-repository -s ppa:kwant-project/ppa
sudo apt-get update
sudo apt-get install python3-kwant
kwantSpectrum requires at least Python 3.5. The following packages must
be installed to build kwantSpectrum:
- `NumPy `_
- `SciPy `_
The packages can be installed by the standard *pip* command::
python3 -m pip install --user numpy scipy
Testing requirements
--------------------
The kwantSpectrum test suite requires the following Python packages:
- `pytest `_
- `pytest-cov `_
- `pytest-flake8 `_
The packages can be installed by the standard *pip* command::
python3 -m pip install --user pytest pytest-cov pytest-flake8
Documentation requirements
--------------------------
Building the documentation requires the following Python packages:
- `matplotlib `_
- `sphinx `_
- `jupyter-sphinx `_
The packages can be installed by the standard *pip* command::
python3 -m pip install --user matplotlib sphinx jupyter-sphinx
Test suite
----------
Unittests can be run directly in the local source repository from the command line::
pytest
Building the documentation
--------------------------
The documentation can be build directly in the ``/doc`` folder of the
local source repository from the command line::
make html
The generated html documentation can be browsed
by opening the file ``doc/build/html/index.html`` with a web browser.
Documentation
#############
Full documentation including a tutorial:
- https://kwant-project.org/extensions/kwantspectrum
Communication
#############
The kwant-discuss mailing list is the main communication channel for
questions and discussions around kwantSpectrum. Searching and using the mailing list
is explained in section
`mailing list `_.
- Mailing list: kwant-discuss@kwant-project.org
In addition, the authors can be reached by email, see below.
Contributing
############
Contributions and feedback are always welcome.
Report bugs and follow development through the project repository.
Authors can be reached by email
or a merge request may be opened on the project's website.
Please make sure that the test suite runs without errors before opening
a new merge request.
License
#######
kwantSpectrum is distributed under BSD license, see the file ``LICENSE.rst``
in the project repository.
Authors
#######
The principle developer of kwantSpectrum is:
* Thomas Kloss (CEA Grenoble), kloss@itp.uni-frankfurt.de
Contributors to the project are:
* Christoph Groth (CEA Grenoble)
* Xavier Waintal (CEA Grenoble)
* Benoît Rossignol (CEA Grenoble)
* Bas Nijholt (Microsoft)
(CEA = Commissariat à l'énergie atomique et aux énergies alternatives)