mirror of
https://github.com/triqs/dft_tools
synced 2024-12-25 22:03:43 +01:00
gf: fix upper bound in out of bounds check in linear mesh
This commit is contained in:
parent
bd4926157c
commit
65bdc65da1
@ -14,6 +14,8 @@ using triqs::arrays::array;
|
|||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
//typedef gf<two_real_times> Gf_type;
|
//typedef gf<two_real_times> Gf_type;
|
||||||
//typedef gf_view<two_real_times> Gf_view_type;
|
//typedef gf_view<two_real_times> Gf_view_type;
|
||||||
|
|
||||||
@ -31,7 +33,9 @@ int main() {
|
|||||||
std::cout <<A << std::endl ;
|
std::cout <<A << std::endl ;
|
||||||
|
|
||||||
G(t_,tp_) << t_ - 3*tp_;
|
G(t_,tp_) << t_ - 3*tp_;
|
||||||
//G2(t_,tp_) << t_ + 3*tp_;
|
G2(t_,tp_) << t_ + 3*tp_;
|
||||||
|
|
||||||
|
G2(t_,tp_) << 2* G(tp_,t_);
|
||||||
|
|
||||||
TEST( G(1,1) );
|
TEST( G(1,1) );
|
||||||
TEST( G[G.mesh()(1,1) ]);
|
TEST( G[G.mesh()(1,1) ]);
|
||||||
@ -45,4 +49,6 @@ int main() {
|
|||||||
|
|
||||||
//TEST( G2(2,1,3) ); // should not compile
|
//TEST( G2(2,1,3) ); // should not compile
|
||||||
|
|
||||||
|
}
|
||||||
|
catch( std::exception const &e) { std::cout << e.what()<< std::endl;}
|
||||||
}
|
}
|
||||||
|
@ -191,7 +191,7 @@ namespace triqs { namespace gfs {
|
|||||||
std::tuple<bool, size_t, double> windowing ( linear_mesh<D> const & mesh, typename D::point_t const & x) {
|
std::tuple<bool, size_t, 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 = floor(a);
|
long i = floor(a);
|
||||||
bool in = (! ((i<0) || (i>=long(mesh.size())-1)));
|
bool in = (! ((i<0) || (i>long(mesh.size())-1)));
|
||||||
double w = a-i;
|
double w = a-i;
|
||||||
// std::cerr << " window "<< i << " "<< in << " "<< w<< std::endl ;
|
// std::cerr << " window "<< i << " "<< in << " "<< w<< std::endl ;
|
||||||
return std::make_tuple(in, (in ? size_t(i) : 0),w);
|
return std::make_tuple(in, (in ? size_t(i) : 0),w);
|
||||||
|
Loading…
Reference in New Issue
Block a user