3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-12 14:08:24 +01:00

Work on doc

- remove empty parts, start to clean the tour.
- added export of _template and _static to reuse in appli doc.
- clean tutorial part. rm cookbook.
This commit is contained in:
Olivier Parcollet 2013-08-31 00:04:09 +02:00
parent 59dbacedb6
commit 3305185bee
26 changed files with 195 additions and 188 deletions

View File

@ -106,12 +106,15 @@ install(DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/html/ COMPONENT documentation DEST
PATTERN "*.py" PATTERN "*.py"
PATTERN "*.txt" PATTERN "*.txt"
PATTERN "*.bib" PATTERN "*.bib"
PATTERN "*.inv"
PATTERN ".svn" EXCLUDE PATTERN ".svn" EXCLUDE
PATTERN "CVS" EXCLUDE PATTERN "CVS" EXCLUDE
) )
install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/themes/agogo DESTINATION share/triqs/themes) install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/themes/agogo DESTINATION share/triqs/themes)
install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/themes/triqs DESTINATION share/triqs/themes) install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/themes/triqs DESTINATION share/triqs/themes)
install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/_static DESTINATION share/triqs/export)
install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/_templates DESTINATION share/triqs/export)
# PDF documentation # PDF documentation
if (Build_PDF_Documentation) if (Build_PDF_Documentation)

View File

@ -6,9 +6,11 @@
<img style="width: 80px; margin: 10px 0 0 5px" src='_static/logo_erc.jpg' alt="ERC"/> <img style="width: 80px; margin: 10px 0 0 5px" src='_static/logo_erc.jpg' alt="ERC"/>
</p> </p>
<!--
<h3><a href="applications.html">TRIQS applications</a></h3> <h3><a href="applications.html">TRIQS applications</a></h3>
<p> <p>
Some applications are supported by the TRIQS collaboration, Some applications are supported by the TRIQS collaboration,
<a class="reference external" href="{{ pathto("applications") }}">check them out!</a> <a class="reference external" href="{{ pathto("applications") }}">check them out!</a>
</p> </p>
-->

9
doc/_templates/sideb_appli.html vendored Normal file
View File

@ -0,0 +1,9 @@
<p>
<a href="http://ipht.cea.fr"> <img style="width: 80px; margin: 10px 5px 0 0" src='_static/logo_cea.png' alt="CEA"/> </a>
<a href="http://www.cpht.polytechnique.fr"> <img style="width: 80px; margin: 10px 5px 0 5px" src='_static/logo_x.png' alt="Ecole Polytechnique"/> </a>
<br>
<a href="http://www.cnrs.fr"> <img style="width: 80px; margin: 10px 0 0 5px" src='_static/logo_cnrs.png' alt="CNRS"/> </a>
<img style="width: 80px; margin: 10px 0 0 5px" src='_static/logo_erc.jpg' alt="ERC"/>
</p>

View File

@ -9,24 +9,19 @@ A quick tour
.. toctree:: .. toctree::
:maxdepth: 1 :maxdepth: 1
overview tutorials/python/introduction
tutorials/contents tutorials/c++/contents
C++ libraries Reference manual
------------- -----------------
This is the reference manual for the Python and the C++ libraries.
.. toctree:: .. toctree::
:maxdepth: 1 :maxdepth: 2
reference/c++/contents
Python modules
--------------
.. toctree::
:maxdepth: 1
reference/python/contents reference/python/contents
reference/c++/contents
Version compatibility Version compatibility
--------------------- ---------------------

View File

