3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-20 01:21:52 +01:00

Replaced options EMIN, EMAX with EWINDOW

It did not make much sense to keep two independent options to
define an energy range. Now the energy window is directly defined
by two floats.
This commit is contained in:
Oleg E. Peil 2015-11-11 18:58:38 +01:00
parent 5ec3e881cd
commit 453c8531c9
2 changed files with 18 additions and 5 deletions

View File

@ -62,8 +62,7 @@ class ConfigParameters:
self.gr_required = { self.gr_required = {
'shells': ('shells', lambda s: map(int, s.split())), 'shells': ('shells', lambda s: map(int, s.split())),
'emin': ('emin', float), 'ewindow': ('ewindow', self.parse_energy_window)}
'emax': ('emax', float)}
self.gr_optional = { self.gr_optional = {
'normalize' : ('normalize', self.parse_string_logical, True), 'normalize' : ('normalize', self.parse_string_logical, True),
@ -133,6 +132,21 @@ class ConfigParameters:
assert first_char in 'tf', "Logical parameters should be given by either 'True' or 'False'" assert first_char in 'tf', "Logical parameters should be given by either 'True' or 'False'"
return first_char == 't' return first_char == 't'
################################################################################
#
# parse_energy_window()
#
################################################################################
def parse_energy_window(self, par_str):
"""
Energy window is given by two floats, with the first one being smaller
than the second one.
"""
ftmp = map(float, par_str.split())
assert len(ftmp) == 2, "EWINDOW must be specified by exactly two floats"
assert ftmp[0] < ftmp[1], "The first float in EWINDOW must be smaller than the second one"
return tuple(ftmp)
################################################################################ ################################################################################
# #
# parse_string_tmatrix() # parse_string_tmatrix()

View File

@ -187,8 +187,7 @@ class ProjectorGroup:
""" """
Constructor Constructor
""" """
self.emin = gr_pars['emin'] self.emin, self.emax = gr_pars['ewindow']
self.emax = gr_pars['emax']
self.ishells = gr_pars['shells'] self.ishells = gr_pars['shells']
self.ortho = gr_pars['normalize'] self.ortho = gr_pars['normalize']
self.normion = gr_pars['normion'] self.normion = gr_pars['normion']
@ -319,7 +318,6 @@ class ProjectorShell:
self.lm2 = (self.lorb+1)**2 self.lm2 = (self.lorb+1)**2
self.ndim = self.extract_tmatrices(sh_pars) self.ndim = self.extract_tmatrices(sh_pars)
print " Dimension of subspace:", self.ndim
# if self.tmatrix is None: # if self.tmatrix is None:
# self.ndim = self.lm2 - self.lm1 # self.ndim = self.lm2 - self.lm1
# else: # else:
@ -620,6 +618,7 @@ def generate_plo(conf_pars, el_struct):
print " Shell : %s"%(pshell.user_index) print " Shell : %s"%(pshell.user_index)
print " Orbital l : %i"%(pshell.lorb) print " Orbital l : %i"%(pshell.lorb)
print " Number of ions: %i"%(len(pshell.ion_list)) print " Number of ions: %i"%(len(pshell.ion_list))
print " Dimension : %i"%(pshell.ndim)
pshells.append(pshell) pshells.append(pshell)
pgroups = [] pgroups = []