From 1b3a66af2463f0a668e247e23072194197263ff7 Mon Sep 17 00:00:00 2001 From: tayral Date: Mon, 6 Jan 2014 15:43:16 +0000 Subject: [PATCH] Fixed bug out of domain for mesh with positive and negative matsubara frequencies --- triqs/gfs/imfreq.hpp | 42 +++++++++++++++++++++++++++++++----------- 1 file changed, 31 insertions(+), 11 deletions(-) diff --git a/triqs/gfs/imfreq.hpp b/triqs/gfs/imfreq.hpp index 604f4e04..a9f723f1 100644 --- a/triqs/gfs/imfreq.hpp +++ b/triqs/gfs/imfreq.hpp @@ -72,33 +72,53 @@ namespace gfs { // dispatch for 2x2 cases : matrix/scalar and tail/no_tail ( true means no_tail) template std::complex _call_impl(G const *g, matsubara_freq const &f, scalar_valued, std::false_type) const { - if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n]; - if ((f.n < 0) && (-f.n < g->mesh().size())) return conj((*g)[-f.n]); + if (g->mesh().index_start()==0){//only positive Matsubara frequencies + if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n]; + if ((f.n < 0) && (-f.n < g->mesh().size())) return conj((*g)[-f.n]); + } + else{ + if ((f.n >= g->mesh().index_start()) && (f.n < g->mesh().size()+g->mesh().index_start())) return (*g)[f.n]; + } return g->singularity().evaluate(f)(0, 0); } template std::complex _call_impl(G const *g, matsubara_freq const &f, scalar_valued, std::true_type) const { - if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n]; - if ((f.n < 0) && (-f.n < g->mesh().size())) return conj((*g)[-f.n]); + if (g->mesh().index_start()==0){//only positive Matsubara frequencies + if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n]; + if ((f.n < 0) && (-f.n < g->mesh().size())) return conj((*g)[-f.n]); + } + else{ + if ((f.n >= g->mesh().index_start()) && (f.n < g->mesh().size()+g->mesh().index_start())) return (*g)[f.n]; + } return 0; } template arrays::matrix_const_view> _call_impl(G const *g, matsubara_freq const &f, matrix_valued, std::false_type) const { - if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n](); - if ((f.n < 0) && (-f.n < g->mesh().size())) - return arrays::matrix>{conj((*g)[-f.n]())}; - else - return g->singularity().evaluate(f); + if (g->mesh().index_start()==0){//only positive Matsubara frequencies + if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n](); + if ((f.n < 0) && (-f.n < g->mesh().size())) + return arrays::matrix>{conj((*g)[-f.n]())}; + } + else{ + if ((f.n >= g->mesh().index_start()) && (f.n < g->mesh().size()+g->mesh().index_start())) return (*g)[f.n]; + } + return g->singularity().evaluate(f); } template arrays::matrix_const_view> _call_impl(G const *g, matsubara_freq const &f, matrix_valued, std::true_type) const { - if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n](); - if ((f.n < 0) && (-f.n < g->mesh().size())) return arrays::matrix>{conj((*g)[-f.n]())}; + if (g->mesh().index_start()==0){//only positive Matsubara frequencies + if ((f.n >= 0) && (f.n < g->mesh().size())) return (*g)[f.n](); + if ((f.n < 0) && (-f.n < g->mesh().size())) + return arrays::matrix>{conj((*g)[-f.n]())}; + } + else{ + if ((f.n >= g->mesh().index_start()) && (f.n < g->mesh().size()+g->mesh().index_start())) return (*g)[f.n]; + } auto r = arrays::matrix>{get_target_shape(*g)}; r() = 0; return r;