2.7 KiB
##NOTES##
-
Routines or utilities existing in two copies, one for QE and one for upflib:
- randy in module uspp, file uspp.f90
- invmat simplified version, in module upf_invmat, file upf_invmat.f90
- capital, lowercase, isnumeric, matches, version_compare in module upf_utils, file upf_utils.f90
- errore and infomsg as upf_error, in file upf_error.f90
-
Module variables that have been (partially) duplicated:
- kinds => upf_kinds (only dp)
- constants => upf_const
- nsp in ions_base points to nsp in uspp_param
-
TO BE DONE:
-
PP files: semilocal Vnl and human-readable sections are not read, but they should: converters may make a good usage of that information How to read from a given record in fortran (without direct I/O) ? fseek, ftell, pos= identifier, stream I/O?
-
set the correct value of nsp in uspp_param when allocate_uspp is called, use it ONLY inside upflib, remove link of nsp in ions_base to uspp_param
-
nh(:) is allocated in init_uspp_dims, but maybe it should allocated together with upf(:), when upf is read? Or maybe nh should be part of upf? It is used in many many places, though!
-
Merge pseudopotential_indexes from CPV/src/pseudopot_sub.f90 with the uspp initialization in upflib (init_us_1 etc); merge qvan2b and qvan2 (requires merge of interpolation tables qrad and qradb)
-
upf_ions now contains just a function n_atom_wfc: move somewhere else?
-
upf_spinorb contains just two variables: merge into uspp? add to it the two functions spinor and sph_ind used only for spin-orbit?
-
lmaxq should be "the maximum value of L in Q functions", not "... + 1" and should be used to dimension arrays where l=0,...,L. The dimension of spherical harmonics (2*lmaxkb+1)^2 is something different and should be stored in a different variable (something like ylmdim, or maxlm)
-
Names of interpolation tables and related routines are random: CP PW new name? contains computed in betagx tab tab_beta beta(G) functions compute_betagx, dbetagx dbeta(G)/dG compute_betagx qradx qrad tab_q Q(G) for USPP/PAW init_tab_qrad dqradx dQ(G)/dG compute_qradx tab_at tab_atwfc atomic R_nl(G) init_tab_atwfc (tab_atrho atomic rho(G) to be done) (tab_vloc local potential to be done)
-
-
upflib restructuring:
- shall we keep just one src folder ? or structure it a bit more, such as
upflib/baselib all basic data structures and io
upflib/advlib advanced initializations (init_us_0,1,2) upflib/tools tools from upftools
- shall we keep just one src folder ? or structure it a bit more, such as
upflib/baselib all basic data structures and io