mirror of
https://github.com/triqs/dft_tools
synced 2025-01-12 22:18:23 +01:00
39edb2f846
- Make more general constructors for the gf.
gf( mesh, target_shape_t)
- remove the old make_gf for the basic gf.
- 2 var non generic gf removed.
- clean evaluator
- add tensor_valued
- add a simple vertex test.
- clean specialisation
- Fix bug introduced in 1906dc3
- forgot to resize the gf in new version of operator =
- Fix make_singularity in gf.hpp
- clean resize in operator =
- update h5 read/write for block gf
- changed a bit the general trait to save *all* the gf.
- allows a more general specialization, then a correct for blocks
- NOT FINISHED : need to save the block indice for python.
How to reread ?
Currently it read the blocks names and reconstitute the mesh from it.
Is it sufficient ?
- clean block constructors
- block constructors simplest possible : an int for the number of blocks
- rest in free factories.
- fixed the generic constructor from GfType for the regular type :
only enable iif GfType is ImmutableGreenFunction
- multivar. fix linear index in C, and h5 format
- linear index now correctly flatten in C mode
(was in fortran mode), using a simple reverse of the tuple in the folding.
- fix the h5 read write of the multivar fonctions
in order to write an array on dimension # variables + dim_target
i.e. without flattening the indices of the meshes.
Easier for later data analysis, e.g. in Python.
- merge matrix/tensor_valued. improve factories
- matrix_valued now = tensor_valued<2>
(simplifies generic code for h5).
- factories_one_var -> factories : this is the generic case ...
only a few specialization, code is simpler.
- clef expression call with rvalue for *this
- generalize matrix_proxy to tensor and clean
- clean exception catch in tests
- exception catching catch in need in test
because the silly OS X does not print anything, just "exception occurred".
Very convenient for the developer...
- BUT, one MUST add return 1, or the make test will *pass* !!
- --> systematically replace the catch by a macro TRIQS_CATCH_AND_ABORT
which return a non zero error code.
- exception : curry_and_fourier which does not work at this stage
(mesh incompatible).
- gf: clean draft of gf 2 times
- comment the python interface for the moment.
- rm useless tests
55 lines
2.4 KiB
Cython
55 lines
2.4 KiB
Cython
cdef extern from "triqs/gfs/legendre.hpp" namespace "triqs::gfs" :
|
|
|
|
cdef cppclass legendre_domain :
|
|
size_t Nmax
|
|
double beta
|
|
statistic_enum statistic
|
|
legendre_domain ()
|
|
|
|
cdef cppclass mesh_legendre "triqs::gfs::gf_mesh<triqs::gfs::legendre>" :
|
|
mesh_legendre ()
|
|
mesh_legendre (mesh_legendre &)
|
|
legendre_domain & domain()
|
|
long size()
|
|
bint operator == (mesh_legendre &)
|
|
|
|
cdef mesh_legendre make_mesh_legendre "triqs::gfs::gf_mesh<triqs::gfs::legendre>" (double beta, statistic_enum S, size_t n_leg)
|
|
#cdef mesh_legendre make_mesh_legendre "triqs::gfs::gf_factories<triqs::gfs::legendre>::make_mesh" (double beta, statistic_enum S, size_t n_leg)
|
|
|
|
cdef cppclass gf_legendre "triqs::python_tools::cython_proxy<triqs::gfs::gf_view<triqs::gfs::legendre>>" :
|
|
gf_legendre()
|
|
gf_legendre(gf_legendre &)
|
|
gf_legendre(mesh_legendre, array_view[double, THREE], nothing, nothing) #except +
|
|
void operator << (gf_legendre &)
|
|
mesh_legendre mesh()
|
|
array_view[double, THREE] data()
|
|
|
|
cdef extern from "triqs/gfs/legendre.hpp" :
|
|
cdef void h5_write (h5_group, char *, gf_legendre &)
|
|
|
|
cdef extern from "triqs/utility/serialization.hpp" :
|
|
cdef std_string boost_serialize "triqs::serialize" (gf_legendre &)
|
|
cdef void boost_unserialize_into "triqs::deserialize_into_view" (std_string, gf_legendre &)
|
|
|
|
# Python -> C
|
|
cdef gf_legendre as_gf_legendre(g) except +
|
|
|
|
# C -> Python
|
|
cdef make_GfLegendre(gf_legendre x, indices_pack=*, name=*)
|
|
|
|
############### Blocks of Im Time #########################
|
|
|
|
cdef extern from "triqs/gfs/block.hpp" namespace "triqs::gfs" :
|
|
|
|
cdef cppclass gf_block_legendre "triqs::python_tools::cython_proxy<triqs::gfs::gf_view<triqs::gfs::block_index,triqs::gfs::gf<triqs::gfs::legendre>>>" :
|
|
gf_block_legendre()
|
|
gf_legendre & operator [](int)
|
|
discrete_mesh & mesh()
|
|
|
|
cdef gf_block_legendre make_gf_block_legendre "triqs::gfs::make_block_gf_view_from_vector<triqs::gfs::gf<triqs::gfs::legendre>>" (vector[gf_legendre] &)
|
|
#cdef gf_block_legendre make_gf_block_legendre "triqs::gfs::make_gf_view<triqs::gfs::block_index,triqs::gfs::gf<triqs::gfs::legendre>>" ( vector[gf_legendre] &)
|
|
|
|
cdef gf_block_legendre as_gf_block_legendre (G) except +
|
|
cdef make_BlockGfLegendre (gf_block_legendre G, block_indices_pack=*, name=*)
|
|
|