@ -11,31 +11,33 @@ Welcome
have changed too. So go look at our :ref:`changelog page <changelog>` have changed too. So go look at our :ref:`changelog page <changelog>`
to find out how to upgrade to 1.0. to find out how to upgrade to 1.0.
TRIQS is a scientific project providing a set of C++ and Python libraries to develop new tools TRIQS (**T**\oolbox for **R**\esearch on **I**\nteracting **Q**\uantum **S**\ystems)
is a scientific project providing a set of C++ and Python libraries to develop new tools
for the study of interacting quantum systems. for the study of interacting quantum systems.
The goal of this toolkit is to provide condensed matter physicists with The goal of this toolkit is to provide condensed matter physicists with
high quality, high level, efficient and simple to use libraries in C++ and Python, high level, efficient and simple to use libraries in C++ and Python,
and to promote the use of modern programming techniques and practices in our field. and to promote the use of modern programming techniques in our field.
TRIQS is free software (GPL). TRIQS is free software (GPL).
TRIQS applications TRIQS applications
----------------------- -----------------------
Several :ref:`full-fledged applications <applications>` have been written using Based on the TRIQS toolkit, several :ref:`full-fledged applications <applications>`
TRIQS and are also maintained by the TRIQS collaboration. They allow for example to are also maintained by the TRIQS collaboration. They allow for example to
solve a generic quantum impurity model or to run a complete LDA+DMFT solve a generic quantum impurity model or to run a complete LDA+DMFT
calculation. calculation.
Since 2005, the TRIQS library and applications have allowed to address Elaborated in a collaboration between IPhT Saclay and Ecole Polytechnique since 2005,
questions as diverse as: the TRIQS library and applications have allowed to address questions as diverse as:
* Momentum-selective aspects on cuprate superconductors (with various cluster DMFT) * Momentum-selective aspects on cuprate superconductors (with various cluster DMFT)
* Degree of correlation in iron-based superconductors (within an LDA+DMFT approach) * Degree of correlation in iron-based superconductors (within an LDA+DMFT approach)
* Fermionic Mott transition and exploration of Sarma phase in cold-atoms * Fermionic Mott transition and exploration of Sarma phase in cold-atoms
C++ & Python
Python & C++
----------------------------- -----------------------------
The libraries exist at two The libraries exist at two

View File

@ -7,7 +7,11 @@
Installation Installation
============ ============
This page describes the installation of TRIQS itself. The installation of the applications based on TRIQS TRIQS and its applications are provided *à la carte*:
after you have installed the TRIQS toolkit, you will be able to easily install
various TRIQS-based applications: impurity solvers, realistic DMFT tools, ...
This page describes the installation of the TRIQS toolkit itself. The installation of the applications
is described in their respective documentation. is described in their respective documentation.
Prerequisite Prerequisite
@ -41,7 +45,7 @@ Installation steps
$ cmake -DCMAKE_INSTALL_PREFIX=path_to_install_directory ../src $ cmake -DCMAKE_INSTALL_PREFIX=path_to_install_directory ../src
If you omit ``CMAKE_INSTALL_PREFIX``, the default If you omit ``CMAKE_INSTALL_PREFIX``, the default
``path_to_install_directory`` is a subdirectory ``INSTALL_DIR`` in your build ``path_to_install_directory`` is the subdirectory *INSTALL_DIR* in your build
directory. More configuration options are described in the directory. More configuration options are described in the
:ref:`cmake options <install_options>`. :ref:`cmake options <install_options>`.

View File

@ -1,7 +1,8 @@
.. index:: install_on_osx_lion .. index:: install_osx_lion
.. highlight:: bash
.. _install_on_osx_lion: .. _install_on_osx_lion:
.. highlight:: bash
Installing required libraries on Mac OS X Installing required libraries on Mac OS X
========================================= =========================================

View File

@ -1,12 +0,0 @@
Arrays cookbook : learn through simple examples...
**********************************************************************************
.. highlight:: c
.. toctree::
:maxdepth: 2
:numbered:
basic
intermediate

View File

@ -1,6 +0,0 @@
Intermediate
===============
.. highlight:: c

View File

@ -1,5 +1,5 @@
C++ libraries C++
============= =============
.. toctree:: .. toctree::

View File

@ -1,11 +0,0 @@
.. _greenfunctions:
Green's function cookbook
==========================
.. toctree::
:maxdepth: 2
real
imaginary

View File

@ -1,2 +0,0 @@
Learn more in the full referencen, see :ref:`greenfunctions`

View File

