rdworks 0.50.1__py3-none-any.whl → 0.51.1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- rdworks/__init__.py +1 -1
- rdworks/conf.py +56 -0
- rdworks/mol.py +42 -0
- {rdworks-0.50.1.dist-info → rdworks-0.51.1.dist-info}/METADATA +1 -1
- {rdworks-0.50.1.dist-info → rdworks-0.51.1.dist-info}/RECORD +8 -8
- {rdworks-0.50.1.dist-info → rdworks-0.51.1.dist-info}/WHEEL +0 -0
- {rdworks-0.50.1.dist-info → rdworks-0.51.1.dist-info}/licenses/LICENSE +0 -0
- {rdworks-0.50.1.dist-info → rdworks-0.51.1.dist-info}/top_level.txt +0 -0
rdworks/__init__.py
CHANGED
rdworks/conf.py
CHANGED
@@ -270,6 +270,62 @@ class Conf:
|
|
270
270
|
return self.sync(ase_atoms.get_positions())
|
271
271
|
|
272
272
|
|
273
|
+
def protonate(self, atom_indices: list[int]) -> Self:
|
274
|
+
"""Protonate given non-hydrogen atoms.
|
275
|
+
|
276
|
+
Args:
|
277
|
+
atom_indices (list[int]): atom indices of non-hydrogen atoms to protonate.
|
278
|
+
|
279
|
+
Returns:
|
280
|
+
Self: self.
|
281
|
+
"""
|
282
|
+
for idx in atom_indices:
|
283
|
+
atom = self.rdmol.GetAtomWithIdx(idx)
|
284
|
+
h = atom.GetNumExplicitHs()
|
285
|
+
c = atom.GetFormalCharge()
|
286
|
+
atom.SetNumExplicitHs(h+1)
|
287
|
+
atom.SetFormalCharge(c+1)
|
288
|
+
Chem.SanitizeMol(self.rdmol)
|
289
|
+
self.rdmol = Chem.AddHs(self.rdmol, addCoords=True)
|
290
|
+
# The Chem.AddHs function in RDKit returns a new Mol object with hydrogens added to the molecule.
|
291
|
+
# It modifies the input molecule by adding hydrogens,
|
292
|
+
# but the original molecule remains unchanged.
|
293
|
+
|
294
|
+
return self
|
295
|
+
|
296
|
+
|
297
|
+
def deprotonate(self, atom_indices: list[int]) -> Self:
|
298
|
+
"""Deprotonate given non-hydrogen atoms.
|
299
|
+
|
300
|
+
Args:
|
301
|
+
atom_indices (list[int]): atom indices of non-hydrogen atoms to deprotonate.
|
302
|
+
|
303
|
+
Returns:
|
304
|
+
Self: self.
|
305
|
+
"""
|
306
|
+
for idx in atom_indices:
|
307
|
+
bonded_H_idx = None
|
308
|
+
atom = self.rdmol.GetAtomWithIdx(idx)
|
309
|
+
h = atom.GetNumExplicitHs()
|
310
|
+
if h-1 >= 0 :
|
311
|
+
atom.SetNumExplicitHs(h-1) # (h-1) must be unsigned int
|
312
|
+
c = atom.GetFormalCharge()
|
313
|
+
atom.SetFormalCharge(c-1)
|
314
|
+
neighbors = atom.GetNeighbors()
|
315
|
+
|
316
|
+
for neighbor in neighbors:
|
317
|
+
if neighbor.GetAtomicNum() == 1:
|
318
|
+
bonded_H_idx = neighbor.GetIdx()
|
319
|
+
break
|
320
|
+
|
321
|
+
if bonded_H_idx is not None:
|
322
|
+
edit_mol = Chem.EditableMol(self.rdmol)
|
323
|
+
edit_mol.RemoveAtom(bonded_H_idx)
|
324
|
+
self.rdmol = edit_mol.GetMol()
|
325
|
+
Chem.SanitizeMol(self.rdmol)
|
326
|
+
|
327
|
+
return self
|
328
|
+
|
273
329
|
|
274
330
|
##################################################
|
275
331
|
### Endpoint methods
|
rdworks/mol.py
CHANGED
@@ -1619,4 +1619,46 @@ class Mol:
|
|
1619
1619
|
self.props = data['props']
|
1620
1620
|
self.confs = [Conf().deserialize(_) for _ in data['confs']] # for 3D conformers (iterable)
|
1621
1621
|
|
1622
|
+
return self
|
1623
|
+
|
1624
|
+
def from_molblock(self, molblock: str) -> Self:
|
1625
|
+
"""Initialize a new Mol object from MolBlock.
|
1626
|
+
|
1627
|
+
Args:
|
1628
|
+
molblock (str): MolBlock string
|
1629
|
+
|
1630
|
+
Raises:
|
1631
|
+
ValueError: invalid MolBlock
|
1632
|
+
|
1633
|
+
Returns:
|
1634
|
+
Self: self.
|
1635
|
+
"""
|
1636
|
+
molecule = Chem.MolFromMolBlock(molblock)
|
1637
|
+
try:
|
1638
|
+
self.rdmol, _ = clean_2d(molecule, reset_isotope=True, remove_H=True)
|
1639
|
+
self.smiles = Chem.MolToSmiles(self.rdmol)
|
1640
|
+
self.confs = [Conf(x) for x in _]
|
1641
|
+
except:
|
1642
|
+
raise ValueError(f'Mol() Error: invalid MolBlock string')
|
1643
|
+
|
1644
|
+
assert self.smiles and self.rdmol, "Mol() Error: invalid molecule"
|
1645
|
+
|
1646
|
+
name = self.rdmol.GetProp('_Name')
|
1647
|
+
|
1648
|
+
rdDepictor.Compute2DCoords(self.rdmol)
|
1649
|
+
|
1650
|
+
try:
|
1651
|
+
self.name = str(name)
|
1652
|
+
except:
|
1653
|
+
self.name = 'untitled'
|
1654
|
+
|
1655
|
+
self.rdmol.SetProp('_Name', self.name) # _Name can't be None
|
1656
|
+
self.InChIKey = generate_inchi_key(self.rdmol)
|
1657
|
+
self.props.update({
|
1658
|
+
'aka' : [], # <-- to be set by MolLibr.unique()
|
1659
|
+
'atoms' : self.rdmol.GetNumAtoms(), # hydrogens not excluded?
|
1660
|
+
'charge': rdmolops.GetFormalCharge(self.rdmol),
|
1661
|
+
"nrb" : Descriptors.NumRotatableBonds(self.rdmol),
|
1662
|
+
})
|
1663
|
+
|
1622
1664
|
return self
|
@@ -1,10 +1,10 @@
|
|
1
|
-
rdworks/__init__.py,sha256=
|
2
|
-
rdworks/conf.py,sha256=
|
1
|
+
rdworks/__init__.py,sha256=97yHJt3kMGu9bPYMVL98USE3E9kkAxZmupT77BGkX6s,1391
|
2
|
+
rdworks/conf.py,sha256=aHpVa3PcbECk-IP6pdxqT2Q9T4eykqoozcgaGRnZdLk,36210
|
3
3
|
rdworks/descriptor.py,sha256=34T_dQ6g8v3u-ym8TLKbQtxIIV5TEo-d3pdedq3o-cg,2106
|
4
4
|
rdworks/display.py,sha256=JR0gR26UpH-JCxVOaqXZCUj2MiGZSrx9Me87FncspVI,13469
|
5
5
|
rdworks/ionized.py,sha256=_t-Ajssv1rytV4Y_KsSbxfnsBKqy-EusbhNUtaWcV6o,7681
|
6
6
|
rdworks/matchedseries.py,sha256=A3ON4CUpQV159mu9VqgNiJ8uoQ9ePOry9d3ra4NCAgc,10377
|
7
|
-
rdworks/mol.py,sha256
|
7
|
+
rdworks/mol.py,sha256=-zjAsBETNUbP4_n8p6how40NhZB24icMYhas1kYPqCc,70064
|
8
8
|
rdworks/mollibr.py,sha256=X4UBO6Ga-QmNS7RwUiaDYAx0Q5hnWs71yTkEpH02Qb4,37696
|
9
9
|
rdworks/pka.py,sha256=NVJVfpcNEMlX5QRyLBgUM7GIT7VMjO-llAR4LWc8J2c,1656
|
10
10
|
rdworks/readin.py,sha256=0bnVcZcAmSLqc6zu1mYcv0LdBv2agQfOpKGwpSRL9VE,11742
|
@@ -66,8 +66,8 @@ rdworks/predefined/misc/reactive-part-3.xml,sha256=LgWHSEbRTVmgBoIO45xbTo1xQJs0X
|
|
66
66
|
rdworks/predefined/misc/reactive.xml,sha256=syedoQ6VYUfRLnxy99ObuDniJ_a_WhrWAJbTKFfJ6VY,11248
|
67
67
|
rdworks/xtb/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
68
68
|
rdworks/xtb/wrapper.py,sha256=w_SX3q7D4_peHERFzONesG8c-a6UTRzfBLx313D8rNE,23638
|
69
|
-
rdworks-0.
|
70
|
-
rdworks-0.
|
71
|
-
rdworks-0.
|
72
|
-
rdworks-0.
|
73
|
-
rdworks-0.
|
69
|
+
rdworks-0.51.1.dist-info/licenses/LICENSE,sha256=UOkJSBqYyQUvtCp7a-vdCANeEcLE2dnTie_eB1By5SY,1074
|
70
|
+
rdworks-0.51.1.dist-info/METADATA,sha256=nlzLbvfGJYCScwVL1Mub2lFFhsDvETxIQFs5UIBdZ90,1967
|
71
|
+
rdworks-0.51.1.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
72
|
+
rdworks-0.51.1.dist-info/top_level.txt,sha256=05C98HbvBK2axUBogC_hAT_CdpOeQYGnQ6vRAgawr8s,8
|
73
|
+
rdworks-0.51.1.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|