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


Python openbabel.OBMol方法代碼示例

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


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

示例1: __init__

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def __init__(self, OBMol=None, source=None, protein=False):
        # lazy
        self._source = source  # dict with keys: n, fmt, string, filename

        if OBMol and not isinstance(OBMol, (Molecule, pybel.Molecule, ob.OBMol)):
            raise ValueError('OBMol needs to be ODDT, Pybel or OB molecule instance')

        # call parent constructor
        super(Molecule, self).__init__(OBMol)

        self._protein = protein

        # ob.DeterminePeptideBackbone(molecule.OBMol)
        # percieve chains in residues
        # if len(res_dict) > 1 and not molecule.OBMol.HasChainsPerceived():
        #    print("Dirty HACK")
        #    molecule = pybel.readstring('pdb', molecule.write('pdb'))
        self._atom_dict = None
        self._res_dict = None
        self._ring_dict = None
        self._coords = None
        self._charges = None

    # lazy Molecule parsing requires masked OBMol 
開發者ID:oddt,項目名稱:oddt,代碼行數:26,代碼來源:ob.py

示例2: _crd2mul

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def _crd2mul(symbols, crds):
    atomnumber = len(symbols)
    xyzstring = ''.join((f"{atomnumber}\nDPGEN\n", "\n".join(
        ['{:2s} {:22.15f} {:22.15f} {:22.15f}'.format(s, x, y, z)
            for s, (x, y, z) in zip(symbols, crds)])))
    conv = openbabel.OBConversion()
    conv.SetInAndOutFormats('xyz', 'gjf')
    mol = openbabel.OBMol()
    conv.ReadString(mol, xyzstring)
    gjfstring = conv.WriteString(mol)
    try:
        mul = int(gjfstring.split('\n')[4].split()[1])
    except IndexError:
        # openbabel 3.0
        mul = int(gjfstring.split('\n')[5].split()[1])
    return mul 
開發者ID:deepmodeling,項目名稱:dpgen,代碼行數:18,代碼來源:gaussian.py

示例3: _update_bond_orders

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def _update_bond_orders(self, idc_lists):
        '''
        Updates the bond orders in the underlying OBMol object.

        Args:
            idc_lists (list of list of int): nested list containing bonds, i.e. pairs
                of row indices (list1) and column indices (list2) which shall be updated
        '''
        con_mat = self.get_connectivity()
        self._obmol.BeginModify()
        for i in range(len(idc_lists[0])):
            idx1 = idc_lists[0][i]
            idx2 = idc_lists[1][i]
            obbond = self._obmol.GetBond(int(idx1+1), int(idx2+1))
            obbond.SetBO(int(con_mat[idx1, idx2]))
        self._obmol.EndModify()

        # reset fingerprints etc
        self._fp = None
        self._can = None
        self._mirror_can = None
        self._inchi_key = None 
開發者ID:atomistic-machine-learning,項目名稱:G-SchNet,代碼行數:24,代碼來源:utility_classes.py

示例4: guess_bond_orders

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def guess_bond_orders(mol):
    """Use OpenBabel to guess bond orders using geometry and functional group templates.

    Args:
        mol (moldesign.Molecule): Molecule to perceive the bonds of

    Returns:
        moldesign.Molecule: New molecule with assigned bonds
    """
    # TODO: pH, formal charges
    pbmol = mol_to_pybel(mol)
    pbmol.OBMol.PerceiveBondOrders()
    newmol = pybel_to_mol(pbmol)
    return newmol 
開發者ID:Autodesk,項目名稱:molecular-design-toolkit,代碼行數:16,代碼來源:openbabel.py

示例5: add_hydrogen

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def add_hydrogen(mol):
    """Add hydrogens to saturate atomic valences.

    Args:
        mol (moldesign.Molecule): Molecule to saturate

    Returns:
        moldesign.Molecule: New molecule with all valences saturated
    """
    pbmol = mol_to_pybel(mol)
    pbmol.OBMol.AddHydrogens()
    newmol = pybel_to_mol(pbmol, reorder_atoms_by_residue=True)
    mdt.helpers.assign_unique_hydrogen_names(newmol)
    return newmol 
