Skip to content

Commit

Permalink
Added residue-residue distance plot example.
Browse files Browse the repository at this point in the history
  • Loading branch information
tomgoddard committed Mar 5, 2024
1 parent 2ef23c5 commit cee3675
Show file tree
Hide file tree
Showing 5 changed files with 131 additions and 0 deletions.
1 change: 1 addition & 0 deletions index.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ These are examples of [ChimeraX](https://www.cgl.ucsf.edu/chimerax/) command use

## Python Examples

* [Plot residue-residue distances](rrdist/rrdist.md). March 5, 2024
* [Smooth surface coloring sharp edges](color_smooth/color_smooth.md). February 16, 2024
* [Search AlphaFold database for transmembrane proteins](alphafold_mining/af_mining.md). January 19, 2024
* [Measure spots seen in 3D microscopy](spots/spots.md). November 6, 2023
Expand Down
Binary file added rrdist/8q5h.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
77 changes: 77 additions & 0 deletions rrdist/rrdist.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
# Show residue-residue distance heatmap

Here is Python code defining a command "rrdist" that computes the distances between C-alpha atoms for all pairs of protein residues in a structure and plots them as a heatmap. The Chimera [RR Distance Maps](https://www.cgl.ucsf.edu/chimera/docs/ContributedSoftware/rrdistmaps/rrdistmaps.html) tool does this, but there is no equivalent tool in ChimeraX. To plot the distances in ChimeraX this Python uses the AlphaFold PAE plot. The distances are written to a text JSON file in the AlphaFold PAE format. Pablo Herrera Nieta [asked](https://mail.cgl.ucsf.edu/mailman/archives/list/[email protected]/thread/56YWK5QPB7O4W2TFV2NRO63HU5G7JJTW/) about this on the ChimeraX mailing list.

To define the rrdist command open [rrdist.py](rrdist.py) in ChimeraX

open rrdist.py

then open a structure and use the rrdist command on it specifying a file path for the json file and the plot will be shown.

open 8q5h
rrdist #1 dist.json

<img src="rrdist.png" height="300"><img src="8q5h.png" height="300">

The black lines in the plot separate the chains, and the first to last residues run from the upper left corner of the plot down the vertical axis and to the right across the horizontal axis. Dragging the mouse on the plot colors ribbon residues (not atoms). See the ChimeraX AlphaFold PAE plot documentation for an explanation. You may want to delete not protein chains before running rrdist using

delete ~protein

Here is the [rrdist.py](rrdist.py) code:

# Compute all pairwise distances between residues and write to a JSON file in AlphaFold PAE
# format so that the distance map can be displayed as a 2D plot with menu entry
# Tools / Structure Prediction / AlphaFold Error Plot.

def rr_distance_map(session, structure, json_output_path):
residues = structure.residues

# Choose atom for each residue to measure distances
atoms = []
for r in residues:
a = r.principal_atom
if a is None:
# Use the first atom if no principal atom.
# The distance matrix must have the same size as the number of residues
# in the structure for the AlphaFold PAE plot to work.
a = r.atoms[0]
atoms.append(a)

# Compute distance matrix
from chimerax.atomic import Atoms
xyz = Atoms(atoms).scene_coords
n = len(xyz)
from numpy import empty, float32, sqrt
dist = empty((n,n), float32)
for i in range(n):
row = xyz - xyz[i]
dist[i,:] = sqrt((row*row).sum(axis = 1))

# Write matrix in JSON AlphaFold PAE format
# {"pae": [[17.14, 18.75, 17.91, ...], [5.32, 8.23, ...], ... ]}
dists = ', '.join(('[ ' + ', '.join('%.2f' % dist[i,j] for j in range(n)) + ' ]')
for i in range(n))
with open(json_output_path, 'w') as file:
file.write('{"pae": [')
file.write(dists)
file.write(']}')

# Open PAE plot
from chimerax.core.commands import run, quote_if_necessary
open_cmd = f'alphafold pae #{structure.id_string} file {quote_if_necessary(json_output_path)}'
run(session, open_cmd)

def register_command(logger):
from chimerax.core.commands import CmdDesc, register, SaveFileNameArg
from chimerax.atomic import StructureArg
desc = CmdDesc(
required = [('structure', StructureArg),
('json_output_path', SaveFileNameArg)],
synopsis = 'Compute residue-residue distance map and show with AlphaFold PAE plot'
)
register('rrdist', desc, rr_distance_map, logger=logger)

register_command(session.logger)


Tom Goddard, March 5, 2024
Binary file added rrdist/rrdist.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
53 changes: 53 additions & 0 deletions rrdist/rrdist.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
# Compute all pairwise distances between residues and write to a JSON file in AlphaFold PAE
# format so that the distance map can be displayed as a 2D plot with menu entry
# Tools / Structure Prediction / AlphaFold Error Plot.

def rr_distance_map(session, structure, json_output_path):
residues = structure.residues

# Choose atom for each residue to measure distances
atoms = []
for r in residues:
a = r.principal_atom
if a is None:
# Use the first atom if no principal atom.
# The distance matrix must have the same size as the number of residues
# in the structure for the AlphaFold PAE plot to work.
a = r.atoms[0]
atoms.append(a)

# Compute distance matrix
from chimerax.atomic import Atoms
xyz = Atoms(atoms).scene_coords
n = len(xyz)
from numpy import empty, float32, sqrt
dist = empty((n,n), float32)
for i in range(n):
row = xyz - xyz[i]
dist[i,:] = sqrt((row*row).sum(axis = 1))

# Write matrix in JSON AlphaFold PAE format
# {"pae": [[17.14, 18.75, 17.91, ...], [5.32, 8.23, ...], ... ]}
dists = ', '.join(('[ ' + ', '.join('%.2f' % dist[i,j] for j in range(n)) + ' ]')
for i in range(n))
with open(json_output_path, 'w') as file:
file.write('{"pae": [')
file.write(dists)
file.write(']}')

# Open PAE plot
from chimerax.core.commands import run, quote_if_necessary
open_cmd = f'alphafold pae #{structure.id_string} file {quote_if_necessary(json_output_path)}'
run(session, open_cmd)

def register_command(logger):
from chimerax.core.commands import CmdDesc, register, SaveFileNameArg
from chimerax.atomic import StructureArg
desc = CmdDesc(
required = [('structure', StructureArg),
('json_output_path', SaveFileNameArg)],
synopsis = 'Compute residue-residue distance map and show with AlphaFold PAE plot'
)
register('rrdist', desc, rr_distance_map, logger=logger)

register_command(session.logger)

0 comments on commit cee3675

Please sign in to comment.