aboutsummaryrefslogtreecommitdiff
path: root/plip/test/test_basic_functions.py
diff options
context:
space:
mode:
Diffstat (limited to 'plip/test/test_basic_functions.py')
-rw-r--r--plip/test/test_basic_functions.py135
1 files changed, 135 insertions, 0 deletions
diff --git a/plip/test/test_basic_functions.py b/plip/test/test_basic_functions.py
new file mode 100644
index 0000000..7134f55
--- /dev/null
+++ b/plip/test/test_basic_functions.py
@@ -0,0 +1,135 @@
+# coding=utf-8
+"""
+Protein-Ligand Interaction Profiler - Analyze and visualize protein-ligand interactions in PDB files.
+test_basic_functions.py - Unit Tests for basic functionality.
+"""
+
+# Python Standard Library
+import unittest
+import numpy
+import random
+
+# Own modules
+from plip.structure.preparation import PDBComplex
+from plip.basic.supplemental import euclidean3d, vector, vecangle, projection
+from plip.basic.supplemental import normalize_vector, cluster_doubles, centroid
+
+
+class TestLigandSupport(unittest.TestCase):
+ """Test for support of different ligands"""
+
+ def test_dna_rna(self):
+ """Test if DNA and RNA is correctly processed as ligands"""
+ tmpmol = PDBComplex()
+ tmpmol.load_pdb('./pdb/1tf6.pdb')
+ # DNA ligand four times consisting of 31 parts (composite)
+ self.assertEqual([len(ligand.members) for ligand in tmpmol.ligands].count(31), 4)
+ for ligset in [set((x[0] for x in ligand.members)) for ligand in tmpmol.ligands]:
+ if len(ligset) == 4:
+ # DNA only contains four bases
+ self.assertEqual(ligset, {'DG', 'DC', 'DA', 'DT'})
+
+
+class TestMapping(unittest.TestCase):
+ """Test"""
+
+ def test_ids(self):
+ """Test if the atom IDs are correctly mapped from internal to original PDB."""
+ tmpmol = PDBComplex()
+ tmpmol.load_pdb('./pdb/1vsn.pdb')
+ bsid = 'NFT:A:283'
+ for ligand in tmpmol.ligands:
+ if ':'.join([ligand.hetid, ligand.chain, str(ligand.position)]) == bsid:
+ tmpmol.characterize_complex(ligand)
+ s = tmpmol.interaction_sets[bsid]
+ for contact in s.hydrophobic_contacts:
+ if contact.restype == 'ALA' and contact.resnr == 133:
+ self.assertEqual(contact.ligatom_orig_idx, 1636)
+ self.assertEqual(contact.bsatom_orig_idx, 994)
+ if contact.restype == 'ASP' and contact.resnr == 61:
+ self.assertEqual(contact.ligatom_orig_idx, 1639)
+ self.assertEqual(contact.bsatom_orig_idx, 448)
+ for contact in s.hbonds_ldon + s.hbonds_pdon:
+ if contact.restype == 'GLN' and contact.resnr == 19:
+ self.assertEqual(contact.a_orig_idx, 1649)
+ self.assertEqual(contact.d_orig_idx, 153)
+ if contact.restype == 'CYS' and contact.resnr == 25:
+ self.assertEqual(contact.a_orig_idx, 1649)
+ self.assertEqual(contact.d_orig_idx, 183)
+ if contact.restype == 'ASN' and contact.resnr == 158:
+ self.assertEqual(contact.d_orig_idx, 1629)
+ self.assertEqual(contact.a_orig_idx, 1199)
+ for contact in s.halogen_bonds:
+ if contact.restype == 'TYR' and contact.resnr == 67:
+ self.assertEqual(contact.don.x_orig_idx, 1627)
+ self.assertEqual(contact.acc.o_orig_idx, 485)
+ if contact.restype == 'LEU' and contact.resnr == 157:
+ self.assertEqual(contact.don.x_orig_idx, 1628)
+ self.assertEqual(contact.acc.o_orig_idx, 1191)
+
+
+class GeometryTest(unittest.TestCase):
+ """Tests for geometrical calculations in PLIP"""
+
+ def vector_magnitude(self, v):
+ return numpy.sqrt(sum(x**2 for x in v))
+
+ # noinspection PyUnusedLocal
+ def setUp(self):
+ """Generate random data for the tests"""
+ # Generate two random n-dimensional float vectors, with -100 <= n <= 100 and values 0 <= i <= 1
+ dim = random.randint(1, 100)
+ self.rnd_vec = [random.uniform(-100, 100) for i in range(dim)]
+
+ def test_euclidean(self):
+ """Tests for mathematics.euclidean"""
+ # Are the results correct?
+ self.assertEqual(euclidean3d([0.0, 0.0, 0.0], [0.0, 0.0, 0.0]), 0)
+ self.assertEqual(euclidean3d([2.0, 3.0, 4.0], [2.0, 3.0, 4.0]), 0)
+ self.assertEqual(euclidean3d([4.0, 5.0, 6.0], [4.0, 5.0, 8.0]), 2.0)
+ # Does the function take vectors or tuples as an input? What about integers?
+ self.assertEqual(euclidean3d((4.0, 5.0, 6.0), [4.0, 5.0, 8.0]), 2.0)
+ self.assertEqual(euclidean3d((4.0, 5.0, 6.0), (4.0, 5.0, 8.0)), 2.0)
+ self.assertEqual(euclidean3d((4, 5, 6), (4.0, 5.0, 8.0)), 2.0)
+ # Is the output a float?
+ self.assertIsInstance(euclidean3d([2.0, 3.0, 4.0], [2.0, 3.0, 4.0]), float)
+
+ def test_vector(self):
+ """Tests for mathematics.vector"""
+ # Are the results correct?
+ self.assertEqual(list(vector([1, 1, 1], [0, 1, 0])), [-1, 0, -1])
+ self.assertEqual(list(vector([0, 0, 10], [0, 0, 4])), [0, 0, -6])
+ # Do I get an Numpy Array?
+ self.assertIsInstance(vector([1, 1, 1], [0, 1, 0]), numpy.ndarray)
+ # Do I get 'None' if the points have different dimensions?
+ self.assertEqual(vector([1, 1, 1], [0, 1, 0, 1]), None)
+
+ def test_vecangle(self):
+ """Tests for mathematics.vecangle"""
+ # Are the results correct?
+ self.assertEqual(vecangle([3, 4], [-8, 6], deg=False), numpy.radians(90.0))
+ self.assertEqual(vecangle([3, 4], [-8, 6]), 90.0)
+ self.assertAlmostEqual(vecangle([-1, -1], [1, 1], deg=False), numpy.pi)
+ # Correct if both vectors are equal?
+ self.assertEqual(vecangle([3, 3], [3, 3]), 0.0)
+
+ def test_centroid(self):
+ """Tests for mathematics.centroid"""
+ # Are the results correct?
+ self.assertEqual(centroid([[0, 0, 0], [2, 2, 2]]), [1.0, 1.0, 1.0])
+ self.assertEqual(centroid([[-5, 1, 2], [10, 2, 2]]), [2.5, 1.5, 2.0])
+
+ def test_normalize_vector(self):
+ """Tests for mathematics.normalize_vector"""
+ # Are the results correct?
+ self.assertAlmostEqual(self.vector_magnitude(normalize_vector(self.rnd_vec)), 1)
+
+ def test_projection(self):
+ """Tests for mathematics.projection"""
+ # Are the results correct?
+ self.assertEqual(projection([-1, 0, 0], [3, 3, 3], [1, 1, 1]), [3, 1, 1])
+
+ def test_cluster_doubles(self):
+ """Tests for mathematics.cluster_doubles"""
+ # Are the results correct?
+ self.assertEqual(set(cluster_doubles([(1, 3), (4, 1), (5, 6), (7, 5)])), {(1, 3, 4), (5, 6, 7)})