當前位置: 首頁>>代碼示例>>Python>>正文


Python pymatgen.Molecule方法代碼示例

本文整理匯總了Python中pymatgen.Molecule方法的典型用法代碼示例。如果您正苦於以下問題:Python pymatgen.Molecule方法的具體用法?Python pymatgen.Molecule怎麽用?Python pymatgen.Molecule使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pymatgen的用法示例。


在下文中一共展示了pymatgen.Molecule方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: create_bond_feature

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def create_bond_feature(self, mol, bid: int, eid: int):
        """
        Create information for a bond for a pair of atoms that are not actually bonded

        Args:
            mol (pybel.Molecule): Molecule being featurized
            bid (int): Index of atom beginning of the bond
            eid (int): Index of atom at the end of the bond
        """
        a1 = mol.OBMol.GetAtom(bid + 1)
        a2 = mol.OBMol.GetAtom(eid + 1)
        same_ring = mol.OBMol.AreInSameRing(a1, a2)
        return {"a_idx": bid,
                "b_idx": eid,
                "bond_type": 0,
                "same_ring": True if same_ring else False,
                "spatial_distance": a1.GetDistance(a2)} 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:19,代碼來源:molecule.py

示例2: _get_chiral_centers

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def _get_chiral_centers(self, mol):
        """
        Use RDKit to find the chiral centers with CIP(R/S) label

        This provides the absolute stereochemistry.  The chiral label obtained
        from pybabel and rdkit.mol.getchiraltag is relative positions of the bonds as provided

        Args:
            mol (Molecule): Molecule to asses
        Return:
            (dict): Keys are the atom index and values are the CIP label
        """
        mol_rdk = self._get_rdk_mol(mol, 'smiles')
        if mol_rdk is None:
            # Conversion to RDKit has failed
            return {}
        else:
            chiral_cc = Chem.FindMolChiralCenters(mol_rdk)
            return dict(chiral_cc) 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:21,代碼來源:molecule.py

示例3: get_pymatgen_molecule

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def get_pymatgen_molecule(self):
        """Create a Molecule instance of the pymatgen library

        .. warning:: The `pymatgen library <http://pymatgen.org>`_ is imported
            locally in this function and will raise
            an ``ImportError`` exception, if it is not installed.

        Args:
            None

        Returns:
            :class:`pymatgen.core.structure.Molecule`:
        """
        from pymatgen import Molecule
        return Molecule(self['atom'].values,
                        self.loc[:, ['x', 'y', 'z']].values) 
開發者ID:mcocdawc,項目名稱:chemcoord,代碼行數:18,代碼來源:_cartesian_class_io.py

示例4: mol_Oh

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def mol_Oh(central, ligand, scale):
    """ 
    Return a perfect octahedra as a mg.Molecule object.

    Args:
        central: (string) Name of the central atom
        ligand: (string) Name of ligand atoms
        scale: (float) length of central-ligand distance

    Returns
        mg.Molecule object
    """
    species = [mg.Element(central)] + 6 * [mg.Element(ligand)]
    template = [[ 0., 0., 0.],
                [ 1., 0., 0.],
                [-1., 0., 0.],
                [ 0., 1., 0.],
                [ 0.,-1., 0.],
                [ 0., 0., 1.],
                [ 0., 0.,-1.]]
    coords = [[scale * xi for xi in coord] for coord in template]
    return mg.Molecule(species, coords) 
開發者ID:gVallverdu,項目名稱:myScripts,代碼行數:24,代碼來源:distorsion.py

示例5: paramVector

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def paramVector(mol, radius = 10.):
    """ 
    Build the vector representing the site in the parameters' space.

    Args:
        * mol : mg.Molecule object of the central atom plus the ligand atoms.
              : The first atom must be the central atom
        * radius : cut off distance for neighbors of the central atoms

    Returns:
        * a numpy array. The n first distances are the central to all ligand
        distances sorted from the smallest to the largest. The m following
        distances are all ligand - ligand distances sorted from the smallest to
        the largest.
    """
    # distances central atom to ligand
    d_central = [di for n, di in mol.get_neighbors(mol[0], radius)]
    # all distances
    dm = mol.distance_matrix
    d_all = [di for line in np.triu(dm) for di in line if di > 0.]
    return np.array(sorted(d_central) + sorted(d_all)) 
開發者ID:gVallverdu,項目名稱:myScripts,代碼行數:23,代碼來源:distorsion.py

示例6: parse_symmetry

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def parse_symmetry(pos):
    mol = Molecule(['C']*len(pos), pos)
    try:
        symbol = PointGroupAnalyzer(mol, tolerance=0.1).sch_symbol
    except:
        symbol = 'N/A'
    return symbol 
開發者ID:qzhu2017,項目名稱:PyXtal,代碼行數:9,代碼來源:01-compare_optalg.py

示例7: get_ase_mol

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def get_ase_mol(molname):
    """convert ase molecule to pymatgen style"""
    ase_mol = molecule(molname)
    pos = ase_mol.get_positions()
    symbols = ase_mol.get_chemical_symbols()
    return(Molecule(symbols, pos)) 
開發者ID:qzhu2017,項目名稱:PyXtal,代碼行數:8,代碼來源:from_ase_molecule.py

