Skip to content

Commit

Permalink
Add hydrogens to caps (openmm#320)
Browse files Browse the repository at this point in the history
  • Loading branch information
peastman authored Dec 3, 2024
1 parent c83d125 commit b31b57b
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 1 deletion.
4 changes: 3 additions & 1 deletion pdbfixer/pdbfixer.py
Original file line number Diff line number Diff line change
Expand Up @@ -389,11 +389,13 @@ def __init__(self, filename=None, pdbfile=None, pdbxfile=None, url=None, pdbid=N
# Load the templates.

self.templates = {}
self._standardTemplates = set()
templatesPath = os.path.join(os.path.dirname(__file__), 'templates')
for file in os.listdir(templatesPath):
templatePdb = app.PDBFile(os.path.join(templatesPath, file))
name = next(templatePdb.topology.residues()).name
self.templates[name] = Template(templatePdb.topology, templatePdb.positions)
self._standardTemplates.add(name)

def _initializeFromPDB(self, file):
"""Initialize this object by reading a PDB file."""
Expand Down Expand Up @@ -1413,7 +1415,7 @@ def _downloadNonstandardDefinitions(self):

def _describeVariant(self, residue, definitions):
"""Build the variant description to pass to addHydrogens() for a residue."""
if residue.name not in app.PDBFile._standardResidues and self._getTemplate(residue.name) is not None:
if residue.name not in self._standardTemplates and self._getTemplate(residue.name) is not None:
# The user has registered a template for this residue. Use the hydrogens from it.
template = self._getTemplate(residue.name)
atoms = [(atom.name, atom.element.symbol.upper(), terminal) for atom, terminal in zip(template.topology.atoms(), template.terminal)]
Expand Down
20 changes: 20 additions & 0 deletions pdbfixer/tests/data/alanine-dipeptide.pdb
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
REMARK 1 CREATED WITH OPENMM 8.2, 2024-12-03
HETATM 1 CH3 ACE A 1 2.000 2.090 0.000 1.00 0.00 C
HETATM 2 C ACE A 1 3.427 2.641 -0.000 1.00 0.00 C
HETATM 3 O ACE A 1 4.391 1.877 -0.000 1.00 0.00 O
ATOM 4 N ALA A 2 3.555 3.970 -0.000 1.00 0.00 N
ATOM 5 CA ALA A 2 4.853 4.614 -0.000 1.00 0.00 C
ATOM 6 CB ALA A 2 5.661 4.221 -1.232 1.00 0.00 C
ATOM 7 C ALA A 2 4.713 6.129 0.000 1.00 0.00 C
ATOM 8 O ALA A 2 3.601 6.653 0.000 1.00 0.00 O
HETATM 9 N NME A 3 5.846 6.835 0.000 1.00 0.00 N
HETATM 10 C NME A 3 5.846 8.284 0.000 1.00 0.00 C
TER 11 NME A 3
CONECT 1 2
CONECT 2 1 3 4
CONECT 3 2
CONECT 4 2
CONECT 7 9
CONECT 9 7 10
CONECT 10 9
END
7 changes: 7 additions & 0 deletions pdbfixer/tests/test_add_hydrogens.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,3 +42,10 @@ def test_registered_template():
count = sum(1 for atom in residue.atoms() if atom.element.symbol == 'H')
if residue.name == 'CAS':
assert count == 9

def test_end_caps():
"""Test adding hydrogens to a chain capped with ACE and NME."""
fixer = pdbfixer.PDBFixer(filename=(Path(__file__).parent / "data" / "alanine-dipeptide.pdb").as_posix())
fixer.addMissingHydrogens()
forcefield = app.ForceField('amber14/protein.ff14SB.xml')
forcefield.createSystem(fixer.topology)

0 comments on commit b31b57b

Please sign in to comment.