本文整理汇总了C++中gf_const_view类的典型用法代码示例。如果您正苦于以下问题:C++ gf_const_view类的具体用法?C++ gf_const_view怎么用?C++ gf_const_view使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了gf_const_view类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: check_input_gf
void check_input_gf(gf_const_view<GfOpts...> g, gf_const_view<GfOpts...> S) {
if(g.mesh() != S.mesh() || get_target_shape(g) != get_target_shape(S))
fatal_error("input quantity and the error-bar function S must have equivalent structure");
auto shape = get_target_shape(g);
if(shape[0] != shape[1]) fatal_error("matrix-valued input quantities must be square");
}
示例2: make_gf_from_fourier
gf<imfreq, T, S> make_gf_from_fourier(gf_const_view<imtime, T, S, E> const& gt, int n_iw = -1) {
if (n_iw == -1) n_iw = (gt.mesh().size() - 1) / 2;
auto m = gf_mesh<imfreq>{gt.mesh().domain(), n_iw};
auto gw = gf<imfreq, T, S>{m, get_target_shape(gt)};
gw() = fourier(gt);
return gw;
}
示例3: is_gf_real_in_tau
bool is_gf_real_in_tau(gf_const_view<imfreq, T, S, E> g, double tolerance = 1.e-13) {
if (g.mesh().positive_only()) return true;
using triqs::arrays::max_element; // the case real, complex is not found by ADL
for (auto const &w : g.mesh().get_positive_freq())
if (max_element(abs(conj(g(-w)) - g(w))) > tolerance) return false;
return true;
}
示例4: density
//-------------------------------------------------------
// For Imaginary Matsubara Frequency functions
// ------------------------------------------------------
arrays::matrix<dcomplex> density(gf_const_view<imfreq> g) {
if (g.mesh().positive_only())
TRIQS_RUNTIME_ERROR << "density is only implemented for g(i omega_n) with full mesh (positive and negative frequencies)";
tail_const_view t = g.singularity();
if (!t.is_decreasing_at_infinity())
TRIQS_RUNTIME_ERROR << " density computation : green Function is not as 1/omega or less !!!";
if (g.mesh().positive_only()) TRIQS_RUNTIME_ERROR << " imfreq gF : full mesh required in density computation";
auto sh = get_target_shape(g);
int N1 = sh[0], N2 = sh[1];
arrays::matrix<dcomplex> res(sh);
auto beta = g.domain().beta;
double b1 = 0, b2 = 1, b3 = -1;
auto F = [&beta](dcomplex a, double b) { return -a / (1 + exp(-beta * b)); };
for (int n1 = 0; n1 < N1; n1++)
for (int n2 = n1; n2 < N2; n2++) {
dcomplex d = t(1)(n1, n2), A = t(2)(n1, n2), B = t(3)(n1, n2);
dcomplex a1 = d - B, a2 = (A + B) / 2, a3 = (B - A) / 2;
dcomplex r = 0;
for (auto const& w : g.mesh()) r += g[w](n1, n2) - (a1 / (w - b1) + a2 / (w - b2) + a3 / (w - b3));
res(n1, n2) = r / beta + d + F(a1, b1) + F(a2, b2) + F(a3, b3);
if (n2 > n1) res(n2, n1) = conj(res(n1, n2));
}
return res;
}
示例5: make_gf_from_inverse_fourier
gf<imtime, T, S> make_gf_from_inverse_fourier(gf_const_view<imfreq, T, S, E> const& gw, int n_tau = -1) {
if (n_tau == -1) n_tau = 2*(gw.mesh().last_index() + 1) +1;
auto m = gf_mesh<imtime>{gw.mesh().domain(), n_tau};
auto gt = gf<imtime, T, S, E>{m, get_target_shape(gw)};
gt() = inverse_fourier(gw);
return gt;
}
示例6: get_tail
// compute a tail from the Legendre GF
// this is Eq. 8 of our paper
array<dcomplex, 3> get_tail(gf_const_view<legendre> gl, int order) {
auto _ = ellipsis{};
auto sh = gl.data().shape();
sh[0] = order;
array<dcomplex, 3> t{sh};
t() = 0.0;
for (int p = 0; p < order; p++)
for (auto l : gl.mesh()) t(p, _) += (triqs::utility::legendre_t(l.index(), p) / std::pow(gl.domain().beta, p)) * gl[l];
return t;
}
示例7: get_tail
// compute a tail from the Legendre GF
// this is Eq. 8 of our paper
tail_view get_tail(gf_const_view<legendre> gl, int size = 10, int omin = -1) {
auto sh = gl.data().shape().front_pop();
tail t(sh, size, omin);
t.data()() = 0.0;
for (int p=1; p<=t.order_max(); p++)
for (auto l : gl.mesh())
t(p) += (triqs::utility::legendre_t(l.index(),p)/pow(gl.domain().beta,p)) * gl[l];
return t;
}
示例8: legendre_matsubara_inverse
void legendre_matsubara_inverse(gf_view<legendre> gl, gf_const_view<imfreq> gw) {
gl() = 0.0;
// Construct a temporary imaginary-time Green's function gt
// I set Nt time bins. This is ugly, one day we must code the direct
// transformation without going through imaginary time
int Nt = 50000;
auto gt = gf<imtime>{{gw.domain(), Nt}, gw.data().shape().front_pop()};
// We first transform to imaginary time because it's been coded with the knowledge of the tails
gt() = inverse_fourier(gw);
legendre_matsubara_inverse(gl, gt());
}
示例9: change_mesh
gf<imtime> change_mesh(gf_const_view<imtime> old_gf, int new_n_tau) {
auto const& old_m = old_gf.mesh();
gf<imtime> new_gf{{old_m.domain().beta, old_m.domain().statistic, new_n_tau, old_m.kind()}, get_target_shape(old_gf)};
auto const& new_m = new_gf.mesh();
new_gf.data()() = 0;
double f = old_m.delta()/new_m.delta();
for(auto tau : old_m) new_gf[closest_mesh_pt(double(tau))] += f*old_gf[tau];
new_gf[0] *= 2.0; new_gf[new_n_tau-1] *= 2.0;
new_gf.singularity() = old_gf.singularity();
return new_gf;
}
示例10: set_input_data
void som_core::set_input_data(gf_const_view<GfOpts...> g, gf_const_view<GfOpts...> S) {
using mesh_t = typename gf_const_view<GfOpts...>::mesh_t;
auto & rhs_ = (input_data_t<mesh_t>&)rhs;
auto & error_bars_ = (input_data_t<mesh_t>&)error_bars;
auto gf_dim = get_target_shape(g)[0];
results.reserve(gf_dim);
for(int i = 0; i < gf_dim; ++i) {
rhs_.emplace_back(g.data()(range(),i,i));
error_bars_.emplace_back(S.data()(range(),i,i));
results.emplace_back(ci);
}
histograms.resize(gf_dim);
}
示例11: write
static void write(h5::group gr, gf_const_view<block_index2, Target> g) {
auto const &m0 = std::get<0>(g.mesh());
auto const &m1 = std::get<1>(g.mesh());
for (int i = 0; i < m0.size(); ++i)
for (int j = 0; j < m1.size(); ++j) h5_write(gr, m0.domain().names()[i] + "_" + m1.domain().names()[j], g._data[i][j]);
h5_write(gr, "block_names", m0.domain().names());
}
示例12: check_gf_stat
template<typename MeshType> void check_gf_stat(gf_const_view<MeshType> g,
triqs::gfs::statistic_enum expected_stat) {
if(g.domain().statistic != expected_stat)
fatal_error("expected a " + mesh_traits<MeshType>::name()
+ " Green's function with "
+ (expected_stat == Fermion ? "fermionic" : "bosonic")
+ " statistics");
}
示例13: make_gf_from_real_gf
// This function takes a g(i omega_n) on half mesh (positive omega_n) and returns a gf on the whole mesh
// using G(-i omega_n) = G(i omega_n)^* for real G(tau) functions.
template <typename T, typename S, typename E> gf<imfreq, T, S, E> make_gf_from_real_gf(gf_const_view<imfreq, T, S, E> g) {
if (!g.mesh().positive_only()) TRIQS_RUNTIME_ERROR << "gf imfreq is not for omega_n >0, real_to_complex does not apply";
auto const &dat = g.data();
auto sh = dat.shape();
int is_boson = (g.mesh().domain().statistic == Boson);
long L = sh[0];
sh[0] = 2 * sh[0] - is_boson;
array<dcomplex, std14::decay_t<decltype(dat)>::rank> new_data(sh);
auto _ = arrays::ellipsis{};
if (is_boson) new_data(L - 1, _) = dat(0, _);
int L1 = (is_boson ? L - 1 : L);
for (int u = is_boson; u < L; ++u) {
new_data(L1 + u, _) = dat(u, _);
new_data(L - 1 - u, _) = conj(dat(u, _));
}
return {gf_mesh<imfreq>{g.mesh().domain(), L}, std::move(new_data), g.singularity(), g.symmetry(), g.indices(), g.name};
}
示例14: rebinning_tau
//-------------------------------------------------------
// For Imaginary Time functions
// ------------------------------------------------------
gf<imtime> rebinning_tau(gf_const_view<imtime> const& g, int new_n_tau) {
auto const& old_m = g.mesh();
gf<imtime> new_gf{{old_m.domain().beta, old_m.domain().statistic, new_n_tau}, get_target_shape(g)};
auto const& new_m = new_gf.mesh();
new_gf.data()() = 0;
long prev_index = 0;
long norm = 0;
for (auto const & tau : old_m) {
long index = std::round((double(tau) - new_m.x_min()) / new_m.delta());
if (index == prev_index) { norm++; } else {
new_gf[index - 1] /= double(norm);
prev_index = index;
norm = 1;
}
new_gf[index] += g[tau];
}
if (norm != 1) new_gf[new_m.size() - 1] /= norm;
new_gf.singularity() = g.singularity();
return new_gf;
}
示例15: mesh
// Legendre coefficients
som_core::som_core(gf_const_view<legendre> g_l, gf_const_view<legendre> S_l,
observable_kind kind, vector<double> const& norms) :
mesh(g_l.mesh()), kind(kind), norms(make_default_norms(norms,get_target_shape(g_l)[0])),
rhs(input_data_r_t()), error_bars(input_data_r_t()) {
if(is_stat_relevant(kind)) check_gf_stat(g_l, observable_statistics(kind));
check_input_gf(g_l,S_l);
if(!is_gf_real(g_l) || !is_gf_real(S_l))
fatal_error("Legendre " + observable_name(kind) + " must be real");
gf<legendre, matrix_real_valued> g_l_real = real(g_l), S_l_real = real(S_l);
set_input_data(make_const_view(g_l_real), make_const_view(S_l_real));
}