本文整理匯總了Python中atom.Atom.set_symbol方法的典型用法代碼示例。如果您正苦於以下問題:Python Atom.set_symbol方法的具體用法?Python Atom.set_symbol怎麽用?Python Atom.set_symbol使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類atom.Atom
的用法示例。
在下文中一共展示了Atom.set_symbol方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: from_ase_atoms
# 需要導入模塊: from atom import Atom [as 別名]
# 或者: from atom.Atom import set_symbol [as 別名]
def from_ase_atoms(self,atoms):
"""
Convert ASE Atoms object to NAPSystem object.
"""
self.a1 = np.array(atoms.cell[0])
self.a2 = np.array(atoms.cell[1])
self.a3 = np.array(atoms.cell[2])
spos = atoms.get_scaled_positions()
symbols = atoms.get_chemical_symbols()
#...initialize and remake self.specorder
self.specorder = []
for s in symbols:
if s not in self.specorder:
self.specorder.append(s)
#...first, initialize atoms array
self.atoms = []
#...append each atom from ASE-Atoms
for ia,spi in enumerate(spos):
si = symbols[ia]
ai = Atom()
sid = self.specorder.index(si)+1
ai.set_id(ia+1)
ai.set_sid(sid)
ai.set_symbol(si)
ai.set_pos(spi[0],spi[1],spi[2])
ai.set_vel(0.,0.,0.)
self.atoms.append(ai)
return
示例2: read_akr
# 需要導入模塊: from atom import Atom [as 別名]
# 或者: from atom.Atom import set_symbol [as 別名]
def read_akr(self,fname='akr0000'):
f=open(fname,'r')
# 1st: lattice constant
self.alc= float(f.readline().split()[0])
# 2nd-4th: cell vectors
for i in range(3):
data= f.readline().split()
self.a1[i]= float(data[0])
self.a2[i]= float(data[1])
self.a3[i]= float(data[2])
# 5th: num of atoms
natm= int(f.readline().split()[0])
# 9th-: atom positions
self.atoms= []
symbol = None
for i in range(natm):
data= [float(x) for x in f.readline().split()]
ai= Atom()
ai.set_sid(data[0])
ai.set_pos(data[1],data[2],data[3])
ai.set_vel(data[4],data[5],data[6])
if self.specorder:
symbol = self.specorder[ai.sid-1]
if symbol and ai.symbol != symbol:
ai.set_symbol(symbol)
self.atoms.append(ai)
f.close()
示例3: make_sc
# 需要導入模塊: from atom import Atom [as 別名]
# 或者: from atom.Atom import set_symbol [as 別名]
def make_sc(latconst=1.0):
"""
Make a cell of simple cubic structure.
"""
s= NAPSystem(specorder=_default_specorder)
#...lattice
a1= np.array([ 1.0, 0.0, 0.0 ])
a2= np.array([ 0.0, 1.0, 0.0 ])
a3= np.array([ 0.0, 0.0, 1.0 ])
s.set_lattice(latconst,a1,a2,a3)
p=[0.00, 0.00, 0.00]
atom= Atom()
atom.set_pos(p[0],p[1],p[2])
atom.set_symbol(_default_specorder[0])
s.add_atom(atom)
return s
示例4: make_bcc
# 需要導入模塊: from atom import Atom [as 別名]
# 或者: from atom.Atom import set_symbol [as 別名]
def make_bcc(latconst=1.0):
"""
Make a cell of bcc structure.
"""
s= NAPSystem(specorder=_default_specorder)
#...lattice
a1= np.array([ 1.0, 0.0, 0.0 ])
a2= np.array([ 0.0, 1.0, 0.0 ])
a3= np.array([ 0.0, 0.0, 1.0 ])
s.set_lattice(latconst,a1,a2,a3)
positions=[(0.00, 0.00, 0.00),
(0.50, 0.50, 0.50)]
for p in positions:
atom= Atom()
atom.set_pos(p[0],p[1],p[2])
atom.set_symbol(_default_specorder[0])
s.add_atom(atom)
return s
示例5: read_pmd
# 需要導入模塊: from atom import Atom [as 別名]
# 或者: from atom.Atom import set_symbol [as 別名]
def read_pmd(self,fname='pmd0000'):
f=open(fname,'r')
# 1st: lattice constant
self.alc= float(f.readline().split()[0])
# 2nd-4th: cell vectors
# for i in range(3):
# data= f.readline().split()
# self.a1[i]= float(data[0])
# self.a2[i]= float(data[1])
# self.a3[i]= float(data[2])
self.a1= np.array([float(x) for x in f.readline().split()])
self.a2= np.array([float(x) for x in f.readline().split()])
self.a3= np.array([float(x) for x in f.readline().split()])
# 5th-7th: velocity of cell vectors
tmp= f.readline().split()
tmp= f.readline().split()
tmp= f.readline().split()
# 8st: num of atoms
natm= int(f.readline().split()[0])
# 9th-: atom positions
self.atoms= []
symbol = None
for i in range(natm):
data= [float(x) for x in f.readline().split()]
ai= Atom()
ai.decode_tag(data[0])
if self.specorder:
symbol = self.specorder[ai.sid-1]
if symbol and ai.symbol != symbol:
ai.set_symbol(symbol)
ai.set_pos(data[1],data[2],data[3]) # position
ai.set_vel(data[4],data[5],data[6]) # velocity
ai.set_ekin(data[7])
ai.set_epot(data[8])
ai.set_strs(data[9],data[10],data[11],
data[12],data[13],data[14])
self.atoms.append(ai)
f.close()
示例6: print
# 需要導入模塊: from atom import Atom [as 別名]
# 或者: from atom.Atom import set_symbol [as 別名]
print('Extracting the atoms inside the new unit vectors...')
hmat= psnew.get_hmat()
hi = np.linalg.inv(hmat)
for ia,posi in enumerate(expos):
sposi = np.dot(hi,posi)
if 0.0 <= sposi[0] < 1.0 and \
0.0 <= sposi[1] < 1.0 and \
0.0 <= sposi[2] < 1.0:
atom = Atom()
symbol = exsymbols[ia]
print('{0:5d} {1:s}'.format(ia,symbol)
+' {0:12.5f} {1:12.5f} {2:12.5f}'.format(sposi[0],
sposi[1],
sposi[2]))
atom.set_symbol(symbol)
atom.set_pos(sposi[0],sposi[1],sposi[2])
psnew.add_atom(atom)
tmp = None
#tmp = raw_input('Input periodic shift vector if you want: ')
tmp = ' 0.5, 0.0, 0.5'
if tmp:
shift = [ float(x) for x in tmp.split(',')]
for a in psnew.atoms:
a.pos[0] += shift[0]
a.pos[1] += shift[1]
a.pos[2] += shift[2]
psnew.assign_pbc()
psnew.write_POSCAR(infile+'.new')
print('Check '+infile+'.new')
示例7: read_dump
# 需要導入模塊: from atom import Atom [as 別名]
# 或者: from atom.Atom import set_symbol [as 別名]
def read_dump(self,fname="dump"):
f=open(fname,'r')
mode= 'None'
ixyz= 0
iatm= 0
symbol = None
self.atoms= []
self.alc= 1.0
for line in f.readlines():
if 'ITEM: NUMBER OF ATOMS' in line:
mode= 'NUMBER OF ATOMS'
continue
elif 'ITEM: BOX BOUNDS' in line:
mode= 'BOX BOUNDS'
continue
elif 'ITEM: ATOMS' in line:
mode= 'ATOMS'
continue
if mode == 'NUMBER OF ATOMS':
natm= int(line.split()[0])
elif mode == 'BOX BOUNDS':
data = line.split()
if ixyz == 0:
xlo_bound= float(data[0])
xhi_bound= float(data[1])
if len(data) > 2:
xy = float(data[2])
elif ixyz == 1:
ylo_bound= float(line.split()[0])
yhi_bound= float(line.split()[1])
if len(data) > 2:
xz = float(data[2])
elif ixyz == 2:
zlo_bound= float(line.split()[0])
zhi_bound= float(line.split()[1])
if len(data) > 2:
yz = float(data[2])
ixyz += 1
if ixyz > 2:
xlo = xlo_bound -min(0.0,xy,xz,xy+yz)
xhi = xhi_bound -max(0.0,xy,xz,xy+yz)
ylo = ylo_bound -min(0.0,yz)
yhi = yhi_bound -max(0.0,yz)
zlo = zlo_bound
zhi = zhi_bound
self.a1 = np.array([xhi-xlo,xy,xz],dtype=float)
self.a2 = np.array([0.0,yhi-ylo,yz],dtype=float)
self.a3 = np.array([0.0,0.0,zhi-zlo],dtype=float)
hmat = self.get_hmat()
hmati= np.linalg.inv(hmat)
elif mode == 'ATOMS':
if iatm < natm:
data= line.split()
ai= Atom()
ai.set_sid(int(data[1]))
if self.specorder:
symbol = self.specorder[ai.sid-1]
if symbol and ai.symbol != symbol:
ai.set_symbol(symbol)
x0= float(data[2])
y0= float(data[3])
z0= float(data[4])
x = hmati[0,0]*x0 +hmati[0,1]*y0 +hmati[0,2]*z0
y = hmati[1,0]*x0 +hmati[1,1]*y0 +hmati[1,2]*z0
z = hmati[2,0]*x0 +hmati[2,1]*y0 +hmati[2,2]*z0
x = self._pbc(x)
y = self._pbc(y)
z = self._pbc(z)
ai.set_pos(x,y,z)
ai.set_vel(0.0,0.0,0.0)
self.atoms.append(ai)
iatm += 1
# print self.alc
# print self.a1[:]
# print self.a2[:]
# print self.a3[:]
f.close()