2013-07-23 19:49:42 +02:00
|
|
|
################################################################################
|
|
|
|
#
|
|
|
|
# TRIQS: a Toolbox for Research in Interacting Quantum Systems
|
|
|
|
#
|
|
|
|
# Copyright (C) 2011 by M. Aichhorn, L. Pourovskii, V. Vildosola
|
|
|
|
#
|
|
|
|
# TRIQS is free software: you can redistribute it and/or modify it under the
|
|
|
|
# terms of the GNU General Public License as published by the Free Software
|
|
|
|
# Foundation, either version 3 of the License, or (at your option) any later
|
|
|
|
# version.
|
|
|
|
#
|
|
|
|
# TRIQS is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
|
|
# details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License along with
|
|
|
|
# TRIQS. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
################################################################################
|
|
|
|
|
|
|
|
from pytriqs.archive import *
|
2017-04-05 20:58:01 +02:00
|
|
|
from pytriqs.gf import *
|
2018-01-22 23:34:20 +01:00
|
|
|
from sumk_dft import *
|
|
|
|
from converters.wien2k_converter import *
|
2015-06-17 15:13:02 +02:00
|
|
|
from pytriqs.operators.util import set_operator_structure
|
2015-12-09 15:35:51 +01:00
|
|
|
from pytriqs.utility.comparison_tests import *
|
|
|
|
from pytriqs.utility.h5diff import h5diff
|
2013-07-23 19:49:42 +02:00
|
|
|
|
2014-09-22 19:20:41 +02:00
|
|
|
# Basic input parameters
|
|
|
|
beta = 40
|
2013-07-23 19:49:42 +02:00
|
|
|
|
|
|
|
# Init the SumK class
|
2014-11-18 11:30:26 +01:00
|
|
|
SK=SumkDFT(hdf_file='SrVO3.h5',use_dft_blocks=True)
|
2013-07-23 19:49:42 +02:00
|
|
|
|
2014-11-26 16:24:02 +01:00
|
|
|
num_orbitals = SK.corr_shells[0]['dim']
|
|
|
|
l = SK.corr_shells[0]['l']
|
|
|
|
spin_names = ['up','down']
|
|
|
|
orb_names = ['%s'%i for i in range(num_orbitals)]
|
2014-09-22 19:20:41 +02:00
|
|
|
orb_hybridized = False
|
2013-07-23 19:49:42 +02:00
|
|
|
|
2015-02-10 14:27:08 +01:00
|
|
|
gf_struct = set_operator_structure(spin_names,orb_names,orb_hybridized)
|
|
|
|
glist = [ GfImFreq(indices=inner,beta=beta) for block,inner in gf_struct.iteritems()]
|
|
|
|
Sigma_iw = BlockGf(name_list = gf_struct.keys(), block_list = glist, make_copies = False)
|
2013-07-23 19:49:42 +02:00
|
|
|
|
2015-11-02 11:42:47 +01:00
|
|
|
SK.set_Sigma([Sigma_iw])
|
2015-12-09 15:35:51 +01:00
|
|
|
Gloc = SK.extract_G_loc()
|
2013-07-23 19:49:42 +02:00
|
|
|
|
2015-12-09 15:35:51 +01:00
|
|
|
if mpi.is_master_node():
|
|
|
|
with HDFArchive('srvo3_Gloc.out.h5','w') as ar:
|
|
|
|
ar['Gloc'] = Gloc[0]
|
|
|
|
|
|
|
|
if mpi.is_master_node():
|
|
|
|
h5diff("srvo3_Gloc.out.h5","srvo3_Gloc.ref.h5")
|