3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-12 05:58:18 +01:00
dft_tools/doc/basicnotions/structure.rst

132 lines
5.3 KiB
ReStructuredText
Raw Normal View History

.. _structure:
Structure of :program:`DFTTools`
================================
.. image:: images/structure.png
:width: 700
:align: center
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
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
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
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
"""""""""""""""""
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
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
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
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
materials. The major part is contained in the module
2015-08-13 11:03:25 +02:00
:class:`SumkDFT`. It contains routines to
* 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
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
---------------
The main result of DMFT calculation is the interacting Green function
and the self energy. However, one is normally interested in
quantities like band structure, density of states, or transport
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.
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.