3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-12 22:18:23 +01:00

Fix #108 (tentatively).

- Pb was that indices for gf where empty when constructed
  with default args from C++.
- changed into : make indices from the shape in the default
  case.
- also added more, simpler construction, for the indices
  to easy C++ construction.
This commit is contained in:
Olivier Parcollet 2014-07-24 17:17:16 +02:00
parent 88800c903c
commit e5928de7f5
2 changed files with 20 additions and 1 deletions

View File

@ -433,7 +433,9 @@ namespace gfs {
gf(typename B::mesh_t m, target_shape_t shape = target_shape_t{}, typename B::indices_t const &ind = typename B::indices_t{}, std::string name = "") gf(typename B::mesh_t m, target_shape_t shape = target_shape_t{}, typename B::indices_t const &ind = typename B::indices_t{}, std::string name = "")
: B(std::move(m), factory::make_data(m, shape), factory::make_singularity(m, shape), typename B::symmetry_t{}, ind, name, // clean unncessary types : B(std::move(m), factory::make_data(m, shape), factory::make_singularity(m, shape), typename B::symmetry_t{}, ind, name, // clean unncessary types
typename B::evaluator_t{}) {} typename B::evaluator_t{}) {
if (this->_indices.is_empty()) this->_indices = typename B::indices_t(shape);
}
friend void swap(gf &a, gf &b) noexcept { a.swap_impl(b); } friend void swap(gf &a, gf &b) noexcept { a.swap_impl(b); }

View File

@ -83,8 +83,24 @@ namespace gfs {
std::vector<std::vector<std::string>> ind; std::vector<std::vector<std::string>> ind;
indices_2() = default; indices_2() = default;
indices_2(std::vector<std::vector<std::string>> _ind) : ind(std::move(_ind)) {} indices_2(std::vector<std::vector<std::string>> _ind) : ind(std::move(_ind)) {}
// from a size
indices_2(int L) : indices_2(arrays::mini_vector<int, 2>{L, L}) {};
// from a shape
indices_2(arrays::mini_vector<int, 2> const & shape) : ind(2) {
for (int i = 0; i < shape[0]; ++i) ind[0].push_back(std::to_string(i));
for (int i = 0; i < shape[1]; ++i) ind[1].push_back(std::to_string(i));
}
// indices from a vector<T> : L and R are the same.
template <typename T> indices_2(std::vector<T> const & _ind) : ind(2) {
for (auto const &i : _ind) ind[0].push_back(std::to_string(i));
ind[1] = ind[0];
}
bool is_empty() const { return ind.size() == 0; } bool is_empty() const { return ind.size() == 0; }
void resize(int s) { ind.resize(s);} void resize(int s) { ind.resize(s);}
@ -173,6 +189,7 @@ namespace gfs {
friend nothing operator+(nothing, nothing) { return nothing(); } friend nothing operator+(nothing, nothing) { return nothing(); }
template <typename RHS> friend void assign_from_expression(nothing &, RHS) {} template <typename RHS> friend void assign_from_expression(nothing &, RHS) {}
template<typename A> bool check_size(A) {return true;} template<typename A> bool check_size(A) {return true;}
bool is_empty() const { return false;}
}; };
inline nothing transpose(nothing) { return {};} inline nothing transpose(nothing) { return {};}