mirror of
https://github.com/triqs/dft_tools
synced 2024-12-31 08:35:50 +01:00
[doc] updates
This commit is contained in:
parent
1a48a8afe1
commit
9f08ec1d80
@ -1,5 +1,7 @@
|
|||||||
.. index:: DFT+DMFT calculation
|
.. index:: DFT+DMFT calculation
|
||||||
|
|
||||||
|
.. highlight:: python
|
||||||
|
|
||||||
.. _DFTDMFTmain:
|
.. _DFTDMFTmain:
|
||||||
|
|
||||||
The DFT+DMFT calculation
|
The DFT+DMFT calculation
|
||||||
@ -20,64 +22,93 @@ to get the local quantities used in DMFT. It is initialized by::
|
|||||||
from pytriqs.applications.dft.sumk_dft import *
|
from pytriqs.applications.dft.sumk_dft import *
|
||||||
SK = SumkDFT(hdf_file = filename)
|
SK = SumkDFT(hdf_file = filename)
|
||||||
|
|
||||||
The only necessary parameter is the filename of the hdf5 archive. In addition, there are some optional parameters:
|
|
||||||
|
|
||||||
* `mu`: The chemical potential at initialization. This value is only used if no other value is found in the hdf5 archive. The default value is 0.0.
|
This is the reference for the function:
|
||||||
* `h_field`: External magnetic field. The default value is 0.0.
|
|
||||||
* `use_dft_blocks`: If true, the structure of the density matrix is analysed at initialisation, and non-zero matrix elements
|
|
||||||
are identified. The DMFT calculation is then restricted to these matrix elements, yielding a more efficient solution of the
|
|
||||||
local interaction problem. Degeneracies in orbital and spin space are also identified and stored for later use. The default value is `False`.
|
|
||||||
* `dft_data`, `symmcorr_data`, `parproj_data`, `symmpar_data`, `bands_data`: These string variables define the subgroups in the hdf5 archive,
|
|
||||||
where the corresponding information is stored. The default values are consistent with those in :ref:`interfacetowien`.
|
|
||||||
|
|
||||||
At initialisation, the necessary data is read from the hdf5 file. If a calculation is restarted based on a previous hdf5 file, information on
|
.. function:: SumkDFT(hdf_file, h_field = 0.0, use_dft_blocks = False, dft_data = 'dft_input', symmcorr_data = 'dft_symmcorr_input', parproj_data = 'dft_parproj_input', symmpar_data = 'dft_symmpar_input', bands_data = 'dft_bands_input', transp_data = 'dft_transp_input', misc_data = 'dft_misc_input')
|
||||||
degenerate shells, the block structure of the density matrix, the chemical potential, and double counting correction is also read in.
|
|
||||||
|
The parameters needed to initialise SumkDFT as as follows (with any default variables as shown above):
|
||||||
|
|
||||||
|
========================= ==================== ===========================================================================
|
||||||
|
Name Type Meaning
|
||||||
|
========================= ==================== ===========================================================================
|
||||||
|
hdf_file String Name of the main hdf5 file containing converted dft information.
|
||||||
|
h_field Scalar External magnetic field.
|
||||||
|
use_dft_blocks Boolean Analyse the structure of the density matrix at initialisation,
|
||||||
|
and identify non-zero matrix elements.
|
||||||
|
The DMFT calculation is then restricted to these matrix elements,
|
||||||
|
yielding a more efficient solution of the local interaction problem.
|
||||||
|
Degeneracies in orbital and spin space are also identified and stored for later use.
|
||||||
|
dft_data String hdf5 subgroup containing required DFT data.
|
||||||
|
symmcorr_data String hdf5 subgroup containing correlated shell symmetry data.
|
||||||
|
parproj_data String hdf5 subgroup containing partial projector data.
|
||||||
|
symmpar_data String hdf5 subgroup containing non-correlated shell symmetry data.
|
||||||
|
bands_data String hdf5 subgroup containing DFT band data.
|
||||||
|
transp_data String hdf5 subgroup containing optics/transport data.
|
||||||
|
misc_data String hdf5 subgroup containing miscellaneous DFT data.
|
||||||
|
========================= ==================== ===========================================================================
|
||||||
|
|
||||||
.. index:: Multiband solver
|
.. index:: Multiband solver
|
||||||
|
|
||||||
Setting up the Multi-Band Solver
|
Setting up the Multi-Band Solver
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
There is a module that helps setting up the multiband CTQMC solver. It is loaded and initialized by::
|
The next step is to setup the impurity solver.
|
||||||
|
For more details here, see the `CTHYB <http://ipht.cea.fr/triqs/1.2/applications/cthyb/>`_ documentation.
|
||||||
|
|
||||||
from pytriqs.applications.dft.solver_multiband import *
|
.. This is initialised as follows::
|
||||||
S = SolverMultiBand(beta, n_orb, gf_struct = SK.gf_struct_solver[0], map=SK.map[0])
|
..
|
||||||
|
.. from pytriqs.applications.impurity_solvers.cthyb import *
|
||||||
The necessary parameters are the inverse temperature `beta`, the Coulomb interaction `U_interact`, the Hund's rule coupling `J_hund`,
|
.. beta = 40.0
|
||||||
and the number of orbitals `n_orb`. There are again several optional parameters that allow the tailoring of the local Hamiltonian to
|
.. gf_struct = SK.gf_struct_solver[0]
|
||||||
specific needs. They are:
|
.. S = Solver(beta=beta, gf_struct=gf_struct)
|
||||||
|
..
|
||||||
* `gf_struct`: The block structure of the local density matrix given in the format calculated by :class:`SumkDFT`.
|
.. The solver method is called later by this statement::
|
||||||
* `map`: If `gf_struct` is given as parameter, `map` also must be given. This is the mapping from the block structure to a general
|
..
|
||||||
up/down structure.
|
.. S.solve(h_loc=h_loc, **p)
|
||||||
|
..
|
||||||
The solver method is called later by this statement::
|
.. where `p` represents the solve parameters.
|
||||||
|
..
|
||||||
S.solve(U_interact,J_hund,use_spinflip=False,use_matrix=True,
|
.. There is a module that helps setting up the multiband CTQMC solver. It is loaded and initialized by::
|
||||||
l=2,T=None, dim_reps=None, irep=None, n_cycles =10000,
|
..
|
||||||
length_cycle=200,n_warmup_cycles=1000)
|
.. from pytriqs.applications.dft.solver_multiband import *
|
||||||
|
.. S = SolverMultiBand(beta, n_orb, gf_struct = SK.gf_struct_solver[0], map=SK.map[0])
|
||||||
The parameters for the Coulomb interaction `U_interact` and the Hund's coupling `J_hund` are necessary input parameters. The rest are optional
|
..
|
||||||
parameters for which default values are set. Generally, they should be reset for the problem at hand. Here is a description of the parameters:
|
.. The necessary parameters are the inverse temperature `beta`, the Coulomb interaction `U_interact`, the Hund's rule coupling `J_hund`,
|
||||||
|
.. and the number of orbitals `n_orb`. There are again several optional parameters that allow the tailoring of the local Hamiltonian to
|
||||||
* `use_matrix`: If `True`, the interaction matrix is calculated from Slater integrals, which are computed from `U_interact` and
|
.. specific needs. They are:
|
||||||
`J_hund`. Otherwise, a Kanamori representation is used. Attention: We define the intraorbital interaction as
|
..
|
||||||
`U_interact`, the interorbital interaction for opposite spins as `U_interact-2*J_hund`, and interorbital for equal spins as
|
.. * `gf_struct`: The block structure of the local density matrix given in the format calculated by :class:`SumkDFT`.
|
||||||
`U_interact-3*J_hund`.
|
.. * `map`: If `gf_struct` is given as parameter, `map` also must be given. This is the mapping from the block structure to a general
|
||||||
* `T`: The matrix that transforms the interaction matrix from spherical harmonics to a symmetry-adapted basis. Only effective for Slater
|
.. up/down structure.
|
||||||
parametrisation, i.e. `use_matrix=True`.
|
..
|
||||||
* `l`: The orbital quantum number. Again, only effective for Slater parametrisation, i.e. `use_matrix=True`.
|
.. The solver method is called later by this statement::
|
||||||
* `use_spinflip`: If `True`, the full rotationally-invariant interaction is used. Otherwise, only density-density terms are
|
..
|
||||||
kept in the local Hamiltonian.
|
.. S.solve(U_interact,J_hund,use_spinflip=False,use_matrix=True,
|
||||||
* `dim_reps`: If only a subset of the full d-shell is used as correlated orbtials, one can specify here the dimensions of all the subspaces
|
.. l=2,T=None, dim_reps=None, irep=None, n_cycles =10000,
|
||||||
of the d-shell, i.e. t2g and eg. Only effective for Slater parametrisation.
|
.. length_cycle=200,n_warmup_cycles=1000)
|
||||||
* `irep`: The index in the list `dim_reps` of the subset that is used. Only effective for Slater parametrisation.
|
..
|
||||||
* `n_cycles`: Number of CTQMC cycles (a sequence of moves followed by a measurement) per core. The default value of 10000 is the minimum, and generally should be increased.
|
.. The parameters for the Coulomb interaction `U_interact` and the Hund's coupling `J_hund` are necessary input parameters. The rest are optional
|
||||||
* `length_cycle`: Number of CTQMC moves per one cycle.
|
.. parameters for which default values are set. Generally, they should be reset for the problem at hand. Here is a description of the parameters:
|
||||||
* `n_warmup_cycles`: Number of initial CTQMC cycles before measurements start. Usually of order of 10000, sometimes needs to be increased significantly.
|
..
|
||||||
|
.. * `use_matrix`: If `True`, the interaction matrix is calculated from Slater integrals, which are computed from `U_interact` and
|
||||||
Most of above parameters can be taken directly from the :class:`SumkDFT` class, without defining them by hand. We will see a specific example
|
.. `J_hund`. Otherwise, a Kanamori representation is used. Attention: We define the intraorbital interaction as
|
||||||
at the end of this tutorial.
|
.. `U_interact`, the interorbital interaction for opposite spins as `U_interact-2*J_hund`, and interorbital for equal spins as
|
||||||
|
.. `U_interact-3*J_hund`.
|
||||||
|
.. * `T`: The matrix that transforms the interaction matrix from spherical harmonics to a symmetry-adapted basis. Only effective for Slater
|
||||||
|
.. parametrisation, i.e. `use_matrix=True`.
|
||||||
|
.. * `l`: The orbital quantum number. Again, only effective for Slater parametrisation, i.e. `use_matrix=True`.
|
||||||
|
.. * `use_spinflip`: If `True`, the full rotationally-invariant interaction is used. Otherwise, only density-density terms are
|
||||||
|
.. kept in the local Hamiltonian.
|
||||||
|
.. * `dim_reps`: If only a subset of the full d-shell is used as correlated orbtials, one can specify here the dimensions of all the subspaces
|
||||||
|
.. of the d-shell, i.e. t2g and eg. Only effective for Slater parametrisation.
|
||||||
|
.. * `irep`: The index in the list `dim_reps` of the subset that is used. Only effective for Slater parametrisation.
|
||||||
|
.. * `n_cycles`: Number of CTQMC cycles (a sequence of moves followed by a measurement) per core. The default value of 10000 is the minimum, and generally should be increased.
|
||||||
|
.. * `length_cycle`: Number of CTQMC moves per one cycle.
|
||||||
|
.. * `n_warmup_cycles`: Number of initial CTQMC cycles before measurements start. Usually of order of 10000, sometimes needs to be increased significantly.
|
||||||
|
..
|
||||||
|
.. Most of above parameters can be taken directly from the :class:`SumkDFT` class, without defining them by hand. We will see a specific example
|
||||||
|
.. at the end of this tutorial.
|
||||||
|
|
||||||
|
|
||||||
.. index:: DFT+DMFT loop, one-shot calculation
|
.. index:: DFT+DMFT loop, one-shot calculation
|
||||||
@ -93,15 +124,13 @@ set up the loop over DMFT iterations and the self-consistency condition::
|
|||||||
|
|
||||||
SK.put_Sigma(Sigma_imp = [ S.Sigma ]) # Put self energy to the SumK class
|
SK.put_Sigma(Sigma_imp = [ S.Sigma ]) # Put self energy to the SumK class
|
||||||
chemical_potential = SK.calc_mu() # calculate the chemical potential for the given density
|
chemical_potential = SK.calc_mu() # calculate the chemical potential for the given density
|
||||||
S.G << SK.extract_G_loc()[0] # extract the local Green function
|
S.G_iw << SK.extract_G_loc()[0] # extract the local Green function
|
||||||
S.G0 << inverse(S.Sigma + inverse(S.G)) # finally get G0, the input for the Solver
|
S.G0_iw << inverse(S.Sigma_iw + inverse(S.G_iw)) # finally get G0, the input for the Solver
|
||||||
|
|
||||||
S.solve(U_interact,J_hund,use_spinflip=False,use_matrix=True, # now solve the impurity problem
|
S.solve(h_loc=h_loc, **p) # now solve the impurity problem
|
||||||
l=2,T=None, dim_reps=None, irep=None, n_cycles =10000,
|
|
||||||
length_cycle=200,n_warmup_cycles=1000)
|
|
||||||
|
|
||||||
dm = S.G.density() # Density matrix of the impurity problem
|
dm = S.G_iw.density() # Density matrix of the impurity problem
|
||||||
SK.calc_dc( dm, U_interact = U, J_hund = J, use_dc_formula = 0) # Set the double counting term
|
SK.calc_dc(dm, U_interact=U, J_hund=J, orb=0, use_dc_formula=dc_type) # Set the double counting term
|
||||||
SK.save(['chemical_potential','dc_imp','dc_energ']) # Save data in the hdf5 archive
|
SK.save(['chemical_potential','dc_imp','dc_energ']) # Save data in the hdf5 archive
|
||||||
|
|
||||||
These basic steps are enough to set up the basic DMFT Loop. For a detailed description of the :class:`SumkDFT` routines,
|
These basic steps are enough to set up the basic DMFT Loop. For a detailed description of the :class:`SumkDFT` routines,
|
||||||
@ -120,8 +149,8 @@ At the end of the calculation, we can save the Greens function and self energy i
|
|||||||
import pytriqs.utility.mpi as mpi
|
import pytriqs.utility.mpi as mpi
|
||||||
if mpi.is_master_node():
|
if mpi.is_master_node():
|
||||||
ar = HDFArchive("YourDFTDMFTcalculation.h5",'w')
|
ar = HDFArchive("YourDFTDMFTcalculation.h5",'w')
|
||||||
ar["G"] = S.G
|
ar["G"] = S.G_iw
|
||||||
ar["Sigma"] = S.Sigma
|
ar["Sigma"] = S.Sigma_iw
|
||||||
|
|
||||||
This is it!
|
This is it!
|
||||||
|
|
||||||
|
175
doc/advanced.rst
175
doc/advanced.rst
@ -9,9 +9,11 @@ First, we load the necessary modules::
|
|||||||
|
|
||||||
from pytriqs.applications.dft.sumk_dft import *
|
from pytriqs.applications.dft.sumk_dft import *
|
||||||
from pytriqs.applications.dft.converters.wien2k_converter import *
|
from pytriqs.applications.dft.converters.wien2k_converter import *
|
||||||
from pytriqs.applications.dft.solver_multiband import *
|
|
||||||
from pytriqs.gf.local import *
|
from pytriqs.gf.local import *
|
||||||
from pytriqs.archive import *
|
from pytriqs.archive import HDFArchive
|
||||||
|
from pytriqs.operators.hamiltonians import *
|
||||||
|
from pytriqs.applications.impurity_solvers.cthyb import *
|
||||||
|
|
||||||
|
|
||||||
Then we define some parameters::
|
Then we define some parameters::
|
||||||
|
|
||||||
@ -20,19 +22,19 @@ Then we define some parameters::
|
|||||||
J = 0.65
|
J = 0.65
|
||||||
beta = 40
|
beta = 40
|
||||||
loops = 10 # Number of DMFT sc-loops
|
loops = 10 # Number of DMFT sc-loops
|
||||||
mix = 0.8 # Mixing factor of Sigma after solution of the AIM
|
sigma_mix = 0.8 # Mixing factor of Sigma after solution of the AIM
|
||||||
Delta_mix = 1.0 # Mixing factor of Delta as input for the AIM
|
delta_mix = 1.0 # Mixing factor of Delta as input for the AIM
|
||||||
dc_type = 1 # DC type: 0 FLL, 1 Held, 2 AMF
|
dc_type = 1 # DC type: 0 FLL, 1 Held, 2 AMF
|
||||||
use_blocks = True # use bloc structure from DFT input
|
use_blocks = True # use bloc structure from DFT input
|
||||||
use_matrix = False # True: Slater parameters, False: Kanamori parameters U+2J, U, U-J
|
|
||||||
use_spinflip = False # use the full rotational invariant interaction?
|
|
||||||
prec_mu = 0.0001
|
prec_mu = 0.0001
|
||||||
qmc_cycles = 20000
|
|
||||||
length_cycle = 200
|
|
||||||
warming_iterations = 2000
|
|
||||||
|
|
||||||
|
# Solver parameters
|
||||||
|
p = {}
|
||||||
|
p["length_cycle"] = 200
|
||||||
|
p["n_warmup_cycles"] = 2000
|
||||||
|
p["n_cycles"] = 20000
|
||||||
|
|
||||||
Most of these parameters are self-explaining. The first, `dft_filename`, gives the filename of the input files.
|
Most of these parameters are self-explanatory. The first, `dft_filename`, gives the filename of the input files.
|
||||||
The next step, as described in the previous section, is to convert the input files::
|
The next step, as described in the previous section, is to convert the input files::
|
||||||
|
|
||||||
Converter = Wien2kConverter(filename=dft_filename, repacking=True)
|
Converter = Wien2kConverter(filename=dft_filename, repacking=True)
|
||||||
@ -46,104 +48,117 @@ from scratch::
|
|||||||
previous_runs = 0
|
previous_runs = 0
|
||||||
previous_present = False
|
previous_present = False
|
||||||
if mpi.is_master_node():
|
if mpi.is_master_node():
|
||||||
ar = HDFArchive(dft_filename+'.h5','a')
|
f = HDFArchive(dft_filename+'.h5','a')
|
||||||
|
if 'dmft_output' in f:
|
||||||
|
ar = f['dmft_output']
|
||||||
if 'iterations' in ar:
|
if 'iterations' in ar:
|
||||||
previous_present = True
|
previous_present = True
|
||||||
previous_runs = ar['iterations']
|
previous_runs = ar['iterations']
|
||||||
del ar
|
else:
|
||||||
|
f.create_group('dmft_output')
|
||||||
|
del f
|
||||||
previous_runs = mpi.bcast(previous_runs)
|
previous_runs = mpi.bcast(previous_runs)
|
||||||
previous_present = mpi.bcast(previous_present)
|
previous_present = mpi.bcast(previous_present)
|
||||||
# if previous runs are present, no need for recalculating the bloc structure:
|
|
||||||
calc_blocs = use_blocks and (not previous_present)
|
|
||||||
|
|
||||||
Now we can use all this information to initialise the :class:`SumkDFT` class::
|
Now we can use all this information to initialise the :class:`SumkDFT` class::
|
||||||
|
|
||||||
SK=SumkDFT(hdf_file=dft_filename+'.h5',use_dft_blocks=calc_blocs)
|
SK = SumkDFT(hdf_file=dft_filename+'.h5',use_dft_blocks=use_blocks)
|
||||||
|
|
||||||
If there was a previous run, we know already about the block structure, and therefore `UseDFTBlocs` is set to `False`.
|
|
||||||
The next step is to initialise the Solver::
|
The next step is to initialise the Solver::
|
||||||
|
|
||||||
Norb = SK.corr_shells[0]['dim']
|
n_orb = SK.corr_shells[0]['dim']
|
||||||
l = SK.corr_shells[0]['l']
|
l = SK.corr_shells[0]['l']
|
||||||
S = SolverMultiBand(beta=beta,n_orb=Norb,gf_struct=SK.gf_struct_solver[0],map=SK.map[0])
|
spin_names = ["up","down"]
|
||||||
|
orb_names = [i for i in range(n_orb)]
|
||||||
As we can see, many options of the solver are set by properties of the :class:`SumkDFT` class, so we don't have
|
# Use GF structure determined by DFT blocks
|
||||||
to set them manually.
|
gf_struct = SK.gf_struct_solver[0]
|
||||||
|
# Construct U matrix for density-density calculations
|
||||||
|
Umat, Upmat = U_matrix_kanamori(n_orb=n_orb, U_int=U, J_hund=J)
|
||||||
|
# Construct Hamiltonian and solver
|
||||||
|
h_loc = h_loc_density(spin_names, orb_names, map_operator_structure=SK.sumk_to_solver[0], U=Umat, Uprime=Upmat, H_dump="H.txt")
|
||||||
|
S = Solver(beta=beta, gf_struct=gf_struct)
|
||||||
|
|
||||||
If there are previous runs stored in the hdf5 archive, we can now load the self energy
|
If there are previous runs stored in the hdf5 archive, we can now load the self energy
|
||||||
of the last iteration::
|
of the last iteration::
|
||||||
|
|
||||||
if (previous_present):
|
if previous_present:
|
||||||
if (mpi.is_master_node()):
|
if mpi.is_master_node():
|
||||||
ar = HDFArchive(dft_filename+'.h5','a')
|
S.Sigma_iw << HDFArchive(dft_filename+'.h5','a')['dmft_output']['Sigma_iw']
|
||||||
S.Sigma << ar['SigmaImFreq']
|
chemical_potential,dc_imp,dc_energ = SK.load(['chemical_potential','dc_imp','dc_energ'])
|
||||||
|
S.Sigma_iw << mpi.bcast(S.Sigma_iw)
|
||||||
|
SK.set_mu(chemical_potential)
|
||||||
|
SK.set_dc(dc_imp,dc_energ)
|
||||||
|
|
||||||
|
The self-energy is broadcast from the master node to the slave nodes. Also, the
|
||||||
|
last saved chemical potential and double counting values are read in and set.
|
||||||
|
|
||||||
|
Now we can go to the definition of the self-consistency step. It consists again
|
||||||
|
of the basic steps discussed in the previous section, with some additional
|
||||||
|
refinement::
|
||||||
|
|
||||||
|
for iteration_number in range(1,loops+1):
|
||||||
|
if mpi.is_master_node(): print "Iteration = ", iteration_number
|
||||||
|
|
||||||
|
SK.symm_deg_gf(S.Sigma_iw,orb=0) # symmetrise Sigma
|
||||||
|
SK.put_Sigma(Sigma_imp = [ S.Sigma_iw ]) # put Sigma into the SumK class
|
||||||
|
chemical_potential = SK.calc_mu( precision = prec_mu ) # find the chemical potential for given density
|
||||||
|
S.G_iw << SK.extract_G_loc()[0] # calc the local Green function
|
||||||
|
mpi.report("Total charge of Gloc : %.6f"%S.G_iw.total_density())
|
||||||
|
|
||||||
|
# Init the DC term and the real part of Sigma, if no previous runs found:
|
||||||
|
if (iteration_number==1 and previous_present==False):
|
||||||
|
dm = S.G_iw.density()
|
||||||
|
SK.calc_dc(dm, U_interact = U, J_hund = J, orb = 0, use_dc_formula = dc_type)
|
||||||
|
S.Sigma_iw << SK.dc_imp[0]['up'][0,0]
|
||||||
|
|
||||||
|
# Calculate new G0_iw to input into the solver:
|
||||||
|
if mpi.is_master_node():
|
||||||
|
# We can do a mixing of Delta in order to stabilize the DMFT iterations:
|
||||||
|
S.G0_iw << S.Sigma_iw + inverse(S.G_iw)
|
||||||
|
ar = HDFArchive(dft_filename+'.h5','a')['dmft_output']
|
||||||
|
if (iteration_number>1 or previous_present):
|
||||||
|
mpi.report("Mixing input Delta with factor %s"%delta_mix)
|
||||||
|
Delta = (delta_mix * delta(S.G0_iw)) + (1.0-delta_mix) * ar['Delta_iw']
|
||||||
|
S.G0_iw << S.G0_iw + delta(S.G0_iw) - Delta
|
||||||
|
ar['Delta_iw'] = delta(S.G0_iw)
|
||||||
|
S.G0_iw << inverse(S.G0_iw)
|
||||||
del ar
|
del ar
|
||||||
S.Sigma = mpi.bcast(S.Sigma)
|
|
||||||
|
|
||||||
The last command is the broadcasting of the self energy from the master node to the slave nodes.
|
S.G0_iw << mpi.bcast(S.G0_iw)
|
||||||
Now we can go to the definition of the self-consistency step. It consists again of the basic steps discussed in the
|
|
||||||
previous section, with some additional refinement::
|
|
||||||
|
|
||||||
for iteration_number in range(1,loops+1) :
|
|
||||||
|
|
||||||
SK.symm_deg_gf(S.Sigma,orb=0) # symmetrise Sigma
|
|
||||||
SK.put_Sigma(Sigma_imp = [ S.Sigma ]) # put Sigma into the SumK class:
|
|
||||||
|
|
||||||
chemical_potential = SK.calc_mu( precision = prec_mu ) # find the chemical potential
|
|
||||||
S.G << SK.extract_G_loc()[0] # calculation of the local Green function
|
|
||||||
mpi.report("Total charge of Gloc : %.6f"%S.G.total_density())
|
|
||||||
|
|
||||||
if ((iteration_number==1)and(previous_present==False)):
|
|
||||||
# Init the DC term and the real part of Sigma, if no previous run was found:
|
|
||||||
dm = S.G.density()
|
|
||||||
SK.calc_dc( dm, U_interact = U, J_hund = J, orb = 0, use_dc_formula = dc_type)
|
|
||||||
S.Sigma << SK.dc_imp[0]['up'][0,0]
|
|
||||||
|
|
||||||
S.G0 << inverse(S.Sigma + inverse(S.G))
|
|
||||||
|
|
||||||
# Solve the impurity problem:
|
# Solve the impurity problem:
|
||||||
S.solve(U_interact=U,J_hund=J,use_spinflip=use_spinflip,use_matrix=use_matrix,
|
S.solve(h_loc=h_loc, **p)
|
||||||
l=l,T=SK.T[0], dim_reps=SK.dim_reps[0], irep=2, n_cycles=qmc_cycles,
|
|
||||||
length_cycle=length_cycle,n_warmup_cycles=warming_iterations)
|
|
||||||
|
|
||||||
# solution done, do the post-processing:
|
# Solved. Now do post-processing:
|
||||||
mpi.report("Total charge of impurity problem : %.6f"%S.G.total_density())
|
mpi.report("Total charge of impurity problem : %.6f"%S.G_iw.total_density())
|
||||||
|
|
||||||
S.Sigma <<(inverse(S.G0)-inverse(S.G))
|
# Now mix Sigma and G with factor sigma_mix, if wanted:
|
||||||
# Solve the impurity problem:
|
if (iteration_number>1 or previous_present):
|
||||||
S.solve(U_interact=U,J_hund=J,use_spinflip=use_spinflip,use_matrix=use_matrix,
|
if mpi.is_master_node():
|
||||||
l=l,T=SK.T[0], dim_reps=SK.dim_reps[0], irep=2, n_cycles=qmc_cycles,
|
ar = HDFArchive(dft_filename+'.h5','a')['dmft_output']
|
||||||
length_cycle=length_cycle,n_warmup_cycles=warming_iterations)
|
mpi.report("Mixing Sigma and G with factor %s"%sigma_mix)
|
||||||
|
S.Sigma_iw << sigma_mix * S.Sigma_iw + (1.0-sigma_mix) * ar['Sigma_iw']
|
||||||
# solution done, do the post-processing:
|
S.G_iw << sigma_mix * S.G_iw + (1.0-sigma_mix) * ar['G_iw']
|
||||||
mpi.report("Total charge of impurity problem : %.6f"%S.G.total_density())
|
|
||||||
|
|
||||||
S.Sigma <<(inverse(S.G0)-inverse(S.G))
|
|
||||||
|
|
||||||
# Now mix Sigma and G with factor Mix, if wanted:
|
|
||||||
if ((iteration_number>1) or (previous_present)):
|
|
||||||
if (mpi.is_master_node()):
|
|
||||||
ar = HDFArchive(dft_filename+'.h5','a')
|
|
||||||
mpi.report("Mixing Sigma and G with factor %s"%mix)
|
|
||||||
S.Sigma << mix * S.Sigma + (1.0-mix) * ar['Sigma']
|
|
||||||
S.G << mix * S.G + (1.0-mix) * ar['GF']
|
|
||||||
del ar
|
del ar
|
||||||
S.G = mpi.bcast(S.G)
|
S.G_iw << mpi.bcast(S.G_iw)
|
||||||
S.Sigma = mpi.bcast(S.Sigma)
|
S.Sigma_iw << mpi.bcast(S.Sigma_iw)
|
||||||
|
|
||||||
# Write the final Sigma and G to the hdf5 archive:
|
# Write the final Sigma and G to the hdf5 archive:
|
||||||
if (mpi.is_master_node()):
|
if mpi.is_master_node():
|
||||||
ar = HDFArchive(dft_filename+'.h5','a')
|
ar = HDFArchive(dft_filename+'.h5','a')['dmft_output']
|
||||||
ar['iterations'] = previous_runs + iteration_number
|
if previous_runs: iteration_number += previous_runs
|
||||||
ar['Sigma'] = S.Sigma
|
ar['iterations'] = iteration_number
|
||||||
ar['GF'] = S.G
|
ar['G_0'] = S.G0_iw
|
||||||
|
ar['G_tau'] = S.G_tau
|
||||||
|
ar['G_iw'] = S.G_iw
|
||||||
|
ar['Sigma_iw'] = S.Sigma_iw
|
||||||
del ar
|
del ar
|
||||||
|
|
||||||
# Now set new double counting:
|
# Set the new double counting:
|
||||||
dm = S.G.density()
|
dm = S.G_iw.density() # compute the density matrix of the impurity problem
|
||||||
SK.calc_dc( dm, U_interact = U, J_hund = J, orb = 0, use_dc_formula = dc_type)
|
SK.calc_dc(dm, U_interact = U, J_hund = J, orb = 0, use_dc_formula = dc_type)
|
||||||
|
|
||||||
#Save stuff:
|
# Save stuff into the dft_output group of hdf5 archive in case of rerun:
|
||||||
SK.save(['chemical_potential','dc_imp','dc_energ'])
|
SK.save(['chemical_potential','dc_imp','dc_energ'])
|
||||||
|
|
||||||
This is all we need for the DFT+DMFT calculation. At the end, all results are stored in the hdf5 output file.
|
This is all we need for the DFT+DMFT calculation. At the end, all results are stored in the hdf5 output file.
|
||||||
|
@ -2,13 +2,14 @@
|
|||||||
The interface
|
The interface
|
||||||
=============
|
=============
|
||||||
|
|
||||||
|
The basic function of the interface to the Wien2k program package is to take
|
||||||
The basic function of the interface to the Wien2k program package is
|
the output of the program that constructs the projected local orbitals
|
||||||
to take the output of the program that constructs the projected local
|
(:program:`dmftproj`, for documentation see
|
||||||
orbitals (:program:`dmftproj`, for documentation see :download:`TutorialDmftproj.pdf <TutorialDmftproj.pdf>`), and to store all the necessary information into
|
:download:`TutorialDmftproj.pdf <TutorialDmftproj.pdf>`),
|
||||||
an hdf5 file. This latter file is then used to do the DMFT calculation. The
|
and to store all the necessary information into an hdf5 file. This latter file
|
||||||
reason for this structure is that this enables the user to have everything
|
is then used to do the DMFT calculation. The reason for this structure is that
|
||||||
that is necessary to reproduce the calculation in one single hdf5 archive.
|
this enables the user to have everything that is necessary to reproduce the
|
||||||
|
calculation in one single hdf5 archive.
|
||||||
|
|
||||||
.. index:: Interface to Wien2k
|
.. index:: Interface to Wien2k
|
||||||
|
|
||||||
@ -31,17 +32,20 @@ calculation for TiO, the :program:`Wien2k` naming convention is that all files a
|
|||||||
:file:`TiO.*`, so you would give `filename = "TiO"`. The constructor opens
|
:file:`TiO.*`, so you would give `filename = "TiO"`. The constructor opens
|
||||||
an hdf5 archive, named :file:`material_of_interest.h5`, where all the data is stored.
|
an hdf5 archive, named :file:`material_of_interest.h5`, where all the data is stored.
|
||||||
|
|
||||||
There are three optional parameters to the Constructor:
|
These are the parameters to the Constructor:
|
||||||
|
|
||||||
* `dft_subgrp`: We store all data in subgroups of the hdf5 archive. For the main data
|
========================= ============================ ===========================================================================
|
||||||
that is needed for the DMFT loop, we use the subgroup specified by this optional parameter.
|
Name Type, Default Meaning
|
||||||
The default value `dft_input` is used as the subgroup name.
|
========================= ============================ ===========================================================================
|
||||||
* `symmcorr_subgrp`: In this subgroup we store all the data for applying the symmetry
|
filename String Material being studied, corresponding to the :program:`Wien2k` file names.
|
||||||
operations in the DMFT loop. The default value is `dft_symmcorr_input`.
|
The constructor stores the data in the hdf5 archive :file:`material_of_interest.h5`.
|
||||||
* `repacking`: If true, and the hdf5 file already exists, the system command :program:`h5repack`
|
dft_subgrp String, dft_input hdf5 subgroup containing required DFT data
|
||||||
is invoked. This command ensures a minimal file size of the hdf5
|
symmcorr_subgrp String, dft_symmcorr_input hdf5 subgroup containing all necessary data to apply
|
||||||
file. The default value is `False`. If you wish to use this, ensure
|
the symmetry operations in the DMFT loop
|
||||||
that :program:`h5repack` is in your path variable!
|
repacking Boolean, False Does the hdf5 file already exist and should the :program:`h5repack` be
|
||||||
|
invoked to ensures a minimal archive file size?
|
||||||
|
Note that the :program:`h5repack` must be in your path variable!
|
||||||
|
========================= ============================ ===========================================================================
|
||||||
|
|
||||||
After initialising the interface module, we can now convert the input text files into the
|
After initialising the interface module, we can now convert the input text files into the
|
||||||
hdf5 archive by::
|
hdf5 archive by::
|
||||||
@ -70,8 +74,12 @@ of :program:`Wien2k`, you have to use::
|
|||||||
This reads the files :file:`material_of_interest.parproj` and :file:`material_of_interest.sympar`.
|
This reads the files :file:`material_of_interest.parproj` and :file:`material_of_interest.sympar`.
|
||||||
Again, there are two optional parameters
|
Again, there are two optional parameters
|
||||||
|
|
||||||
* `parproj_subgrp`: The subgroup for partial projectors data. The default value is `dft_parproj_input`.
|
========================= ============================ ===========================================================================
|
||||||
* `symmpar_subgrp`: The subgroup for symmetry operations data. The default value is `dft_symmpar_input`.
|
Name Type, Default Meaning
|
||||||
|
========================= ============================ ===========================================================================
|
||||||
|
parproj_subgrp String, dft_parproj_input hdf5 subgroup containing partial projectors data.
|
||||||
|
symmpar_subgrp String, dft_symmpar_input hdf5 subgroup containing symmetry operations data.
|
||||||
|
========================= ============================ ===========================================================================
|
||||||
|
|
||||||
Another routine of the class allows to read the input for plotting the momentum-resolved
|
Another routine of the class allows to read the input for plotting the momentum-resolved
|
||||||
spectral function. It is done by::
|
spectral function. It is done by::
|
||||||
|
@ -9,7 +9,7 @@ All the data is stored using the hdf5 standard, as described also in the documen
|
|||||||
hdf5 data format
|
hdf5 data format
|
||||||
----------------
|
----------------
|
||||||
|
|
||||||
In order to be used with the DMFT routines, the following data needs to be provided in the hdf5 file. It contains a lot of information in order to perform DMFT calculations for all kinds of situations, e.g. d-p Hamiltonians, more than one correlated atomic shell, or using symmetry operations for the k-summation. We store all data in subgroups of the hdf5 arxive:
|
In order to be used with the DMFT routines, the following data needs to be provided in the hdf5 file. It contains a lot of information in order to perform DMFT calculations for all kinds of situations, e.g. d-p Hamiltonians, more than one correlated atomic shell, or using symmetry operations for the k-summation. We store all data in subgroups of the hdf5 archive:
|
||||||
|
|
||||||
:program:`Main data`: There needs to be one subgroup for the main data of the calculation. The default name of this group is `dft_input`. Its contents are
|
:program:`Main data`: There needs to be one subgroup for the main data of the calculation. The default name of this group is `dft_input`. Its contents are
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user