3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-26 12:31:49 +01:00

gf. wrap legendre.

This commit is contained in:
Olivier Parcollet 2014-05-22 17:56:42 +02:00
parent cfe3532c94
commit f2136f7b80
3 changed files with 86 additions and 19 deletions

View File

@ -18,13 +18,15 @@ macro (triqs_python_extension ModuleName)
# Adjust pythonpath so that pytriqs is visible and the wrap_generator too... # Adjust pythonpath so that pytriqs is visible and the wrap_generator too...
# pytriqs needed since we import modules with pure python method to extract the doc.. # pytriqs needed since we import modules with pure python method to extract the doc..
add_custom_command(OUTPUT ${wrap_name} ${converter_name} DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${ModuleName}_desc.py add_custom_command(OUTPUT ${wrap_name} ${converter_name} DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${ModuleName}_desc.py
COMMAND PYTHONPATH=${CMAKE_BINARY_DIR}/pytriqs/wrap_generator:${CMAKE_BINARY_DIR}/ ${PYTHON_INTERPRETER} ${CMAKE_CURRENT_BINARY_DIR}/${ModuleName}_desc.py ${CMAKE_SOURCE_DIR}/pytriqs/wrap_generator/wrapper.mako.cpp ${wrap_name} ${CMAKE_SOURCE_DIR}/pytriqs/wrap_generator/py_converter_wrapper.mako.hpp ${converter_name} ) COMMAND PYTHONPATH=${CMAKE_BINARY_DIR}/pytriqs/wrap_generator:${CMAKE_BINARY_DIR}/ ${PYTHON_INTERPRETER} ${CMAKE_CURRENT_BINARY_DIR}/${ModuleName}_desc.py
${CMAKE_SOURCE_DIR}/pytriqs/wrap_generator/wrapper.mako.cpp
${wrap_name}
${CMAKE_SOURCE_DIR}/pytriqs/wrap_generator/py_converter_wrapper.mako.hpp
${converter_name} )
set_property (GLOBAL APPEND PROPERTY TRIQS_PY_CONVERTERS_TARGETS "python_wrap_${ModuleName}") set_property (GLOBAL APPEND PROPERTY TRIQS_PY_CONVERTERS_TARGETS "python_wrap_${ModuleName}")
add_custom_target(python_wrap_${ModuleName} ALL DEPENDS ${wrap_name} ${converter_name}) add_custom_target(python_wrap_${ModuleName} ALL DEPENDS ${wrap_name} ${converter_name})
#//add_custom_target(${ModuleName}_converter.cpp ALL DEPENDS ${wrap_name})
add_dependencies(python_wrap_${ModuleName} py_copy ${CMAKE_CURRENT_BINARY_DIR}/${ModuleName}_desc.py ) add_dependencies(python_wrap_${ModuleName} py_copy ${CMAKE_CURRENT_BINARY_DIR}/${ModuleName}_desc.py )
add_library(${ModuleName} MODULE ${wrap_name}) add_library(${ModuleName} MODULE ${wrap_name})
@ -35,7 +37,6 @@ macro (triqs_python_extension ModuleName)
install (FILES ${converter_name} DESTINATION "include/pytriqs/converters") install (FILES ${converter_name} DESTINATION "include/pytriqs/converters")
install (TARGETS ${ModuleName} DESTINATION ${TRIQS_PYTHON_LIB_DEST}/${ARGN} ) install (TARGETS ${ModuleName} DESTINATION ${TRIQS_PYTHON_LIB_DEST}/${ARGN} )
endif (${ARGN} MATCHES "") endif (${ARGN} MATCHES "")
#set_property (GLOBAL APPEND PROPERTY DEPENDANCE_TO_ADD triqs_${NickName} )
endmacro (triqs_python_extension) endmacro (triqs_python_extension)

View File

