3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-13 14:29:01 +01:00
dft_tools/doc/reference/c++/gf/gf_retime.rst

97 lines
2.3 KiB
ReStructuredText
Raw Normal View History

2013-08-22 16:55:51 +02:00
.. highlight:: c
.. _gf_retime:
Real time
2013-08-22 16:55:51 +02:00
===================================================
This is a specialisation of :ref:`gf_and_view` for imaginary Matsubara frequencies.
Synopsis
------------
.. code::
gf<retime, Target, Opt>
The *Target* template parameter can take the following values :
+-------------------------+-----------------------------------------------------+
| Target | Meaning |
+=========================+=====================================================+
| scalar_valued | The function is scalar valued (double, complex...). |
+-------------------------+-----------------------------------------------------+
| matrix_valued [default] | The function is matrix valued. |
+-------------------------+-----------------------------------------------------+
2013-08-22 16:55:51 +02:00
Domain & mesh
----------------
CORRECT THIS !! PUT OUT THE C++ impl for doxy doc
The domain is :doxy:`matsubara_freq_domain<triqs::gfs::matsubara_domain>`.
The mesh is :doxy:`matsubara_freq_mesh<triqs::gfs::matsubara_freq_mesh>`.
2013-08-22 16:55:51 +02:00
Singularity
-------------
The singularity is a high frequency expansion, :ref:`gf_tail`.
Evaluation method
2013-08-22 16:55:51 +02:00
---------------------
* Linear interpolation on the mesh.
* Return type :
* If Target==scalar_valued : a complex
* If Target==matrix_valued : an object modeling ImmutableMatrix concept.
* When the point is outside of the mesh, the evaluation of the gf returns :
* the evaluation of the high frequency tail if no_tail is not set.
* 0 otherwise
2013-09-18 15:13:23 +02:00
2013-08-22 16:55:51 +02:00
Data storage
---------------
* If Target==scalar_valued :
* `data_t` : 1d array of complex<double>.
* g.data()(i) is the value of g for the i-th point of the mesh.
* If Target==matrix_valued :
* `data_t` : 3d array (C ordered) of complex<double>.
2013-09-18 15:13:23 +02:00
* g.data()(i, range(), range()) is the value of g for the i-th point of the mesh.
2013-08-22 16:55:51 +02:00
HDF5 storage convention
---------------------------
2013-09-18 15:13:23 +02:00
h5 tag : `ReTime`
2013-08-22 16:55:51 +02:00
Examples
---------
.. compileblock::
#include <triqs/gfs.hpp>
2013-08-22 16:55:51 +02:00
using namespace triqs::gfs;
2013-09-18 15:13:23 +02:00
2013-08-22 16:55:51 +02:00
int main() {
2013-09-18 15:13:23 +02:00
double tmin=0, tmax=10; // the time interval
auto n_times=100; // we will have 100 points
//we want a 2x2 matrix-valued Green function
auto g=gf<retime>{ {tmin, tmax, n_times} , {2,2} };
2013-08-22 16:55:51 +02:00
};