Skip to content

Commit

Permalink
Merge pull request prody#2013 from jamesmkrieger/dali_filter_reverse
Browse files Browse the repository at this point in the history
add reverse to filterDaliMultimers
  • Loading branch information
jamesmkrieger authored Dec 10, 2024
2 parents 0945824 + 913954b commit da5904d
Showing 1 changed file with 36 additions and 7 deletions.
43 changes: 36 additions & 7 deletions prody/database/dali.py
Original file line number Diff line number Diff line change
Expand Up @@ -515,7 +515,7 @@ def getTitle(self):

return self._title

def daliFilterMultimer(atoms, dali_rec, n_chains=None):
def daliFilterMultimer(atoms, dali_rec, n_chains=None, reverse=False):
"""
Filters multimers to only include chains with Dali mappings.
Expand All @@ -524,6 +524,14 @@ def daliFilterMultimer(atoms, dali_rec, n_chains=None):
:arg dali_rec: the DaliRecord object with which to filter chains
:type dali_rec: :class:`.DaliRecord`
:arg n_chains: the number of chains in multimers to keep
Default is None, keeping all multimers
:arg n_chains: int
:arg reverse: whether to reverse filtering to exclude by n_chain
Default is False
:type reverse: bool
"""
if not isinstance(atoms, Atomic):
raise TypeError("atoms should be an Atomic object")
Expand All @@ -535,6 +543,12 @@ def daliFilterMultimer(atoms, dali_rec, n_chains=None):
except:
raise AttributeError("Dali Record does not have any data yet. Please run fetch.")

if not isinstance(n_chains, (int, type(None))):
raise TypeError('n_chains should be None or an integer')

if not isinstance(reverse, bool):
raise TypeError('reverse should be a Boolean')

numChains = 0
atommap = None
for i, chain in enumerate(atoms.iterChains()):
Expand All @@ -546,17 +560,32 @@ def daliFilterMultimer(atoms, dali_rec, n_chains=None):
else:
atommap += chain

if n_chains is None or numChains == n_chains:
return atommap
else:
return None
if n_chains is None or \
not reverse and numChains == n_chains or \
reverse and numChains != n_chains:
return atommap
return None

def daliFilterMultimers(structures, dali_rec, n_chains=None):
def daliFilterMultimers(structures, dali_rec, n_chains=None, reverse=False):
"""A wrapper for daliFilterMultimer to apply to multiple structures.
:arg structures: a list of :class:`.Atomic` objects to be filtered
:type structures: list
:arg dali_rec: the DaliRecord object with which to filter chains
:type dali_rec: :class:`.DaliRecord`
:arg n_chains: the number of chains in multimers to keep
Default is None, keeping all multimers
:arg n_chains: int
:arg reverse: whether to reverse filtering to exclude by n_chain
Default is False
:type reverse: bool
"""
dali_ags = []
for entry in structures:
result = daliFilterMultimer(entry, dali_rec, n_chains)
result = daliFilterMultimer(entry, dali_rec, n_chains, reverse)
if result is not None:
dali_ags.append(result)
return dali_ags

0 comments on commit da5904d

Please sign in to comment.