@ -1,20 +0,0 @@
Create a real frequency Green function
--------------------------------------
.. compileblock::
#include <triqs/arrays.hpp>
#include <triqs/gfs/refreq.hpp>
using triqs::gfs::make_gf;
using triqs::gfs::refreq;
int main() {
double wmin=0;
double wmax=10;
size_t n_freq=5;
//we want a Green function whose values are 2*2 matrices of complex numbers
auto shape = triqs::arrays::make_shape(2,2);
auto GF=make_gf<refreq>(wmin, wmax, n_freq, shape);
};

View File

@ -4,53 +4,54 @@
.. _util_exceptions: .. _util_exceptions:
Exceptions Exceptions
============================= =============
TRIQS defines special exceptions, with the following characteristics : TRIQS defines special exceptions, with the following characteristics :
* they derives from std::exceptions and have the interface * they derives from std::exceptions
* their .what() contains : * their .what() contains :
* the file and line where the exception occurred * the file and line where the exception occurred
* an additionnal error message (see example below). The error behaves like a std::stringstream, * an additionnal error message (see example below). The error behaves like a std::stringstream,
one can accumulate any message one can accumulate any message
* a complete stack strace of the C++ code at the exception point, with demangling of the function name (on gcc and clang). * a complete stack strace of the C++ code at the exception point, with demangling of the function name (on gcc and clang).
* the boost python interface catches these exceptions and report all the information , for debugging.
So instead of having "Unknown exception in C++", you have a complete trace of the problem that occurred.
.. warning:: .. warning::
For uniformity, it is highly recommended to use these macros when developing for TRIQS. For uniformity, it is highly recommended to use these macros when developing for TRIQS.
Example of use :: Example :
#include <triqs/utility/exceptions.hpp> .. compileblock::
...
if (!condition) TRIQS_RUNTIME_ERROR <<" The value of a = "<<a<<" is not in the expected range" << R;
...
List of available exceptions :
* TRIQS_RUNTIME_ERROR. // automatically included in e.g. arrays, gfs, any triqs library...
#include <triqs/utility/exceptions.hpp>
int main() {
if (2!=3) TRIQS_RUNTIME_ERROR <<" The condition is false because "<< 2 << "!=" << 3;
}
This macro is simply :: The exception can of course be caught :
#define TRIQS_RUNTIME_ERROR throw triqs::runtime_error()<<" Triqs runtime error at "<<__FILE__<< " : "<<__LINE__<<"\n\n Trace is :\n\n"<<triqs::utility::stack_trace()<<"\n" .. compileblock::
So it can be catched with the `triqs::runtime_error` type, e.g. :: // automatically included in e.g. arrays, gfs, any triqs library...
#include <triqs/utility/exceptions.hpp>
#include <triqs/utility/exceptions.hpp> #include <iostream>
try { void f() {
... try {
if (!condition) TRIQS_RUNTIME_ERROR <<" The value of a = "<<a<<" is not in the expected range" << R; if (2!=3) TRIQS_RUNTIME_ERROR <<" The condition is false because "<< 2 << "!=" << 3;
... }
} catch (triqs::runtime_error const & e) {
catch (triqs::runtime_error const & e) {
std::cout << "caught error "<< e.what()<<std::endl; std::cout << "caught error "<< e.what()<<std::endl;
} }
}
int main() {
f();
}

View File

@ -1,5 +1,5 @@
Python libraries Python
================ ================
.. toctree:: .. toctree::

View File