開發者ID:Autodesk,項目名稱:molecular-design-toolkit,代碼行數:16,代碼來源:openbabel.py

示例6: to_mol2

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def to_mol2(infile,outfile):
    conv = ob.OBConversion()
    conv.SetInAndOutFormats("sdf","mol2")
    mol = ob.OBMol()
    conv.ReadFile(mol, infile)
    conv.WriteFile(mol, outfile) 
開發者ID:ericchansen,項目名稱:q2mm,代碼行數:8,代碼來源:sdf_to_mae.py

示例7: OBMol

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def OBMol(self):
        if not self._OBMol and self._source:
            self._OBMol = readstring(self._source['fmt'],
                                     self._source['string'],
                                     opt=self._source['opt'] if 'opt' in self._source else {}).OBMol
            self._source = None
        return self._OBMol 
開發者ID:oddt,項目名稱:oddt,代碼行數:9,代碼來源:ob.py

示例8: atoms

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def atoms(self):
        return AtomStack(self.OBMol) 
開發者ID:oddt,項目名稱:oddt,代碼行數:4,代碼來源:ob.py

示例9: bonds

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def bonds(self):
        return BondStack(self.OBMol)

    # cache frequently used properties and cache them in prefixed [_] variables 
開發者ID:oddt,項目名稱:oddt,代碼行數:6,代碼來源:ob.py

示例10: addh

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def addh(self, only_polar=False):
        """Add hydrogens"""
        if only_polar:
            self.OBMol.AddPolarHydrogens()
        else:
            self.OBMol.AddHydrogens()
        self._clear_cache() 
開發者ID:oddt,項目名稱:oddt,代碼行數:9,代碼來源:ob.py

示例11: make2D

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def make2D(self):
        """Generate 2D coordinates for molecule"""
        pybel._operations['gen2D'].Do(self.OBMol)
        self._clear_cache() 
開發者ID:oddt,項目名稱:oddt,代碼行數:6,代碼來源:ob.py

示例12: calccharges

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def calccharges(self, model='gasteiger'):
        """Calculate partial charges for a molecule. By default the Gasteiger
        charge model is used.

        Parameters
        ----------
        model : str (default="gasteiger")
            Method for generating partial charges. Supported models:
            * gasteiger
            * mmff94
            * others supported by OpenBabel (`obabel -L charges`)
        """
        if __version__ < '2.4.0':  # TODO: Get rid of this block for new OB
            if model in pybel._getpluginnames('charges'):
                m = pybel._getplugins(ob.OBChargeModel.FindType, [model])[model]
                if not m.ComputeCharges(self.OBMol):
                    raise Exception('Could not assigh partial charges for '
                                    'molecule "%s"' % self.title)
            else:
                raise ValueError('Model "%s" is not supported in OpenBabel' %
                                 model)
        else:
            super(Molecule, self).calccharges(model)
        self._clear_cache()

    # Custom ODDT properties # 
開發者ID:oddt,項目名稱:oddt,代碼行數:28,代碼來源:ob.py

示例13: clone

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def clone(self):
        return Molecule(ob.OBMol(self.OBMol)) 
開發者ID:oddt,項目名稱:oddt,代碼行數:4,代碼來源:ob.py

示例14: clone_coords

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def clone_coords(self, source):
        self.OBMol.SetCoordinates(source.OBMol.GetCoordinates())
        return self 
開發者ID:oddt,項目名稱:oddt,代碼行數:5,代碼來源:ob.py

示例15: __iter__

# 需要導入模塊: import openbabel [as 別名]
# 或者: from openbabel import OBMol [as 別名]
def __iter__(self):
        for i in range(self.OBMol.NumAtoms()):
            yield Atom(self.OBMol.GetAtom(i + 1)) 
開發者ID:oddt,項目名稱:oddt,代碼行數:5,代碼來源:ob.py


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