本文整理匯總了Python中simphony.cuds.primitive_cell.PrimitiveCell.for_triclinic_lattice方法的典型用法代碼示例。如果您正苦於以下問題:Python PrimitiveCell.for_triclinic_lattice方法的具體用法?Python PrimitiveCell.for_triclinic_lattice怎麽用?Python PrimitiveCell.for_triclinic_lattice使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類simphony.cuds.primitive_cell.PrimitiveCell
的用法示例。
在下文中一共展示了PrimitiveCell.for_triclinic_lattice方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_primitive_cell_for_triclinic_lattice
# 需要導入模塊: from simphony.cuds.primitive_cell import PrimitiveCell [as 別名]
# 或者: from simphony.cuds.primitive_cell.PrimitiveCell import for_triclinic_lattice [as 別名]
def test_primitive_cell_for_triclinic_lattice(self):
with self.assertRaises(ValueError):
PrimitiveCell.for_triclinic_lattice(-1, -2, -3, 0.5, 0.6, 0.7)
with self.assertRaises(ValueError):
PrimitiveCell.for_triclinic_lattice(1, 2, 3, 0, np.pi, np.pi)
with self.assertRaises(ValueError):
PrimitiveCell.for_triclinic_lattice(1, 2, 3, 0.1, 0.2, 0.8)
with self.assertRaises(ValueError):
# angles too big
PrimitiveCell.for_triclinic_lattice(1, 2, 3, 2.1, 2.1, 2.1)
cosa = np.cos(self.alpha)
cosb = np.cos(self.beta)
sinb = np.sin(self.beta)
cosg = np.cos(self.gamma)
sing = np.sin(self.gamma)
p1 = (self.a, 0, 0)
p2 = (self.b*cosg, self.b*sing, 0)
p3 = (self.c*cosb, self.c*(cosa-cosb*cosg) / sing,
self.c*np.sqrt(sinb**2 - ((cosa-cosb*cosg) / sing)**2))
pc = PrimitiveCell.for_triclinic_lattice(
self.a, self.b, self.c, self.alpha, self.beta, self.gamma)
self.assertIsInstance(pc, PrimitiveCell)
self.assertEqual(pc.bravais_lattice,
BravaisLattice.TRICLINIC)
assert_array_equal(pc.p1, p1)
assert_array_equal(pc.p2, p2)
assert_array_equal(pc.p3, p3)
示例2: make_triclinic_lattice
# 需要導入模塊: from simphony.cuds.primitive_cell import PrimitiveCell [as 別名]
# 或者: from simphony.cuds.primitive_cell.PrimitiveCell import for_triclinic_lattice [as 別名]
def make_triclinic_lattice(name, hs, angles, size, origin=(0, 0, 0)):
"""Create and return a 3D triclinic lattice.
Parameters
----------
name : str
hs : float[3]
lattice spacings in each axis direction
angles : float[3]
angles between the (conventional) unit cell edges (in radians)
size : int[3]
Number of lattice nodes in each axis direction.
origin : float[3], default value = (0, 0, 0)
lattice origin
Returns
-------
lattice : Lattice
A reference to a Lattice object.
"""
pc = PrimitiveCell.for_triclinic_lattice(
hs[0], hs[1], hs[2], angles[0], angles[1], angles[2])
return Lattice(name, pc, size, origin)
示例3: test_cell_volume
# 需要導入模塊: from simphony.cuds.primitive_cell import PrimitiveCell [as 別名]
# 或者: from simphony.cuds.primitive_cell.PrimitiveCell import for_triclinic_lattice [as 別名]
def test_cell_volume(self):
pc = PrimitiveCell.for_triclinic_lattice(1, 1, 1, np.pi/2,
np.pi/2, np.pi/2)
self.assertAlmostEqual(pc.volume, 1)