@ -1,9 +1,10 @@
Basic Using arrays
============ ===============
.. highlight:: c .. highlight:: c
Declaring and printing an array Declaring and printing an array
------------------------------- -------------------------------
.. compileblock:: .. compileblock::
@ -37,19 +38,6 @@ Simple operations
} }
Simple functions
-------------------
.. compileblock::
#include <triqs/arrays.hpp>
using triqs::arrays::array;
int main(){
array<double,1> A(10),B(10);
A()=2;B()=3;
///.....
}
HDF5 Archiving HDF5 Archiving
------------------- -------------------
Archiving an array into an HDF5 file is easy: Archiving an array into an HDF5 file is easy:
@ -185,35 +173,3 @@ Map and fold
} }
Bound checking
---------------
By default, there is no bound checking:
.. compileblock::
#include <triqs/arrays.hpp>
using triqs::arrays::array;
int main(){
array<double,2> A(2,2); A() = 3;
std::cout << A(0,3) << std::endl;
}
But one can add bound-checking by adding a preprocessor command:
.. compileblock::
#define TRIQS_ARRAYS_ENFORCE_BOUNDCHECK
#include <triqs/arrays.hpp>
using triqs::arrays::array;
int main(){
try {
array<double,2> A(2,2); A() = 3;
std::cout << A(0,3) << std::endl;
}
//catch (triqs::arrays::key_error & e) { std::cout<< e.what()<< std::endl;}
catch (std::exception & e) { std::cout<< e.what()<< std::endl;} // or like this : triqs::arrays::key_error derives from std::exception
}

View File

@ -1,8 +1,14 @@
C++ libraries C++ libraries
================================= =================================
.. warning::
TO BE WRITTEN
.. toctree:: .. toctree::
:maxdepth: 1 :maxdepth: 1
../../reference/c++/arrays/cookbook/contents
../../reference/c++/gf/cookbook/contents
..
array_tutorial

View File

@ -0,0 +1,42 @@
from pytriqs.gf.local import *
from pytriqs.operators import *
from pytriqs.applications.impurity_solvers.cthyb_matrix import Solver
D, V, U = 1.0, 0.2, 4.0
e_f, Beta = -U/2.0, 50
# The impurity solver
S = Solver(Beta = Beta, # inverse temperature
GFstruct = [ ('up',[1]), ('down',[1]) ], # Structure of the Green's function
H_Local = U * N('up',1) * N('down',1), # Local Hamiltonian
Quantum_Numbers = { # Quantum Numbers
'Nup' : N('up',1), # (operators commuting with H_Local)
'Ndown' : N('down',1) },
N_Cycles = 500000, # Number of QMC cycles
Length_Cycle = 200, # Length of one cycle
N_Warmup_Cycles = 10000, # Warmup cycles
N_Legendre_Coeffs = 50, # Number of Legendre coefficients
Random_Generator_Name = 'mt19937', # Name of the random number generator
Use_Segment_Picture = True, # Use the segment picture
Measured_Operators = { # Operators to be averaged
'Nimp' : N('up',1)+N('down',1) },
Global_Moves = [ # Global move in the QMC
(0.05, lambda (a,alpha,dag) : ( {'up':'down','down':'up'}[a],alpha,dag ) ) ],
)
# Initialize the non-interacting Green's function S.G0
for spin, g0 in S.G0 :
g0 <<= inverse( iOmega_n - e_f - V**2 * Wilson(D) )
# Run the solver. The result will be in S.G
S.Solve()
# Save the results in an hdf5 file (only on the master node)
from pytriqs.archive import HDFArchive
import pytriqs.utility.mpi as mpi
if mpi.is_master_node():
Results = HDFArchive("solution.h5",'w')
Results["G"] = S.G
Results["Gl"] = S.G_Legendre
Results["Nimp"] = S.Measured_Operators_Results['Nimp']

View File

@ -0,0 +1,6 @@
from pytriqs.gf.local import *
from pytriqs.archive import *
from pytriqs.plot.mpl_interface import oplot
A = HDFArchive("solution.h5")
oplot(A['G']['up'], '-o', x_window = (0,10))

View File

