Python 画沿着高对称性的能带图

将能带图沿着高对称性处理为二维数组形式,然后依次画点连线,为了美观,而需要自己加线

import numpy as np
import matplotlib.pylab as plt

eig_vbm= -1.3286 # fermi energy level in scf output for metals
eig = np.load('eig.npy')
eig = eig - eig_vbm
nks = 111
nbnd = 25
ymin=-80
ymax=10
lw=0.5 # line width

for i in range(nbnd):
    line1=plt.plot(np.arange(0,nks), eig[:,i],color='grey',linewidth=lw)

# 只画第15条
#line1=plt.plot(np.arange(0,nks), eig[:,14]-eig_vbm,color='grey',linewidth=lw)
vline=[0,40,70,110]
#vline=dline
for i in range(len(vline)):
    plt.axvline(x=vline[i], ymin=ymin, ymax=ymax,linewidth=lw,color='black')
plt.xlim([0,nks-1]) # 201 points
plt.ylim([ymin,ymax])

plt.ylabel(r'E (eV)',fontsize=16)
plt.xticks((0,40,70,110), (r'${\Gamma}$', 'M', 'K', r'${\Gamma}$'))

plt.ylim([-7,3])
plt.show()

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值