3
0
mirror of https://github.com/triqs/dft_tools synced 2024-11-18 20:12:53 +01:00
dft_tools/doc/guide/images_scripts/Ce-gamma.py

172 lines
6.2 KiB
Python
Raw Normal View History

2014-11-18 11:30:26 +01:00
from pytriqs.applications.dft.sumk_dft import *
2013-08-07 16:40:18 +02:00
from pytriqs.applications.dft.converters.wien2k_converter import *
from pytriqs.applications.impurity_solvers.hubbard_I.hubbard_solver import Solver
2013-08-07 16:40:18 +02:00
2015-03-18 20:54:07 +01:00
lda_filename = 'Ce-gamma'
2014-03-28 23:29:06 +01:00
beta = 40
U_int = 6.00
J_hund = 0.70
2015-03-18 20:54:07 +01:00
Loops = 5 # Number of DMFT sc-loops
2013-08-07 16:40:18 +02:00
Mix = 0.7 # Mixing factor in QMC
DC_type = 0 # 0...FLL, 1...Held, 2... AMF, 3...Lichtenstein
2015-03-18 20:54:07 +01:00
DC_Mix = 1.0 # 1.0 ... all from imp; 0.0 ... all from Gloc
useBlocs = False # use bloc structure from LDA input
2013-08-07 16:40:18 +02:00
useMatrix = True # use the U matrix calculated from Slater coefficients instead of (U+2J, U, U-J)
2015-03-18 20:54:07 +01:00
chemical_potential_init=0.0 # initial chemical potential
2013-08-07 16:40:18 +02:00
2015-03-18 20:54:07 +01:00
HDFfilename = lda_filename+'.h5'
2013-08-07 16:40:18 +02:00
# Convert DMFT input:
# Can be commented after the first run
2015-03-18 20:54:07 +01:00
Converter = Wien2kConverter(filename=lda_filename)
Converter.convert_dft_input()
2013-08-07 16:40:18 +02:00
#check if there are previous runs:
previous_runs = 0
previous_present = False
if mpi.is_master_node():
ar = HDFArchive(HDFfilename,'a')
if 'iterations' in ar:
previous_present = True
previous_runs = ar['iterations']
else:
previous_runs = 0
previous_present = False
del ar
mpi.barrier()
previous_runs = mpi.bcast(previous_runs)
previous_present = mpi.bcast(previous_present)
# Init the SumK class
2015-03-18 20:54:07 +01:00
SK=SumkDFT(hdf_file=lda_filename+'.h5',use_dft_blocks=False)
2013-08-07 16:40:18 +02:00
Norb = SK.corr_shells[0]['dim']
l = SK.corr_shells[0]['l']
2013-08-07 16:40:18 +02:00
2015-03-18 20:54:07 +01:00
# Init the Hubbard-I solver:
2014-03-28 23:29:06 +01:00
S = Solver(beta = beta, l = l)
2013-08-07 16:40:18 +02:00
2015-03-18 20:54:07 +01:00
chemical_potential=chemical_potential_init
# load previous data: old self-energy, chemical potential, DC correction
2013-08-07 16:40:18 +02:00
if (previous_present):
mpi.report("Using stored data for initialisation")
if (mpi.is_master_node()):
ar = HDFArchive(HDFfilename,'a')
2015-03-18 20:54:07 +01:00
S.Sigma <<= ar['SigmaF']
2013-08-07 16:40:18 +02:00
del ar
2015-03-18 20:54:07 +01:00
things_to_load=['chemical_potential','dc_imp']
old_data=SK.load(things_to_load)
chemical_potential=old_data[0]
SK.dc_imp=old_data[1]
2013-08-07 16:40:18 +02:00
S.Sigma = mpi.bcast(S.Sigma)
2015-03-18 20:54:07 +01:00
chemical_potential=mpi.bcast(chemical_potential)
SK.dc_imp=mpi.bcast(SK.dc_imp)
2013-08-07 16:40:18 +02:00
# DMFT loop:
for Iteration_Number in range(1,Loops+1):
itn = Iteration_Number + previous_runs
# put Sigma into the SumK class:
SK.put_Sigma(Sigma_imp = [ S.Sigma ])
2013-08-07 16:40:18 +02:00
# Compute the SumK, possibly fixing mu by dichotomy
2015-03-18 20:54:07 +01:00
if SK.density_required and (Iteration_Number > 1):
chemical_potential = SK.calc_mu( precision = 0.000001 )
2013-08-07 16:40:18 +02:00
else:
2015-03-18 20:54:07 +01:00
mpi.report("No adjustment of chemical potential\nTotal density = %.3f"%SK.total_density(mu=chemical_potential))
2013-08-07 16:40:18 +02:00
# Density:
2015-03-18 20:54:07 +01:00
S.G <<= SK.extract_G_loc()[0]
2013-08-07 16:40:18 +02:00
mpi.report("Total charge of Gloc : %.6f"%S.G.total_density())
2015-03-18 20:54:07 +01:00
# calculated DC at the first run to have reasonable initial non-interacting atomic level positions
2013-08-07 16:40:18 +02:00
if ((Iteration_Number==1)and(previous_present==False)):
2015-03-18 20:54:07 +01:00
dc_value_init=U_int/2.0
dm=S.G.density()
SK.calc_dc( dm, U_interact = U_int, J_hund = J_hund, orb = 0, use_dc_formula = DC_type, use_dc_value=dc_value_init)
2013-08-07 16:40:18 +02:00
2015-03-18 20:54:07 +01:00
# calculate non-interacting atomic level positions:
2013-08-07 16:40:18 +02:00
eal = SK.eff_atomic_levels()[0]
S.set_atomic_levels( eal = eal )
# solve it:
2014-03-28 23:29:06 +01:00
S.solve(U_int = U_int, J_hund = J_hund, verbosity = 1)
2013-08-07 16:40:18 +02:00
# Now mix Sigma and G:
if ((itn>1)or(previous_present)):
if (mpi.is_master_node()and (Mix<1.0)):
2015-03-18 20:54:07 +01:00
ar = HDFArchive(HDFfilename,'r')
2013-08-07 16:40:18 +02:00
mpi.report("Mixing Sigma and G with factor %s"%Mix)
2015-03-18 20:54:07 +01:00
if ('SigmaF' in ar):
S.Sigma <<= Mix * S.Sigma + (1.0-Mix) * ar['SigmaF']
2013-08-07 16:40:18 +02:00
if ('GF' in ar):
2015-03-18 20:54:07 +01:00
S.G <<= Mix * S.G + (1.0-Mix) * ar['GF']
del ar
2013-08-07 16:40:18 +02:00
S.G = mpi.bcast(S.G)
S.Sigma = mpi.bcast(S.Sigma)
# after the Solver has finished, set new double counting:
dm = S.G.density()
2015-03-18 20:54:07 +01:00
SK.calc_dc( dm, U_interact = U_int, J_hund = J_hund, orb = 0, use_dc_formula = DC_type )
2013-08-07 16:40:18 +02:00
# correlation energy calculations:
correnerg = 0.5 * (S.G * S.Sigma).total_density()
mpi.report("Corr. energy = %s"%correnerg)
2015-03-18 20:54:07 +01:00
# store the impurity self-energy, GF as well as correlation energy in h5
2013-08-07 16:40:18 +02:00
if (mpi.is_master_node()):
2015-03-18 20:54:07 +01:00
ar = HDFArchive(HDFfilename,'a')
ar['iterations'] = itn
ar['chemical_cotential%s'%itn] = chemical_potential
ar['SigmaF'] = S.Sigma
ar['GF'] = S.G
2013-08-07 16:40:18 +02:00
ar['correnerg%s'%itn] = correnerg
ar['DCenerg%s'%itn] = SK.dc_energ
2013-08-07 16:40:18 +02:00
del ar
2015-03-18 20:54:07 +01:00
#Save essential SumkDFT data:
things_to_save=['chemical_potential','dc_energ','dc_imp']
SK.save(things_to_save)
2013-08-07 16:40:18 +02:00
if (mpi.is_master_node()):
2015-03-18 20:54:07 +01:00
print 'DC after solver: ',SK.dc_imp[0]
2013-08-07 16:40:18 +02:00
2015-03-18 20:54:07 +01:00
# print out occupancy matrix of Ce 4f
2013-08-07 16:40:18 +02:00
mpi.report("Orbital densities of impurity Green function:")
2015-03-18 20:54:07 +01:00
for s in dm:
2013-08-07 16:40:18 +02:00
mpi.report("Block %s: "%s)
2015-03-18 20:54:07 +01:00
for ii in range(len(dm[s])):
2013-08-07 16:40:18 +02:00
str = ''
2015-03-18 20:54:07 +01:00
for jj in range(len(dm[s])):
if (dm[s][ii,jj].real>0):
str += " %.4f"%(dm[s][ii,jj].real)
2013-08-07 16:40:18 +02:00
else:
2015-03-18 20:54:07 +01:00
str += " %.4f"%(dm[s][ii,jj].real)
2013-08-07 16:40:18 +02:00
mpi.report(str)
mpi.report("Total charge of impurity problem : %.6f"%S.G.total_density())
# find exact chemical potential
if (SK.density_required):
SK.chemical_potential = SK.calc_mu( precision = 0.000001 )
2015-03-18 20:54:07 +01:00
# calculate and save occupancy matrix in the Bloch basis for Wien2k charge denity recalculation
dN,d = SK.calc_density_correction(filename = lda_filename+'.qdmft')
2013-08-07 16:40:18 +02:00
mpi.report("Trace of Density Matrix: %s"%d)
2015-03-18 20:54:07 +01:00
# store correlation energy contribution to be read by Wien2ki and then included to DFT+DMFT total energy
2013-08-07 16:40:18 +02:00
if (mpi.is_master_node()):
ar = HDFArchive(HDFfilename)
itn = ar['iterations']
correnerg = ar['correnerg%s'%itn]
DCenerg = ar['DCenerg%s'%itn]
del ar
correnerg -= DCenerg[0]
2015-03-18 20:54:07 +01:00
f=open(lda_filename+'.qdmft','a')
2013-08-07 16:40:18 +02:00
f.write("%.16f\n"%correnerg)
f.close()