@ -1,33 +1,11 @@
.. index:: introduction .. index:: introduction
.. role:: red .. role:: red
Python modules Python
================================== ==================================
TRIQS (**T**\oolbox for **R**\esearch on **I**\nteracting **Q**\uantum **S**\ystems) This introduction is a little tour of some aspects of TRIQS and some of its applications,
is a free software scientific project at the Python level. The goal is not to explain here in details but to quickly show some of TRIQS's current capabilities.
that aims at providing tools for the theoretical study of strongly correlated quantum systems.
It is based on some of the codes originally developed and used at IPhT Saclay and Ecole Polytechnique since 2005
(see :ref:`credits <collaboration>`).
It is implemented as a `Python <http://www.python.org>`_ library, with Python, C++ and Fortran codes and contains :
* Various basic objects e.g. :
* Local Green's functions of various kinds.
* Bravais lattices, tight-binding hoppings, local density of states, superlattices (for cluster methods)
* Some simple *k*-sums over the Brillouin zone.
* Optional extension modules :
* Quantum impurity solvers :
* :ref:`Continuous-time hybridization Quantum Monte Carlo <ctqmc_hyb>`.
* :ref:`Hubbard I <hubbardI>`.
* :ref:`Wien2TRIQS <Wien2k>` : an interface to the Wien2k electronic structure code for performing LDA+DMFT computations.
The rest of the introduction is a little demo of examples used elsewhere in the documentation.
The goal is not to explain them here in details but to quickly show some of TRIQS's current capabilities.
.. toctree:: .. toctree::
:maxdepth: 1 :maxdepth: 1

View File

@ -1,5 +1,5 @@
Recommended reading and references Learning Python : recommended reading and references
---------------------------------------------------------- ----------------------------------------------------------
* A good set of lectures is the `Scipy lecture notes <http://scipy-lectures.github.com/>`_. * A good set of lectures is the `Scipy lecture notes <http://scipy-lectures.github.com/>`_.

View File

@ -0,0 +1,48 @@
from pytriqs.gf.local import *
from pytriqs.archive import *
import pytriqs.utility.mpi as mpi
# Set up a few parameters
Half_Bandwidth = 1.0
U = 2.5
Chemical_Potential = U/2.0
Beta = 100
N_loops = 5
# Construct a CTQMC solver
from pytriqs.applications.impurity_solvers.operators import * # imports the class manipulating C, C_dagger and N = C_dagger C
from pytriqs.applications.impurity_solvers.cthyb_matrix import Solver # imports the solver class
S = Solver(Beta = Beta, # inverse temperature
GFstruct = [ ('up',[1]), ('down',[1]) ], # Structure of the Green function
H_Local = U * N('up',1) * N('down',1), # Local Hamiltonian
Quantum_Numbers = { 'Nup' : N('up',1), 'Ndown' : N('down',1) }, # Quantum Numbers (operators commuting with H_Local)
N_Cycles = 5000, # Number of QMC cycles
Length_Cycle = 200, # Length of a cycle
N_Warmup_Cycles = 1000, # How many warmup cycles
N_Legendre_Coeffs = 30, # Use 30 Legendre coefficients to represent G(tau)
Random_Generator_Name = "mt19937", # Use the Mersenne Twister 19937 random generator
Use_Segment_Picture = True) # Here we can use the segment picture
# Initalize the Green's function to a semi circular
S.G <<= SemiCircular(Half_Bandwidth)
# Now do the DMFT loop
for IterationNumber in range(N_loops):
# Compute S.G0 with the self-consistency condition while imposing paramagnetism
g = 0.5 * ( S.G['up'] + S.G['down'] )
for name, g0block in S.G0:
g0block <<= inverse( iOmega_n + Chemical_Potential - (Half_Bandwidth/2.0)**2 * g )
# Run the solver
S.Solve()
# Some intermediate saves
if mpi.is_master_node():
R = HDFArchive("single_site_bethe.h5")
R["G-%s"%IterationNumber] = S.G
del R
# Here we would usually write some convergence test
# if Converged : break

View File

@ -21,6 +21,6 @@ Finally, the obtained bath and impurity densities of states are plotted using th
:include-source: :include-source:
:scale: 70 :scale: 70
You will find more information on the local Green's function implementation in TRIQS in :ref:`the corresponding chapter of the manual <green>` You will find more information on the local Green's function implementation in TRIQS in :doc:`the corresponding chapter of the manual <../../reference/python/green/green>`

View File

