mirror of
https://github.com/triqs/dft_tools
synced 2025-01-12 22:18:23 +01:00
Fix and wrap set_tail_from_fit
The c++ version of the tail fit is wrapped to python. I also changed slightly the code so that when replace_by_fit is true the data is changed all the way to the end of the Matsubara axis not only on the interval where the fit was done.
This commit is contained in:
parent
b31f4a0a09
commit
d73c1cf00c
@ -3,6 +3,7 @@ from wrap_generator import *
|
|||||||
module = module_(full_name = "pytriqs.gf.local.gf", doc = "Local Green functions ...")
|
module = module_(full_name = "pytriqs.gf.local.gf", doc = "Local Green functions ...")
|
||||||
module.add_include("<triqs/gfs.hpp>")
|
module.add_include("<triqs/gfs.hpp>")
|
||||||
module.add_include("<triqs/gfs/local/functions.hpp>")
|
module.add_include("<triqs/gfs/local/functions.hpp>")
|
||||||
|
module.add_include("<triqs/gfs/local/fit_tail.hpp>")
|
||||||
module.add_include("<triqs/gfs/local/pade.hpp>")
|
module.add_include("<triqs/gfs/local/pade.hpp>")
|
||||||
module.add_include("<triqs/gfs/local/legendre_matsubara.hpp>")
|
module.add_include("<triqs/gfs/local/legendre_matsubara.hpp>")
|
||||||
module.add_using("namespace triqs::arrays")
|
module.add_using("namespace triqs::arrays")
|
||||||
@ -368,6 +369,11 @@ g.add_method(name = "set_from_legendre",
|
|||||||
calling_pattern = "self_c = legendre_to_imfreq(*gl)",
|
calling_pattern = "self_c = legendre_to_imfreq(*gl)",
|
||||||
doc = """Fills self with the legendre transform of gl""")
|
doc = """Fills self with the legendre transform of gl""")
|
||||||
|
|
||||||
|
g.add_method(name = "set_tail_from_fit",
|
||||||
|
signature = "void(tail_view known_moments, int n_moments, int n_min, int n_max, bool replace_by_fit = true)",
|
||||||
|
calling_pattern = "set_tail_from_fit(self_c, known_moments, n_moments, n_min, n_max, replace_by_fit)",
|
||||||
|
doc = """Set the tail by fitting""")
|
||||||
|
|
||||||
# Pure python methods
|
# Pure python methods
|
||||||
g.add_pure_python_method("pytriqs.gf.local._gf_imfreq.replace_by_tail")
|
g.add_pure_python_method("pytriqs.gf.local._gf_imfreq.replace_by_tail")
|
||||||
g.add_pure_python_method("pytriqs.gf.local._gf_imfreq.fit_tail")
|
g.add_pure_python_method("pytriqs.gf.local._gf_imfreq.fit_tail")
|
||||||
|
@ -92,7 +92,7 @@ namespace triqs { namespace gfs { namespace local {
|
|||||||
if (replace_by_fit) { // replace data in the fitting range by the values from the fitted tail
|
if (replace_by_fit) { // replace data in the fitting range by the values from the fitted tail
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (auto iw : gf.mesh()) { // (arrays::range(n_min,n_max+1)) {
|
for (auto iw : gf.mesh()) { // (arrays::range(n_min,n_max+1)) {
|
||||||
if ((i >= n_min) && (i <= n_max)) gf[iw] = gf.singularity().evaluate(iw);
|
if (i >= n_min) gf[iw] = gf.singularity().evaluate(iw);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user