示例8: get_nn_info

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def get_nn_info(self, molecule: Molecule, n: int) -> List[Dict]:
        site = molecule[n]
        siw = []
        for i, s in enumerate(molecule):
            if i != n:
                siw.append({'site': s,
                            'image': None,
                            'weight': site.distance(s),
                            'site_index': i})
        return siw 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:12,代碼來源:local_env.py

示例9: setUpClass

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def setUpClass(cls):
        cls.structure = Structure.from_file(os.path.join(MODULE_DIR, 'cifs', 'BaTiO3_mp-2998_computed.cif'))
        cls.molecule = Molecule(['C', 'O', 'O'], [[0, 0, 0], [-1, 0, 0], [1, 0, 0]])
        cls.mall = MinimumDistanceNNAll(4)
        cls.aapair = AllAtomPairs() 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:7,代碼來源:test_local_env.py

示例10: test_simple_molecule_graph

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def test_simple_molecule_graph(self):
        mol = Molecule(['C', 'H', 'O'], [[0, 0, 0], [1, 0, 0], [2, 0, 0]])
        graph = SimpleMolGraph().convert(mol)
        self.assertListEqual(to_list(graph['atom']), [6, 1, 8])
        self.assertTrue(np.allclose(graph['bond'], [1, 2, 1, 1, 2, 1]))
        self.assertListEqual(to_list(graph['index1']), [0, 0, 1, 1, 2, 2])
        self.assertListEqual(to_list(graph['index2']), [1, 2, 0, 2, 0, 1]) 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:9,代碼來源:test_molecule.py

示例11: mol_from_pymatgen

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def mol_from_pymatgen(mol: Molecule):
    """
    Args:
        mol(Molecule)
    """
    mol = pybel.Molecule(BabelMolAdaptor(mol).openbabel_mol)
    mol.make3D()
    return mol 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:10,代碼來源:molecule.py

示例12: get_graphs_within_cutoff

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def get_graphs_within_cutoff(structure: StructureOrMolecule,
                             cutoff: float = 5.0,
                             numerical_tol: float = 1e-8) \
        -> Tuple[np.ndarray, np.ndarray, np.ndarray, np.ndarray]:
    """
    Get graph representations from structure within cutoff
    Args:
        structure (pymatgen Structure or molecule)
        cutoff (float): cutoff radius
        numerical_tol (float): numerical tolerance

    Returns:
        center_indices, neighbor_indices, images, distances
    """
    if isinstance(structure, Structure):
        lattice_matrix = np.ascontiguousarray(
            np.array(structure.lattice.matrix), dtype=float)
        pbc = np.array([1, 1, 1], dtype=int)
    elif isinstance(structure, Molecule):
        lattice_matrix = np.array(
            [[1000.0, 0., 0.],
             [0., 1000., 0.],
             [0., 0., 1000.]], dtype=float)
        pbc = np.array([0, 0, 0], dtype=int)
    else:
        raise ValueError('structure type not supported')
    r = float(cutoff)
    cart_coords = np.ascontiguousarray(
        np.array(structure.cart_coords), dtype=float)
    center_indices, neighbor_indices, images, distances = \
        find_points_in_spheres(cart_coords, cart_coords, r=r, pbc=pbc,
                               lattice=lattice_matrix, tol=numerical_tol)
    center_indices = center_indices.astype(DataType.np_int)
    neighbor_indices = neighbor_indices.astype(DataType.np_int)
    images = images.astype(DataType.np_int)
    distances = distances.astype(DataType.np_float)
    exclude_self = (center_indices != neighbor_indices) | (distances > numerical_tol)
    return center_indices[exclude_self], neighbor_indices[exclude_self], \
        images[exclude_self], distances[exclude_self] 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:41,代碼來源:data.py

示例13: setUpClass

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def setUpClass(cls):
        cls.molecule = Molecule(['C', 'O', 'O'], [[0, 0, 0], [-1, 0, 0], [1, 0, 0]])
        cls.model = MEGNetModel.from_file(os.path.join(
            CWD, '../../../mvl_models/mp-2019.4.1/formation_energy.hdf5')) 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:6,代碼來源:test_molecule_util.py

示例14: test_get_pmg_mol_from_smiles

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def test_get_pmg_mol_from_smiles(self):
        mol = get_pmg_mol_from_smiles('C')
        self.assertTrue(isinstance(mol, Molecule)) 
開發者ID:materialsvirtuallab,項目名稱:megnet,代碼行數:5,代碼來源:test_molecule_util.py

示例15: from_pymatgen_molecule

# 需要導入模塊: import pymatgen [as 別名]
# 或者: from pymatgen import Molecule [as 別名]
def from_pymatgen_molecule(cls, molecule):
        """Create an instance of the own class from a pymatgen molecule

        Args:
            molecule (:class:`pymatgen.core.structure.Molecule`):

        Returns:
            Cartesian:
        """
        new = cls(atoms=[el.value for el in molecule.species],
                  coords=molecule.cart_coords)
        return new._to_numeric() 
開發者ID:mcocdawc,項目名稱:chemcoord,代碼行數:14,代碼來源:_cartesian_class_io.py


注:本文中的pymatgen.Molecule方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。