3
0
mirror of https://github.com/triqs/dft_tools synced 2024-12-27 06:43:40 +01:00
dft_tools/test/triqs/gfs/gfv2.cpp
Olivier Parcollet 9ce291d640 gf: update gf imfreq for g( om - nu) case
DRAFT : to be tested further...

- update gf<imfreq>
- write a specific mesh for matsubara frequencies
- now the cast series is :
  mesh_pt --> matsubara_freq --> complex<double>
- matsubara_freq is just the matsubara frequency
- arithmetic of the mesh_pt casted to matsubara_freq
- arithmetic of matsubara_freq is casted to complex, except + and -,
  which are kept as matsubara_freq.
- evaluator now accept : int, mesh_pt, and matsubara_freq
  for matsubara_freq : for negative omega, use conjugation
  for omega outside windows, evaluate the tail on omega.
- as a result : g( om - nu) where om, nu are 2 meshes points,
  is the extrapolation outside the grid if necessary.
- updated tests
- added evaluation for tail.
2013-11-18 23:41:32 +01:00

148 lines
3.2 KiB
C++

#define TRIQS_ARRAYS_ENFORCE_BOUNDCHECK
#include <triqs/gfs.hpp>
using namespace triqs::gfs;
using namespace triqs::arrays;
#define TEST(X) std::cout << BOOST_PP_STRINGIZE((X)) << " ---> "<< (X) <<std::endl<<std::endl;
#include <triqs/gfs/local/functions.hpp>
// example
//template<typename T> using block_gf = gf<block_index, gf<T>>;
// block_gf<imtime> ...
// but not on gcc 4.6 !
//
int main() {
try {
triqs::gfs::freq_infty inf;
double beta =1;
auto G = gf<imfreq>{ {beta, Fermion}, {2,2} };
auto Gc = gf<imfreq>{ {beta, Fermion}, {2,2} };
auto G3 = gf<imfreq>{ {beta, Fermion}, {2,2} };
auto Gt = gf<imtime>{ {beta, Fermion,100}, {2,2} };
auto Gv = G();
TEST( G( 0) ) ;
Gv.on_mesh(0) = 20;
TEST( Gv( 0) ) ;
TEST( G( 0) ) ;
Gv.on_mesh(0) = 0;
auto Gv2 = slice_target(G(),range(0,1),range(0,1));
TEST( Gv2( 0) ) ;
Gv2.on_mesh(0) = 10;
TEST( Gv2( 0) ) ;
TEST( G( 0) ) ;
triqs::clef::placeholder<0> om_;
triqs::clef::placeholder<1> nu_;
TEST( G(om_) ) ;
TEST( eval(G(om_), om_=0) ) ;
TEST( Gv(om_) ) ;
TEST( eval(Gv(om_), om_=0) ) ;
std::cout <<"-------------lazy assign 1 ------------------"<<std::endl;
Gv(om_) << (0.2 + om_ + 2.1);
TEST(G(0));
TEST(G(inf));
std::cout <<"-------------lazy assign 2 ------------------"<<std::endl;
G(om_) << 1/(om_ + 2.3);
TEST(G(0));
TEST(G(inf));
TEST(inverse(G(inf)));
std::cout <<"----------------- 3 --------------------"<<std::endl;
TEST( Gv(om_) ) ;
TEST( eval(Gv(om_), om_=0) ) ;
// tail
auto t = G(inf);
TEST(t.order_min());
TEST( t( 2) ) ;
TEST( Gv2(inf)( 2) ) ;
// copy
Gc = G;
TEST( G( 0) ) ;
TEST( Gc( 0) ) ;
// operations on gf
G3 = G +2* Gc;
G3 = G + Gc;
// TEST( G3( 0) ) ;
// G3 = G3 /2.0;
// TEST( G3( 0) ) ;
// does not compile : ok
// G3 = G + Gt;
//
std::cout <<"----------------- 4 --------------------"<<std::endl;
// test for density
TEST( density(G3) );
// should not compile
//G3 = G + Gt;
//#define ALL_TEST
#ifdef ALL_TEST
for (int u=0; u<10; ++u) {
TEST( (G + 2.0* Gc)( u) ) ;
TEST( (8.0*G + 2.0* Gc)( u) ) ;
TEST( (8.0*G - 2.0* Gc)( u) ) ;
TEST( (G - Gc)( u) ) ;
TEST( (G - 2.0* Gc)( u) ) ;
TEST( (G * Gc)( u) ) ;
}
#endif
TEST( G( 0) ) ;
TEST(G(inf)(2));
TEST( ( G(inf) + G(inf) ) (2));
TEST( ( G(inf) * G(inf) ) (4));
TEST( t(1));
//tqa::array<double,9> A(1,2,3,4,5,6,7,8,9); A()=0;
//auto x = local::impl::gf_impl<triqs::gfs::meshes::imfreq, true>::wrap_infty (G.tail_view()) + 2.0;
// test hdf5
H5::H5File file("ess_gf.h5", H5F_ACC_TRUNC );
h5_write(file, "g", G);
//
{
auto G0w = gf<imfreq, scalar_valued>{{beta, Fermion, 100}};
auto D0w = gf<imfreq, scalar_valued>{{beta, Boson, 100}};
auto Sigma_w = gf<imfreq, scalar_valued>{{beta, Fermion, 100}};
G0w(om_) << 1 / (om_ - 3);
for (auto const& nu : D0w.mesh()) Sigma_w(om_) << 2 * G0w(om_ - nu);
}
//
{
auto G0w = gf<imfreq, matrix_valued>{{beta, Fermion, 100}, {1,1}};
auto D0w = gf<imfreq, matrix_valued>{{beta, Boson, 100}, {1,1}};
auto Sigma_w = gf<imfreq, matrix_valued>{{beta, Fermion, 100}, {1,1}} ;
G0w(om_) << 1 / (om_ - 3);
for (auto const& nu : D0w.mesh()) Sigma_w(om_) << 2 * G0w(om_ - nu);
}
}
TRIQS_CATCH_AND_ABORT;
}