@ -9,12 +9,12 @@ neighbour hopping using the ``BravaisLattice`` class of TRIQS, compute its
density of states (DOS) and then plot it by using again the ``oplot`` function. density of states (DOS) and then plot it by using again the ``oplot`` function.
.. literalinclude:: ../lattice/ex1.py .. literalinclude:: ../../reference/python/lattice/ex1.py
:lines: 1-34 :lines: 1-34
.. image:: ../lattice/ex1.png .. image:: ../../reference/python/lattice/ex1.png
:width: 700 :width: 700
:align: center :align: center
More information on the lattice tools implemeted in TRIQS can be :ref:`found here <lattice>` More information on the lattice tools implemeted in TRIQS can be :doc:`found here <../../reference/python/lattice/lattice>`

View File

@ -3,6 +3,8 @@
Tour 3: Solving a quantum impurity model with QMC Tour 3: Solving a quantum impurity model with QMC
---------------------------------------------------------- ----------------------------------------------------------
`[Requires TRIQS and the application cthyb_matrix]`
Free electrons are nice, but the `I` in TRIQS means `interacting`. Free electrons are nice, but the `I` in TRIQS means `interacting`.
So let us solve a simple one-band Anderson impurity model So let us solve a simple one-band Anderson impurity model
@ -25,14 +27,14 @@ We solve this model using the hybridization expansion Continuous Time Quantum Mo
proposed by `P. Werner et al. <http://link.aps.org/doi/10.1103/PhysRevLett.97.076405>`_ proposed by `P. Werner et al. <http://link.aps.org/doi/10.1103/PhysRevLett.97.076405>`_
To this end we first initialize the ``Solver`` class of the TRIQS CT-Hyb implementaion To this end we first initialize the ``Solver`` class of the TRIQS CT-Hyb implementaion
``pytriqs.applications.impurity_solvers.ctqmc_hyb``. ``pytriqs.applications.impurity_solvers.cthyb_matrix``.
Then, after having constructed the non-interacting Green's function :math:`G^{-1}_{0,\sigma}`, Then, after having constructed the non-interacting Green's function :math:`G^{-1}_{0,\sigma}`,
we launch the CT-Hyb calculations by calling the ``Solve`` method of the ``Solver`` class. we launch the impurity solver calculations by calling the ``Solve`` method.
Finally, the resulting interacting Green's function as well as average impurity occupancy Finally, the resulting interacting Green's function as well as average impurity occupancy
is stored in the :ref:`HDF5 format<hdf5_base>`. is stored in the :ref:`HDF5 format<hdf5_base>`.
.. literalinclude:: ../solvers/aim.py .. literalinclude:: ./aim.py
The result can be then read from the ``HDF5`` file and plotted using the ``oplot`` function: The result can be then read from the ``HDF5`` file and plotted using the ``oplot`` function:
@ -43,5 +45,5 @@ The result can be then read from the ``HDF5`` file and plotted using the ``oplot
:align: center :align: center
We go through this example in more details in the tutorial :ref:`Anderson impurity model <aim>` We go through this example in more details in the documentation of the cthyb_matrix application.

View File

@ -2,6 +2,9 @@
Tour 4: Dynamical Mean Field Theory on a Bethe lattice Tour 4: Dynamical Mean Field Theory on a Bethe lattice
------------------------------------------------------ ------------------------------------------------------
`Requires TRIQS and the application cthyb_matrix`
In the case of Bethe lattice the dynamical mean-field theory (DMFT) self-consistency condition takes a particularly simple form In the case of Bethe lattice the dynamical mean-field theory (DMFT) self-consistency condition takes a particularly simple form
.. math:: .. math::
@ -15,7 +18,7 @@ the previous single-impurity example to the case of a bath with semi-circular de
Here is a complete program doing this plain vanilla DMFT on a half-filled one-band Bethe lattice: Here is a complete program doing this plain vanilla DMFT on a half-filled one-band Bethe lattice:
.. literalinclude:: ../solvers/dmft/single_site_bethe.py .. literalinclude:: ./single_site_bethe.py
A general introduction to DMFT calculations with TRIQS can be found :ref:`here <dmftloop>` A general introduction to DMFT calculations with TRIQS can be found :ref:`here <dmftloop>`