3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-26 04:21:58 +01:00

Work on doc. Added notations & C++ intro

This commit is contained in:
Olivier Parcollet 2013-09-08 19:20:34 +02:00
parent 4413c6a588
commit fe58c9759f
5 changed files with 51 additions and 6 deletions

View File

@ -107,7 +107,7 @@ install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/themes/triqs DESTINATION share/tri
# PDF documentation
if (Build_PDF_Documentation)
add_dependencies(docs_sphinx_pdf_cpp triqs )
add_dependencies(docs_sphinx_pdf triqs )
install(FILES ${sphinx_top_pdf} DESTINATION share/doc/triqs/)
endif()

View File

@ -9,12 +9,13 @@ C++
.. toctree::
:maxdepth: 1
conventions
using_the_lib/contents
arrays/contents
gf/contents
clef/contents
mctools/intro
det_manip/det_manip
det_manip/contents
parameters/parameters
utilities/contents

View File

@ -0,0 +1,43 @@
C++11/14 & notations
=====================
C++11/C++14
---------------
TRIQS is a C++11 library. It *requires* a last generation C++ compiler (Cf :ref:`require_cxx_compilers`).
Indeed, the development of C++ is very dynamic these years.
The language and its usage is changing very profoundly with the introduction of several
notions (e.g. move semantics, type deduction, lambda, variadic templates ...).
Moreover, C++11 compliant compilers are now widely available, with gcc and clang.
A major consequence of this evolution is that writing libraries
has become much more accessible, at a *much* lower cost in development time,
with clearer, shorter and more readable code, hence maintainable.
Efficient techniques which were considered before as complex and reserved to professional C++ experts
are now becoming simple to implement, like e.g. expression templates.
The implementation of most of the TRIQS library (e.g. clef, arrays) would be either impossible or at least
much more complex and time consuming (with a lot of abstruse boost-like construction)
in previous versions of C++.
Besides, this evolution is not finished.
The new coming standard, C++14, expected to be adopted and implemented very soon,
will still make it a lot better. In particular, the concept support (template constraints)
will hopefully solve the most problematic issue with metaprogramming techniques, i.e. the lack of concept
check at compile time, resulting in long and obscur error messages from the compiler when *using* the library.
Hence, TRIQS will move to C++14 as soon as compilers are available.
Notation
----------
In the documentation, we make use in particular of the C++14 concept notation for template.
For example ::
template<ImmutableArray A> void f(A const & a);
means that f is a template ::
template<typename A> void f(A const & a);
which is enabled or valid only for types A which models the `ImmutableArray` concept.

View File

@ -1,13 +1,14 @@
.. _montecarlo:
The Monte Carlo class
=====================
Tools for Monte Carlo
=========================
The TRIQS library has a class called ``mc_generic`` which allows you to write
The TRIQS library provide simple tools for Monte Carlo codes, like a class called ``mc_generic`` which allows you to write
Monte Carlo algorithms in a simple framework. The class takes care of the basic
mechanics which is common to any Monte Carlo method so that you can focus on
the implementation details of your specific algorithm.
.. toctree::
:maxdepth: 2