@ -4,6 +4,7 @@ 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/pade.hpp>") module.add_include("<triqs/gfs/local/pade.hpp>")
module.add_include("<triqs/gfs/local/legendre_matsubara.hpp>")
module.add_using("namespace triqs::arrays") module.add_using("namespace triqs::arrays")
module.add_using("namespace triqs::gfs") module.add_using("namespace triqs::gfs")
module.add_using("namespace triqs::gfs::local") module.add_using("namespace triqs::gfs::local")
@ -146,6 +147,15 @@ m.add_constructor(signature = "(double beta, statistic_enum S, int n_max, mesh_k
module.add_class(m) module.add_class(m)
########################
## MeshLegendre
########################
m = make_mesh( py_type = "MeshLegendre", c_tag = "legendre", has_kind = False, is_im = True)
m.add_constructor(signature = "(double beta, statistic_enum S, int n_max=1025)")
module.add_class(m)
######################## ########################
## MeshReFreq ## MeshReFreq
######################## ########################
@ -188,7 +198,7 @@ module.add_class(m)
## Gf Generic : common to all 5 one variable gf ## Gf Generic : common to all 5 one variable gf
######################## ########################
def make_gf( py_type, c_tag, is_complex_data = True, is_im = False) : def make_gf( py_type, c_tag, is_complex_data = True, is_im = False, has_tail = True) :
data_type = "std::complex<double>" if is_complex_data else "double" data_type = "std::complex<double>" if is_complex_data else "double"
@ -232,9 +242,10 @@ def make_gf( py_type, c_tag, is_complex_data = True, is_im = False) :
getter = cfunction(calling_pattern="auto result = get_target_shape(self_c)", signature = "shape_type()"), getter = cfunction(calling_pattern="auto result = get_target_shape(self_c)", signature = "shape_type()"),
doc = "") doc = "")
g.add_property(name = "tail", if has_tail:
getter = cfunction(c_name="singularity", signature = "local::tail_view()"), g.add_property(name = "tail",
doc ="The high frequency tail") getter = cfunction(c_name="singularity", signature = "local::tail_view()"),
doc ="The high frequency tail")
g.add_property(name = "indices", g.add_property(name = "indices",
getter = cfunction(calling_pattern="auto result = self_c.indices()[0]", signature = "std::vector<std::string>()"), getter = cfunction(calling_pattern="auto result = self_c.indices()[0]", signature = "std::vector<std::string>()"),
@ -292,7 +303,7 @@ def make_gf( py_type, c_tag, is_complex_data = True, is_im = False) :
signature = "gf<%s>()"%c_tag, signature = "gf<%s>()"%c_tag,
doc = "Returns a NEW gf, with transposed data...") doc = "Returns a NEW gf, with transposed data...")
if c_tag != "imtime" : if c_tag not in [ "imtime", "legendre"] :
g.add_method(py_name = "conjugate", calling_pattern = "auto result = conj(self_c)" , signature = "gf<%s>()"%c_tag, doc = "Return a new function, conjugate of self.") g.add_method(py_name = "conjugate", calling_pattern = "auto result = conj(self_c)" , signature = "gf<%s>()"%c_tag, doc = "Return a new function, conjugate of self.")
g.number_protocol['multiply'].add_overload(calling_pattern = "*", signature = "gf<%s>(matrix<%s> x,gf<%s> y)"%(c_tag,data_type,c_tag)) #'x'), (self.c_type,'y')], rtype = self.c_type) g.number_protocol['multiply'].add_overload(calling_pattern = "*", signature = "gf<%s>(matrix<%s> x,gf<%s> y)"%(c_tag,data_type,c_tag)) #'x'), (self.c_type,'y')], rtype = self.c_type)
@ -337,6 +348,11 @@ g.add_method(py_name = "set_from_fourier",
calling_pattern = "self_c = fourier(*gt)", calling_pattern = "self_c = fourier(*gt)",
doc = """Fills self with the Fourier transform of gt""") doc = """Fills self with the Fourier transform of gt""")
g.add_method(py_name = "set_from_legendre",
signature = "void(gf_view<legendre> gl)",
calling_pattern = "self_c = legendre_to_imfreq(*gl)",
doc = """Fills self with the legendre transform of gl""")
# 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")
@ -354,11 +370,59 @@ g.add_method(py_name = "set_from_inverse_fourier",
calling_pattern = "self_c = inverse_fourier(*gw)", calling_pattern = "self_c = inverse_fourier(*gw)",
doc = """Fills self with the Inverse Fourier transform of gw""") doc = """Fills self with the Inverse Fourier transform of gw""")
g.add_method(py_name = "set_from_legendre",
signature = "void(gf_view<legendre> gl)",
calling_pattern = "self_c = legendre_to_imtime(*gl)",
doc = """Fills self with the legendre transform of gl""")
# add the call operator using the interpolation # add the call operator using the interpolation
g.add_call(signature = "matrix<double>(double tau)", doc = "G(tau) using interpolation") g.add_call(signature = "matrix<double>(double tau)", doc = "G(tau) using interpolation")
module.add_class(g) module.add_class(g)
########################
## GfLegendre
########################
# the domain
dom = class_( py_type = "GfLegendreDomain",
c_type = "legendre_domain",
c_type_absolute = "triqs::gfs::legendre_domain",
serializable= "tuple",
)
dom.add_constructor(signature = "(double beta, statistic_enum S, int n_max)")
module.add_class(dom)
g = make_gf(py_type = "GfLegendre", c_tag = "legendre", is_im = True, is_complex_data = False, has_tail =False)
g.add_method(py_name = "density",
calling_pattern = "auto result = density(self_c)",
signature = "matrix_view<double>()",
doc = "Density, as a matrix, computed from a Matsubara sum")
g.add_method(py_name = "total_density",
calling_pattern = "auto result = trace(density(self_c))",
signature = "double()",
doc = "Trace of density")
g.add_method(py_name = "set_from_imtime",
signature = "void(gf_view<imtime> gt)",
calling_pattern = "self_c = imtime_to_legendre(*gt)",
doc = """Fills self with the legendre transform of gt""")
g.add_method(py_name = "set_from_imfreq",
signature = "void(gf_view<imfreq> gw)",
calling_pattern = "self_c = imfreq_to_legendre(*gw)",
doc = """Fills self with the legendre transform of gw""")
g.add_method(py_name = "enforce_discontinuity",
signature = "void(matrix_view<double> disc)",
calling_pattern = "enforce_discontinuity(self_c, disc)",
doc = """Modify the coefficient to adjust discontinuity""")
module.add_class(g)
######################## ########################
## GfReFreq ## GfReFreq
######################## ########################
@ -373,7 +437,7 @@ g.add_method(py_name = "set_from_fourier",
g.add_method(py_name = "set_from_pade", g.add_method(py_name = "set_from_pade",
signature = "void(gf_view<imfreq> gw, int n_points = 100, double freq_offset = 0.0)", signature = "void(gf_view<imfreq> gw, int n_points = 100, double freq_offset = 0.0)",
calling_pattern = "pade(self_c,*gw,n_points, freq_offset)", calling_pattern = "pade(self_c,*gw,n_points, freq_offset)",
doc = """ TO BE WRITTEN""") doc = """TO BE WRITTEN""")
module.add_class(g) module.add_class(g)

View File

@ -173,6 +173,8 @@ namespace gfs {
}; };
inline nothing transpose(nothing) { return {};} inline nothing transpose(nothing) { return {};}
inline nothing inverse(nothing) { return {};}
inline nothing conj(nothing) { return {};}
template <typename... T> nothing slice_target(nothing, T...) { return nothing(); } template <typename... T> nothing slice_target(nothing, T...) { return nothing(); }
template <typename T> nothing operator+(nothing, T const &) { return nothing(); } template <typename T> nothing operator+(nothing, T const &) { return nothing(); }
template <typename T> nothing operator-(nothing, T const &) { return nothing(); } template <typename T> nothing operator-(nothing, T const &) { return nothing(); }