2015-08-10 11:32:08 +02:00
|
|
|
|
2015-11-18 15:46:58 +01:00
|
|
|
import os
|
|
|
|
import rpath
|
|
|
|
_rpath = os.path.dirname(rpath.__file__) + '/'
|
|
|
|
|
2015-08-10 11:32:08 +02:00
|
|
|
import numpy as np
|
2016-03-10 16:52:37 +01:00
|
|
|
import applications.dft.converters.plovasp.vaspio as vaspio
|
|
|
|
import applications.dft.converters.plovasp.elstruct as elstruct
|
2016-03-10 12:24:05 +01:00
|
|
|
from applications.dft.converters.plovasp.inpconf import ConfigParameters
|
|
|
|
from applications.dft.converters.plovasp.proj_shell import ProjectorShell
|
|
|
|
from applications.dft.converters.plovasp.proj_group import ProjectorGroup
|
2015-08-10 11:32:08 +02:00
|
|
|
import mytest
|
|
|
|
|
|
|
|
################################################################################
|
|
|
|
#
|
|
|
|
# TestSelectBands
|
|
|
|
#
|
|
|
|
################################################################################
|
|
|
|
class TestSelectBands(mytest.MyTestCase):
|
|
|
|
"""
|
|
|
|
Function:
|
|
|
|
|
2015-11-18 15:46:58 +01:00
|
|
|
def ProjectorGroup.select_bands(eigvals)
|
2015-08-10 11:32:08 +02:00
|
|
|
|
|
|
|
Scenarios:
|
|
|
|
- compare output for a correct input
|
|
|
|
- **if** emin > max(eigvals) **raise** Exception
|
|
|
|
- **if** emax > min(eigvals) **raise** Exception
|
|
|
|
"""
|
2015-11-18 15:46:58 +01:00
|
|
|
def setUp(self):
|
|
|
|
conf_file = _rpath + 'simple.cfg'
|
|
|
|
self.pars = ConfigParameters(conf_file)
|
|
|
|
self.pars.parse_input()
|
|
|
|
vasp_data = vaspio.VaspData(_rpath + 'simple/')
|
|
|
|
self.el_struct = elstruct.ElectronicStructure(vasp_data)
|
2015-08-10 11:32:08 +02:00
|
|
|
|
|
|
|
efermi = vasp_data.doscar.efermi
|
2015-11-18 15:46:58 +01:00
|
|
|
self.eigvals = vasp_data.eigenval.eigs - efermi
|
|
|
|
|
|
|
|
self.proj_sh = ProjectorShell(self.pars.shells[0], vasp_data.plocar.plo, vasp_data.plocar.proj_params, 0)
|
2015-11-19 16:01:05 +01:00
|
|
|
self.proj_gr = ProjectorGroup(self.pars.groups[0], [self.proj_sh], self.eigvals)
|
2015-11-18 15:46:58 +01:00
|
|
|
|
|
|
|
# Scenario 1
|
|
|
|
def test_correct(self):
|
|
|
|
ib_win, nb_min, nb_max = self.proj_gr.select_bands(self.eigvals)
|
2015-08-10 11:32:08 +02:00
|
|
|
|
|
|
|
nb_min_exp = 3
|
2015-11-18 15:46:58 +01:00
|
|
|
nb_max_exp = 8
|
|
|
|
ib_win_exp = np.array([[[3, 8]], [[3, 7]], [[3, 7]], [[3, 7]], [[3, 7]], [[3, 7]], [[3, 7]], [[3, 4]]])
|
2015-08-10 11:32:08 +02:00
|
|
|
|
|
|
|
self.assertEqual(nb_min, nb_min_exp)
|
|
|
|
self.assertEqual(nb_max, nb_max_exp)
|
|
|
|
self.assertEqual(ib_win, ib_win_exp)
|
|
|
|
|
|
|
|
# Scenario 2
|
|
|
|
def test_emin_too_large(self):
|
2015-11-18 15:46:58 +01:00
|
|
|
self.proj_gr.emin = 20.0
|
|
|
|
self.proj_gr.emax = 25.0
|
|
|
|
with self.assertRaisesRegexp(Exception, "No bands inside the window"):
|
|
|
|
ib_win, nb_min, nb_max = self.proj_gr.select_bands(self.eigvals)
|
2015-08-10 11:32:08 +02:00
|
|
|
|
|
|
|
# Scenario 3
|
|
|
|
def test_emax_too_small(self):
|
2015-11-18 15:46:58 +01:00
|
|
|
self.proj_gr.emin = -50.0
|
|
|
|
self.proj_gr.emax = -55.0
|
2015-08-10 11:32:08 +02:00
|
|
|
with self.assertRaisesRegexp(Exception, "Energy window does not overlap"):
|
2015-11-18 15:46:58 +01:00
|
|
|
ib_win, nb_min, nb_max = self.proj_gr.select_bands(self.eigvals)
|
2015-08-10 11:32:08 +02:00
|
|
|
|
|
|
|
|