当前位置: 首页>>代码示例>>Python>>正文


Python Vasp.get_number_of_bands方法代码示例

本文整理汇总了Python中ase.calculators.vasp.Vasp.get_number_of_bands方法的典型用法代码示例。如果您正苦于以下问题:Python Vasp.get_number_of_bands方法的具体用法?Python Vasp.get_number_of_bands怎么用?Python Vasp.get_number_of_bands使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ase.calculators.vasp.Vasp的用法示例。


在下文中一共展示了Vasp.get_number_of_bands方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。

示例1: range

# 需要导入模块: from ase.calculators.vasp import Vasp [as 别名]
# 或者: from ase.calculators.vasp.Vasp import get_number_of_bands [as 别名]
               encut = 500.00,
               gga = "PS",
	       kpts=kpts,
               nsw = 0,
               ismear = 0, 
	       sigma = 0.01,
	       reciprocal = True)
zns.set_calculator(calc_band)
print "Band Calc"
bands = zns.get_potential_energy()

# Get the band energies across the Brillouin zone
e_kn = np.array([calc_band.get_eigenvalues(k) for k in range(len(kpts))])
# Get Fermi energy
ef = calc_band.get_fermi_level()
nbands = calc_band.get_number_of_bands()

# Plotting time
e_kn -= ef
emin = e_kn.min() - 1.0
emax = e_kn[:, nbands-1].max() + 1.0

# Plot the energy Vs k-point for each band
nelect = calc_band.get_number_of_electrons()
for n in range(nbands):
# Choose colour based on valence or conduction
    for n in range(nbands):
	if n < nelect/2:
	    plt.plot(x, e_kn[len(ibzkpts):len(kpts), n],color='#800000')
	else:
	    plt.plot(x, e_kn[len(ibzkpts):len(kpts), n],color='#228B22')
开发者ID:WMD-group,项目名称:ASE-Tutorials,代码行数:33,代码来源:GaNBands.py

示例2: abs

# 需要导入模块: from ase.calculators.vasp import Vasp [as 别名]
# 或者: from ase.calculators.vasp.Vasp import get_number_of_bands [as 别名]
            algo = 'Fast',
            ismear= 0,
            sigma = 1.,
            istart = 0,
            lwave = False,
            lcharg = False)

co.set_calculator(calc)
en = co.get_potential_energy()
assert abs(en + 14.918933) < 1e-4

# Secondly, check that restart from the previously created VASP output works

calc2 = Vasp(restart=True)
co2 = calc2.get_atoms()

# Need tolerance of 1e-14 because VASP itself changes coordinates
# slightly between reading POSCAR and writing CONTCAR even if no ionic
# steps are made.
assert array_almost_equal(co.positions, co2.positions, 1e-14)

assert en - co2.get_potential_energy() == 0.
assert array_almost_equal(calc.get_stress(co), calc2.get_stress(co2))
assert array_almost_equal(calc.get_forces(co), calc2.get_forces(co2))
assert array_almost_equal(calc.get_eigenvalues(), calc2.get_eigenvalues())
assert calc.get_number_of_bands() == calc2.get_number_of_bands()
assert calc.get_xc_functional() == calc2.get_xc_functional()

# Cleanup
calc.clean()
开发者ID:JConwayAWT,项目名称:PGSS14CC,代码行数:32,代码来源:vasp_co.py


注:本文中的ase.calculators.vasp.Vasp.get_number_of_bands方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。