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_imfreq.rst

122 lines
3.4 KiB
ReStructuredText
Raw Normal View History

2013-08-22 16:55:51 +02:00
.. highlight:: c
.. _gf_imfreq:
Matsubara frequencies
2013-08-22 16:55:51 +02:00
==========================================================
This is a specialisation of :ref:`gf<gf_and_view>` for imaginary Matsubara frequencies.
2013-09-18 15:13:23 +02:00
Synopsis
------------
.. code::
gf<imfreq, Target, Opt>
The *Target* template parameter can take the following values :
2013-08-22 16:55:51 +02:00
+-------------------------+-----------------------------------------------------+
| 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
----------------
The domain is :doxy:`matsubara_freq_domain<triqs::gfs::matsubara_domain>`.
The Matsubara frequencies are :math:`\omega_n=\frac{(2n+1)\pi}{\beta}` for fermions and :math:`\omega_n=\frac{2n\pi}{\beta}` for bosons.
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`.
2013-08-22 16:55:51 +02:00
Evaluation method
2013-08-22 16:55:51 +02:00
---------------------
* No interpolation.
* 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-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 :
2013-08-22 16:55:51 +02:00
* `data_t` : 3d array (C ordered) of complex<double>.
* 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
---------------------------
h5 tag : `ImFreq`
TODO : DECIDE if we have 2 tag, one for scalar, one for matrix....
2013-08-22 16:55:51 +02:00
Examples
---------
.. compileblock::
2013-09-18 15:13:23 +02:00
#include <triqs/gfs.hpp>
using namespace triqs::gfs;
2013-08-22 16:55:51 +02:00
int main(){
double beta=10;
int Nfreq =100;
2013-09-18 15:13:23 +02:00
// --- first a matrix_valued function ------------
2013-09-18 15:13:23 +02:00
// First give information to build the mesh, second to build the target
auto g1 = gf<imfreq> { {beta,Fermion,Nfreq}, {1,1} };
2013-09-18 15:13:23 +02:00
// or a more verbose/explicit form ...
auto g2 = gf<imfreq> { gf_mesh<imfreq>{beta,Fermion,Nfreq}, make_shape(1,1) };
2013-09-18 15:13:23 +02:00
// Filling the gf with something...
triqs::clef::placeholder<0> wn_;
g1(wn_) << 1/ (wn_ + 2);
2013-09-18 15:13:23 +02:00
// evaluation at n=3
std::cout << g1(3) << " == "<< 1/ ( 1_j * M_PI / beta * (2*3+1) + 2) << std::endl;
2013-09-18 15:13:23 +02:00
// the high frequency expansion was automatically computed.
//std::cout << g1.singularity() << std::endl; // a bit verbose..
// --- a scalar_valued function ------------
// same a before, but without the same of the target space ...
auto g3 = gf<imfreq,scalar_valued> { {beta,Fermion,Nfreq} };
auto g4 = gf<imfreq,scalar_valued> { gf_mesh<imfreq>{beta,Fermion,Nfreq} };
2013-08-22 16:55:51 +02:00
g3(wn_) << 1/ (wn_ + 2);
// evaluation at n=3.
std::cout << g3(3) << " == "<< 1/ ( 1_j * std::acos(-1) / beta * (2*3+1) + 2) << std::endl;
}
2013-08-22 16:55:51 +02:00