mirror of
https://github.com/triqs/dft_tools
synced 2025-01-12 05:58:18 +01:00
gf: Fix out of bound in linear mesh in gf eval.
- When reaching the last point of the grid, move one step back and set w =1. - fix the gf_2times but and related issues.
This commit is contained in:
parent
39edb2f846
commit
7693077b79
@ -193,13 +193,14 @@ namespace triqs { namespace gfs {
|
|||||||
|
|
||||||
/// Approximation of a point of the domain by a mesh point
|
/// Approximation of a point of the domain by a mesh point
|
||||||
template<typename D>
|
template<typename D>
|
||||||
std::tuple<bool, size_t, double> windowing (linear_mesh<D> const & mesh, typename D::point_t const & x) {
|
std::tuple<bool, long, double> windowing (linear_mesh<D> const & mesh, typename D::point_t const & x) {
|
||||||
double a = (x - mesh.x_min())/mesh.delta();
|
double a = (x - mesh.x_min())/mesh.delta();
|
||||||
long i = std::floor(a);
|
long i = std::floor(a), imax = long(mesh.size())-1;
|
||||||
bool in = (! ((i<0) || (i>long(mesh.size())-1)));
|
bool in = (i>=0) && (i<imax);
|
||||||
double w = a-i;
|
double w = a-i;
|
||||||
// std::cerr << " window "<< i << " "<< in << " "<< w<< std::endl ;
|
if (i==imax) { --i; in = (std::abs(w)< 1.e-14); w=1.0;}
|
||||||
return std::make_tuple(in, (in ? size_t(i) : 0),w);
|
return std::make_tuple(in,i,w);
|
||||||
|
//return std::make_tuple(in, (in ? i : 0),w);
|
||||||
}
|
}
|
||||||
|
|
||||||
}}
|
}}
|
||||||
|
Loading…
Reference in New Issue
Block a user