Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Idp go #593

Merged
merged 24 commits into from
May 22, 2024
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
7ce1254
fix missing bias application, add preprint citation
csbrasnett Apr 23, 2024
7349c14
Merge branch 'master' into idp-bugfix
fgrunewald Apr 23, 2024
51c284d
added integration test
csbrasnett Apr 23, 2024
0aaf858
added more detail to -ss help
csbrasnett Apr 24, 2024
d084a73
start of adding additional idp bonded potentials
csbrasnett Apr 24, 2024
359cd77
add idr interactions
csbrasnett Apr 24, 2024
46e8473
cleaned up and fixed
csbrasnett Apr 25, 2024
df6b672
Merge remote-tracking branch 'origin/idp-bugfix' into idp-go
csbrasnett Apr 29, 2024
67884de
Merge branch 'master' into idp-go
csbrasnett Apr 29, 2024
d2a528e
Merge branch 'marrink-lab:master' into idp-go
csbrasnett May 1, 2024
633c407
Changed approach for adding extra IDR potentials
csbrasnett May 2, 2024
4399d7e
added IDR links to force field
csbrasnett May 2, 2024
d629b7b
updated tests with new bonded potentials
csbrasnett May 2, 2024
735accb
improved error handling if no idp-tune
csbrasnett May 2, 2024
eb498c7
Addressed comments and cleaned up.
csbrasnett May 6, 2024
9b646d1
removed old commented code
csbrasnett May 6, 2024
b62c3b2
removed unnecessary imports, added test for idr annotation
csbrasnett May 7, 2024
8d75c3c
addressed comments
csbrasnett May 7, 2024
b3179b4
corrected to new argument name in test_annotate_idrs.py
csbrasnett May 7, 2024
72b9d4e
fixed test for assigning residue water bias
csbrasnett May 22, 2024
a801775
added test to check folded-disordered go bond removal
csbrasnett May 22, 2024
635c4a2
cleaned up test
csbrasnett May 22, 2024
cd0d5bd
changed test_annotate_idrs.py to test system not molecule
csbrasnett May 22, 2024
5fd9e10
added more tests to test_w
csbrasnett May 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
22 changes: 21 additions & 1 deletion bin/martinize2
Original file line number Diff line number Diff line change
Expand Up @@ -170,7 +170,7 @@ def pdb_to_universal(
return canonicalized


def martinize(system, mappings, to_ff, delete_unknown=False):
def martinize(system, mappings, to_ff, delete_unknown=False, idrs=False, disordered_regions = []):
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
def martinize(system, mappings, to_ff, delete_unknown=False, idrs=False, disordered_regions = []):
def martinize(system, mappings, to_ff, delete_unknown=False, idrs=False, disordered_regions=(,)):

As before, no mutable types as default arguments

"""
Convert a system from one force field to an other at lower resolution.
"""
Expand All @@ -185,6 +185,9 @@ def martinize(system, mappings, to_ff, delete_unknown=False):
).run_system(system)
LOGGER.info("Averaging the coordinates.", type="step")
vermouth.DoAverageBead(ignore_missing_graphs=True).run_system(system)
if idrs:
LOGGER.info("Annotating IDRs.", type="step")
vermouth.AnnotateIDRs(idr_regions=[(int(start), int(stop)) for start, stop in disordered_regions]).run_system(system)
LOGGER.info("Applying the links.", type="step")
vermouth.DoLinks().run_system(system)
LOGGER.info("Placing the charge dummies.", type="step")
Expand Down Expand Up @@ -612,6 +615,13 @@ def entry():
"format: <start_resid_1>:<end_resid_1> <start_resid_2>:<end_resid_2>..."
),
)
idr_tuning = water_group.add_argument(
"-idr-tune",
dest="idr_tune",
action="store_true",
default=False,
help=("Tune the idr regions with specific bonded potentials."),
)


prot_group = parser.add_argument_group("Protein description")
Expand Down Expand Up @@ -922,6 +932,13 @@ def entry():
)
vermouth.SetMoleculeMeta(scfix=args.scfix).run_system(system)

vermouth.SetMoleculeMeta(idr=args.idr_tune).run_system(system)
if args.idr_tune:
if not target_ff.has_feature("idr"):
LOGGER.warning('Improved IDR potentials are not implemented '
'for this force field',
type="missing-feature")

