Skip to content

Commit

Permalink
add seqdist to iterNeighbors
Browse files Browse the repository at this point in the history
  • Loading branch information
jamesmkrieger committed Nov 5, 2023
1 parent 55a5585 commit 8ac358f
Showing 1 changed file with 16 additions and 10 deletions.
26 changes: 16 additions & 10 deletions prody/measure/contacts.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ class Contacts(object):
Contacts are identified using the coordinates of atoms at the time
of instantiation."""

def __init__(self, atoms, unitcell=None):
def __init__(self, atoms, unitcell=None, ):
"""*atoms* must be an :class:`.Atomic` instance.
:arg unitcell: orthorhombic unitcell dimension array with shape
Expand Down Expand Up @@ -131,7 +131,7 @@ def getUnitcell(self):
return self._unitcell.copy()


def iterNeighbors(atoms, radius, atoms2=None, unitcell=None):
def iterNeighbors(atoms, radius, atoms2=None, unitcell=None, seqdist=None):
"""Yield pairs of *atoms* that are within *radius* of each other and the
distance between them. If *atoms2* is also provided, one atom from *atoms*
and another from *atoms2* will be yielded. If one of *atoms* or *atoms2*
Expand Down Expand Up @@ -199,7 +199,8 @@ def iterNeighbors(atoms, radius, atoms2=None, unitcell=None):
_dict = {}
if ag is None:
for (i, j), r in zip(*kdtree(radius)):
yield (i, j, r)
if seqdist is None or abs(i.getResnum() - j.getResnum()) > seqdist:
yield (i, j, r)
else:
for (i, j), r in zip(*kdtree(radius)):
a1 = _dict.get(i)
Expand All @@ -210,7 +211,8 @@ def iterNeighbors(atoms, radius, atoms2=None, unitcell=None):
if a2 is None:
a2 = Atom(ag, index(j), acsi)
_dict[j] = a2
yield (a1, a2, r)
if seqdist is None or abs(a1.getResnum() - a2.getResnum()) > seqdist:
yield (a1, a2, r)
else:
try:
coords2 = atoms2._getCoords()
Expand Down Expand Up @@ -251,34 +253,38 @@ def iterNeighbors(atoms, radius, atoms2=None, unitcell=None):
if ag is None or ag2 is None:
for j, xyz in enumerate(coords2):
for i, r in zip(*kdtree(radius, xyz)):
yield (i, j, r)
if seqdist is None or abs(i.getResnum() - j.getResnum()) > seqdist:
yield (i, j, r)
else:
for a2 in atoms2.iterAtoms():
for i, r in zip(*kdtree(radius, a2._getCoords())):
a1 = _dict.get(i)
if a1 is None:
a1 = Atom(ag, index(i), acsi)
_dict[i] = a1
yield (a1, a2, r)
if seqdist is None or abs(a1.getResnum() - a2.getResnum()) > seqdist:
yield (a1, a2, r)
else:
kdtree = KDTree(coords2, unitcell=unitcell, none=list)
_dict = {}
if ag is None or ag2 is None:
for i, xyz in enumerate(coords):
for j, r in zip(*kdtree(radius, xyz)):
yield (i, j, r)
if seqdist is None or abs(i.getResnum() - j.getResnum()) > seqdist:
yield (i, j, r)
else:
for a1 in atoms.iterAtoms():
for i, r in zip(*kdtree(radius, a1._getCoords())):
a2 = _dict.get(i)
if a2 is None:
a2 = Atom(ag2, index2(i), acsi2)
_dict[i] = a2
yield (a1, a2, r)
if seqdist is None or abs(a1.getResnum() - a2.getResnum()) > seqdist:
yield (a1, a2, r)


def findNeighbors(atoms, radius, atoms2=None, unitcell=None):
def findNeighbors(atoms, radius, atoms2=None, unitcell=None, seqdist=None):
"""Returns list of neighbors that are within *radius* of each other and the
distance between them. See :func:`iterNeighbors` for more details."""

return list(iterNeighbors(atoms, radius, atoms2, unitcell))
return list(iterNeighbors(atoms, radius, atoms2, unitcell, seqdist))

0 comments on commit 8ac358f

Please sign in to comment.