Files
rdkit/Code/GraphMol/Wrap/testConformer.py
Ric 880a8e5725 Reformat Python code for 2023.03 release (#6294)
* run yapf

* run isort

---------

Co-authored-by: Greg Landrum <greg.landrum@gmail.com>
2023-04-28 06:53:56 +02:00

145 lines
3.8 KiB
Python

# $Id$
#
# Copyright (C) 2004 Rational Discovery LLC
# All Rights Reserved
#
import os
import sys
import unittest
from rdkit import Chem, Geometry, RDConfig
from rdkit.Geometry import Point3D
def feq(v1, v2, tol2=1e-4):
return abs(v1 - v2) <= tol2
def ptEq(pt1, pt2, tol=1e-4):
return feq(pt1.x, pt2.x, tol) and feq(pt1.y, pt2.y, tol) and feq(pt1.z, pt2.z, tol)
def addConf(mol):
conf = Chem.Conformer(mol.GetNumAtoms())
for i in range(mol.GetNumAtoms()):
conf.SetAtomPosition(i, (0., 0., 0.))
mol.AddConformer(conf)
mb = Chem.MolToMolBlock(mol)
mb = Chem.MolToMolBlock(mol)
class TestCase(unittest.TestCase):
def setUp(self):
pass
def test0Conformers(self):
"""Test the conformer data structure"""
mol = Chem.MolFromSmiles("CC")
conf = Chem.Conformer(2)
conf.SetAtomPosition(0, (-0.5, 0.0, 0.0))
conf.SetAtomPosition(1, (1.0, 0.0, 0.0))
conf.SetId(0)
cid = mol.AddConformer(conf)
self.assertTrue(cid == 0)
conf2 = mol.GetConformer(0)
self.assertTrue(conf2.GetId() == cid)
pt1 = conf2.GetAtomPosition(0)
self.assertTrue(ptEq(pt1, Point3D(-0.5, 0.0, 0.0)))
pt2 = conf2.GetAtomPosition(1)
self.assertTrue(ptEq(pt2, Point3D(1.0, 0.0, 0.0)))
#changing conf should not change conf2 - related to issue 217
conf.SetAtomPosition(1, Point3D(2.0, 0.0, 0.0))
pt2 = conf2.GetAtomPosition(1)
self.assertTrue(feq(pt2[0], 1.0))
conf = Chem.Conformer(2)
conf.SetAtomPosition(0, Point3D(-0.5, 0.0, 0.0))
conf.SetAtomPosition(1, Point3D(1.0, 0.0, 0.0))
conf.SetId(2)
cid = mol.AddConformer(conf, 0)
self.assertTrue(cid == 2)
conf3 = mol.GetConformer(2)
def test0AddHds(self):
mol = Chem.MolFromSmiles("CC")
conf = Chem.Conformer(1)
conf.SetAtomPosition(0, Point3D(-0.5, 0.0, 0.0))
conf.SetAtomPosition(1, Point3D(1.0, 0.0, 0.0))
cid = mol.AddConformer(conf)
conf2 = mol.GetConformer()
self.assertTrue(conf2.GetNumAtoms() == 2)
nmol = Chem.AddHs(mol, 0, 1)
conf3 = nmol.GetConformer()
self.assertTrue(conf3.GetNumAtoms() == 8)
self.assertTrue(conf2.GetNumAtoms() == 2)
targetCoords = [[-0.5, 0.0, 0.0], [1.0, 0.0, 0.0], [-0.8667, 0.0, 1.03709],
[-0.8667, 0.8981, -0.5185], [-0.8667, -0.8981, -0.5185], [1.3667, 0.0, -1.0371],
[1.36667, 0.8981, 0.5185], [1.36667, -0.8981, 0.5185]]
for i in range(8):
pt = conf3.GetAtomPosition(i)
self.assertTrue(ptEq(pt, Point3D(*tuple(targetCoords[i]))))
def test2Issue217(self):
smi = 'c1ccccc1'
m = Chem.MolFromSmiles(smi)
addConf(m)
self.assertTrue(m.GetNumConformers() == 1)
mb2 = Chem.MolToMolBlock(m)
def test3Exceptions(self):
smi = 'c1ccccc1'
m = Chem.MolFromSmiles(smi)
addConf(m)
self.assertTrue(m.GetNumConformers() == 1)
self.assertRaises(ValueError, lambda: m.GetConformer(2))
def test4ConfTuple(self):
smi = 'c1ccccc1'
m = Chem.MolFromSmiles(smi)
for i in range(10):
addConf(m)
confs = m.GetConformers()
self.assertTrue(len(confs) == 10)
for conf in confs:
for i in range(6):
pt = conf.GetAtomPosition(i)
self.assertTrue(ptEq(pt, Point3D(0.0, 0.0, 0.0)))
m.RemoveAllConformers()
self.assertTrue(m.GetNumConformers() == 0)
confs = m.GetConformers()
self.assertEqual(len(confs), 0)
def test5PositionsArray(self):
smi = 'c1ccccc1'
m = Chem.MolFromSmiles(smi)
addConf(m)
confs = m.GetConformers()
self.assertTrue(len(confs) == 1)
for conf in confs:
pos = conf.GetPositions()
self.assertTrue(pos.shape, (6, 3))
m.RemoveAllConformers()
self.assertTrue(m.GetNumConformers() == 0)
confs = m.GetConformers()
self.assertEqual(len(confs), 0)
if __name__ == '__main__':
unittest.main()