ss_sequence = list(
itertools.chain(
*(
Expand All @@ -943,6 +960,8 @@ def entry():
mappings=known_mappings,
to_ff=known_force_fields[args.to_ff],
delete_unknown=True,
idrs=args.idr_tune,
disordered_regions=args.water_idrs
)

# Apply position restraints if required.
Expand Down Expand Up @@ -1051,6 +1070,7 @@ def entry():
vermouth.rcsu.go_vs_includes.VirtualSiteCreator().run_system(system)
itp_paths = {"atomtypes": "virtual_sites_atomtypes.itp",
"nonbond_params": "virtual_sites_nonbond_params.itp"}

# now we add a bias by defining specific virtual-site water interactions
vermouth.processors.ComputeWaterBias(args.water_bias,
{ s:float(eps) for s, eps in args.water_bias_eps},
Expand Down
67 changes: 67 additions & 0 deletions vermouth/data/force_fields/martini3001/aminoacids.ff
Original file line number Diff line number Diff line change
Expand Up @@ -962,6 +962,73 @@ scfix true
[ angles ]
BB +BB +SC1 10 100 15 {"group": "SC-BB-BB and BB-BB-SC scFix", "comment": "BB-BB-SC"}

;;; IDR specific links
[ link ]
resname $protein_resnames
cgidr true
[ features ]
idr
[ molmeta ]
idr true
[ angles ]
BB +BB +SC1 10 85 10 {"group": "idp-fix"}

[ link ]
resname $protein_resnames
cgidr true
[ features ]
idr
[ molmeta ]
idr true
[ angles ]
-SC1 -BB BB 10 85 10 {"group": "idp-fix"}

[ link ]
resname $protein_resnames
cgidr true
[ features ]
idr
[ molmeta ]
idr true
[ dihedrals ]
BB +BB ++BB +++BB 9 -120 -1 1 {"group": "idp-fix", "comment": "BB-BB-BB-BB-v1", "version":1}
BB +BB ++BB +++BB 9 -120 -1 2 {"group": "idp-fix", "comment": "BB-BB-BB-BB-v2", "version":2}

[ link ]
resname $protein_resnames
cgidr true
[ features ]
idr
[ molmeta ]
idr true
[ dihedrals ]
SC1 BB +BB +SC1 9 -130 -1.5 1 {"group": "idp-fix", "version": 1, "comment": "SC1-BB-BB-SC1-v1"}
SC1 BB +BB +SC1 9 100 -1.5 2 {"group": "idp-fix", "version": 2, "comment": "SC1-BB-BB-SC1-v2"}

[ link ]
resname $protein_resnames
cgidr true
[ features ]
idr
[ molmeta ]
idr true
[ dihedrals ]
-SC1 -BB BB +BB 1 115 -4.5 1 {"group": "idp-fix", "comment": "SC1-BB-BB(GLY)-BB"}
[ non-edges ]
BB SC1

[ link ]
resname $protein_resnames
cgidr true
[ features ]
idr
[ molmeta ]
idr true
[ dihedrals ]
-BB BB +BB +SC1 1 0 -2.0 1 {"group": "idp-fix", "comment": "BB-BB(GLY)-BB-SC1"}
[ non-edges ]
BB SC1

[ link ]
resname $protein_resnames
[ angles ]
Expand Down
1 change: 1 addition & 0 deletions vermouth/processors/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,3 +44,4 @@
from .merge_all_molecules import MergeAllMolecules
from .annotate_mut_mod import AnnotateMutMod
from .water_bias import ComputeWaterBias
from .annotate_idrs import AnnotateIDRs
81 changes: 81 additions & 0 deletions vermouth/processors/annotate_idrs.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Copyright 2024 University of Groningen
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""
Provides processors that can add and remove IDR specific bonds
"""

import functools

from .processor import Processor
from ..graph_utils import make_residue_graph
from ..rcsu.go_utils import _in_resid_region
from ..log_helpers import StyleAdapter, get_logger
LOGGER = StyleAdapter(get_logger(__name__))


def annotate_disorder(molecule, idr_regions):
"""
annotate the disordered regions of the molecule
"""
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Docstring is incomplete.
Also, is it worth making the attribute used an argument (with default "cgidr")?


for key, node in molecule.nodes.items():
_old_resid = node['_old_resid']

Check warning on line 35 in vermouth/processors/annotate_idrs.py

View check run for this annotation

Codecov / codecov/patch

vermouth/processors/annotate_idrs.py#L35

Added line #L35 was not covered by tests
if _in_resid_region(_old_resid, idr_regions):
molecule.nodes[key]["cgidr"] = True

Check warning on line 37 in vermouth/processors/annotate_idrs.py

View check run for this annotation

Codecov / codecov/patch

vermouth/processors/annotate_idrs.py#L37

Added line #L37 was not covered by tests

class AnnotateIDRs(Processor):
"""
Processor to annotate intrinsically disordered regions of a molecule.

This processor is designed primarily for the work described in the reference
M3_GO, but is generally applicable for such circumstances where extra
addition/removals are necessary.

"""

def __init__(self, idr_regions = None):
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
def __init__(self, idr_regions = None):
def __init__(self, idr_regions=None):

"""
Parameters
----------
idr_regions:
regions defining the IDRs
"""
self.idr_regions = idr_regions

Check warning on line 56 in vermouth/processors/annotate_idrs.py

View check run for this annotation

Codecov / codecov/patch

vermouth/processors/annotate_idrs.py#L56

Added line #L56 was not covered by tests

def run_molecule(self, molecule):
"""
Assign disordered regions for a single molecule
"""

annotate_disorder(molecule, self.idr_regions)

Check warning on line 63 in vermouth/processors/annotate_idrs.py

View check run for this annotation

Codecov / codecov/patch

vermouth/processors/annotate_idrs.py#L63

Added line #L63 was not covered by tests

return molecule

Check warning on line 65 in vermouth/processors/annotate_idrs.py

View check run for this annotation

Codecov / codecov/patch

vermouth/processors/annotate_idrs.py#L65

Added line #L65 was not covered by tests

def run_system(self, system):
"""
Assign the water bias of the Go model to file. Biasing
is always molecule specific i.e. no two different
vermouth molecules can have the same bias.

Parameters
----------
system: :class:`vermouth.system.System`
"""
if not self.idr_regions:
return system
self.system = system
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
self.system = system

Why do you need this?

LOGGER.info("Annotating disordered regions", type="step")
super().run_system(system)

Check warning on line 81 in vermouth/processors/annotate_idrs.py

View check run for this annotation

Codecov / codecov/patch

vermouth/processors/annotate_idrs.py#L78-L81

Added lines #L78 - L81 were not covered by tests
37 changes: 37 additions & 0 deletions vermouth/processors/water_bias.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
from ..graph_utils import make_residue_graph
from ..rcsu.go_utils import get_go_type_from_attributes, _get_bead_size, _in_resid_region
from ..gmx.topology import NonbondParam
import numpy as np

class ComputeWaterBias(Processor):
"""
Expand Down Expand Up @@ -118,6 +119,41 @@
meta={"comment": ["water bias", sec_struc]})
self.system.gmx_topology_params["nonbond_params"].append(water_bias)

def remove_cross_nb_interactions(self, molecule, res_graph):
"""
Remove Go bonds between folded and disordered regions of a molecule

Parameters
----------
molecule: :class:`vermouth.molecule.Molecule`
the molecule
res_graph: :class:`vermouth.molecule.Molecule`
the residue graph of the molecule
"""
#list of all the Go pairs in the molecule
all_go_pairs = np.array([list(i.atoms) for i in self.system.gmx_topology_params["nonbond_params"] if 'W' not in list(i.atoms)])
# list to record which items we don't want. cross = go potential between folded and disordered domain.
all_cross_pairs = []

for res_node in res_graph.nodes:
resid = res_graph.nodes[res_node]['resid']
_old_resid = res_graph.nodes[res_node]['_old_resid']
chain = res_graph.nodes[res_node]['chain']

if _in_resid_region(_old_resid, self.idr_regions):
vs_go_node = next(get_go_type_from_attributes(res_graph.nodes[res_node]['graph'],
resid=resid,
chain=chain,
prefix=molecule.meta.get('moltype')))
all_cross_pairs.append(np.where(all_go_pairs == vs_go_node)[0]) #just need the first one

# make sure we only have one entry in case a site has more than one interaction
all_cross_pairs = np.unique([x for xs in all_cross_pairs for x in xs])
# delete the folded-disordered Go interactions from the list going backwards.
# otherwise list order gets messed up.
for i in reversed(all_cross_pairs):
del self.system.gmx_topology_params["nonbond_params"][i]

Check warning on line 155 in vermouth/processors/water_bias.py

View check run for this annotation

Codecov / codecov/patch

vermouth/processors/water_bias.py#L155

Added line #L155 was not covered by tests

def run_molecule(self, molecule):
"""
Assign water bias for a single molecule
Expand All @@ -134,6 +170,7 @@
res_graph = make_residue_graph(molecule)

self.assign_residue_water_bias(molecule, res_graph)
self.remove_cross_nb_interactions(molecule, res_graph)

return molecule

Expand Down
1 change: 1 addition & 0 deletions vermouth/tests/data/integration_tests/tier-1/hst5/README
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,4 @@

# -ff martini 3001
# BB-W bias for idr
# add extra IDR potentials
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,4 @@ martinize2
-water-bias
-water-bias-eps idr:0.5
-id-regions 1:24
-idr-tune
Loading
Loading