2016-07-08 12:04:31 +02:00
|
|
|
.. _structure:
|
|
|
|
|
|
|
|
Structure of :program:`DFTTools`
|
|
|
|
================================
|
2015-03-12 00:01:12 +01:00
|
|
|
|
|
|
|
.. image:: images/structure.png
|
|
|
|
:width: 700
|
|
|
|
:align: center
|
|
|
|
|
2016-07-08 12:04:31 +02:00
|
|
|
The central part of :program:`DFTTools`, which is performing the
|
2015-08-13 11:03:25 +02:00
|
|
|
steps for the DMFT self-consistency cycle, is written following the
|
|
|
|
same philosophy as the :ref:`TRIQS <triqslibs:welcome>` toolbox. At
|
|
|
|
the user level, easy-to-use python modules are provided that allow to
|
2016-07-08 12:04:31 +02:00
|
|
|
write simple and short scripts performing the actual calculation.
|
|
|
|
The usage of those modules is presented in the user guide of this
|
|
|
|
:ref:`documentation`. Before considering the user guide, we suggest
|
|
|
|
to read the following introduction on the general structure of
|
|
|
|
the :program:`DFTTools` package.
|
2015-08-13 11:03:25 +02:00
|
|
|
|
|
|
|
The interface layer
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
Since the input for this DMFT part has to be provided by DMFT
|
|
|
|
calculations, there needs to be another layer that connects the
|
|
|
|
python-based modules with the DFT output. Naturally, this layer
|
|
|
|
depends on the DFT package at hand. At the moment, there is an
|
|
|
|
interface to the Wien2k band structure package, and a very light
|
|
|
|
interface that can be used in a more general setup. Note that this
|
2015-08-13 13:33:18 +02:00
|
|
|
light interface layer **does not** allow full charge self-consistent
|
2015-08-13 11:03:25 +02:00
|
|
|
calculations.
|
|
|
|
|
|
|
|
Wien2k interface
|
|
|
|
""""""""""""""""
|
|
|
|
|
|
|
|
This interface layer consists of two parts. First, the output from Wien2k
|
2016-07-08 12:04:31 +02:00
|
|
|
is taken, and localized Wannier orbitals are constructed. This is done
|
|
|
|
by the FORTRAN program :program:`dmftproj`. The second part consist in
|
2015-08-13 11:03:25 +02:00
|
|
|
the conversion of the :program:`dmftproj` into the hdf5 file
|
|
|
|
format to be used for the DMFT calculation. This step is done by a
|
|
|
|
python routine called :class:`Wien2kConverter`, that reads the text output and
|
|
|
|
creates the hdf5 input file with the necessary ingredients. Quite
|
2016-07-08 12:04:31 +02:00
|
|
|
naturally, :program:`DFTTools` will adopt this converter concept also for future
|
2015-08-13 11:03:25 +02:00
|
|
|
developments for other DFT packages.
|
|
|
|
|
|
|
|
General interface
|
|
|
|
"""""""""""""""""
|
|
|
|
|
2016-07-08 12:04:31 +02:00
|
|
|
In addition to the specialized Wien2k interface, :program:`DFTTools`
|
2015-08-13 11:03:25 +02:00
|
|
|
provides also a very light-weight general interface. It basically
|
|
|
|
consists of a very simple :class:`HkConverter`. As input it requires a
|
2016-07-08 12:04:31 +02:00
|
|
|
Hamiltonian matrix :math:`H_{mn}(\mathbf{k})` written already in
|
|
|
|
localized-orbital indices :math:`m,n`, on a :math:`\mathbf{k}`-point
|
2015-08-13 11:03:25 +02:00
|
|
|
grid covering the Brillouin zone, and just a few other informations
|
2016-07-08 12:04:31 +02:00
|
|
|
like total number of electrons, how many correlated atoms in the unit
|
|
|
|
cell, and so on. It converts this Hamiltonian into a hdf5 format and
|
2015-08-13 11:03:25 +02:00
|
|
|
sets some variables to standard values, such that it can be used with
|
|
|
|
the python modules performing the DMFT calculation. How the
|
2016-07-08 12:04:31 +02:00
|
|
|
Hamiltonian matrix :math:`H_{mn}(\mathbf{k})` is actually calculated,
|
|
|
|
is **not** part of this interface.
|
2015-08-13 11:03:25 +02:00
|
|
|
|
|
|
|
The DMFT calculation
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
As mentioned above, there are a few python routines that allow to
|
|
|
|
perform the multi-band DMFT calculation in the context of real
|
2016-07-08 12:04:31 +02:00
|
|
|
materials. The major part is contained in the module
|
2015-08-13 11:03:25 +02:00
|
|
|
:class:`SumkDFT`. It contains routines to
|
|
|
|
|
2018-09-20 00:32:33 -04:00
|
|
|
* calculate local Green functions
|
2015-08-13 11:03:25 +02:00
|
|
|
* do the upfolding and downfolding from Bloch bands to Wannier
|
|
|
|
orbitals
|
|
|
|
* calculate the double-counting correction
|
|
|
|
* calculate the chemical potential in order to get the electron count right
|
|
|
|
* other things like determining the structure of the local
|
2016-07-08 12:04:31 +02:00
|
|
|
Hamiltonian, rotating from local to global coordinate systems, etc.
|
2015-08-13 11:03:25 +02:00
|
|
|
|
|
|
|
At the user level, all these routines can be used to construct
|
|
|
|
situation- and problem-dependent DMFT calculations in a very efficient
|
|
|
|
way.
|
|
|
|
|
|
|
|
Full charge self consistency
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
Using the Wien2k interface, one can perform full charge
|
|
|
|
self-consistent calculations. :class:`SumkDFT` provides routines to
|
|
|
|
calculate the correlated density matrix and stores it in a format that
|
|
|
|
can be read in by the :program:`lapw2` part of the Wien2k
|
|
|
|
package. Changing a one-shot calculation in a full charge
|
|
|
|
self-consistent one is only a couple of additional lines in the code!
|
|
|
|
|
|
|
|
Post-processing
|
|
|
|
---------------
|
|
|
|
|
2018-09-20 00:32:33 -04:00
|
|
|
The main result of DMFT calculation is the interacting Green function
|
|
|
|
and the self energy. However, one is normally interested in
|
2016-07-08 12:04:31 +02:00
|
|
|
quantities like band structure, density of states, or transport
|
2018-09-20 00:32:33 -04:00
|
|
|
properties. In order to calculate these, :program:`DFTTools`
|
|
|
|
provides the post-processing modules :class:`SumkDFTTools`.
|
|
|
|
It contains routines to calculate
|
2015-08-13 11:03:25 +02:00
|
|
|
|
|
|
|
* (projected) density of states
|
|
|
|
* partial charges
|
|
|
|
* correlated band structures (*spaghettis*)
|
|
|
|
* transport properties such as optical conductivity, resistivity,
|
|
|
|
or thermopower.
|
|
|
|
|
2018-09-20 00:32:33 -04:00
|
|
|
Note that most of these post-processing tools need a real-frequency
|
|
|
|
self energy, and should you be using a CT-QMC impurity solver this
|
|
|
|
comes with the necessity of performing an :ref:`analytic continuation<ac>`.
|
|
|
|
|
|
|
|
.. _runpy:
|
|
|
|
|
|
|
|
Executing your python scripts
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
After having prepared your own python script you may run
|
|
|
|
it on one core with
|
|
|
|
|
|
|
|
`python MyScript.py`
|
|
|
|
|
|
|
|
or in parallel mode
|
|
|
|
|
|
|
|
`mpirun -np 64 python MyScript.py`
|
|
|
|
|
|
|
|
where :program:`mpirun` launches the calculation in parallel mode on 64 cores.
|
|
|
|
The exact form of this command will, of course, depend on the
|
|
|
|
mpi-launcher installed, but the form above works on most systems.
|
|
|
|
|
|
|
|
How to run full charge self-consistent DFT+DMFT calculations (in combination with Wien2k)
|
|
|
|
is described in the :ref:`full charge self-consistency tutorial<full_charge_selfcons>` and
|
|
|
|
the :ref:`Ce tutorial<DFTDMFTtutorial>`, as such calculations need to be launched in a different way.
|