Skip to main content

The program takes in a Molecular Assembly PDB file as arument, finds the right orientation such that the ring sits on the XY plane, projects all atoms onto the XY plane and calculates the max diameter between two atoms that lie furthest apart on the XY plane

Project description

calcDiameter: a method to find the maximum diameter of a ring-shaped protein complex of symmetry Cn.


How it works

It reads a ‘Biological Assembly’ PDB file and finds the right orientation such that the protein ring lies ‘flat’ on XY plane. Then, the maximum distance between any pair of residues residing in the same ‘height slice’ is returned. On top of that the method returns the ‘effective radius’

Installation

Via pip from PyPi (recommended):

$ sudo pip install calcDiameter

If your system lacks pip, install it first.

Python version

The tool was developed using Python 3.7, however running under Python 3.x should work as well.

Usage

Python 3.7 shell

>>> from calcDiameter import *
>>> calcDiameter('1qaw.pdb')
Reading PDB file
Obtaining approximate orientation by testing rotations about X and Y axes every 10 degrees...
Obtaining accurate orientation by testing rotations about X and Y axes every 1 degree...
Plotting projecton of CA atom coordinates onto the XY plane
Max diameter between E:75 & K:17 is 79.701881; effective radius is 39.898543
(79.70188096903092, 'E:75', 'K:17', 39.89854271684067)

You can set the tolerated height difference between points using the bin_ parameter; by default=3 Angstrom, change to 30 (the Z component of the distance is disregarded regardless of the bin_ parameter!). Note that the effective radius has not changed:

>>> calcDiameter.calcDiameter('1qaw.pdb', bin_=30)
Reading PDB file
Obtaining approximate orientation by testing rotations about X and Y axes every 10 degrees...
Obtaining accurate orientation by testing rotations about X and Y axes every 1 degree...
Plotting projecton of CA atom coordinates onto the XY plane
Max diameter between E:75 & K:18 is 79.706971; effective radius is 39.898543
(79.70697056799868, 'E:75', 'K:18', 39.89854271684067)

The full list of options is as follows

>>>calcDiameter(pdb, plot=True, plot3d=False, no_rotation=False, bin_=3, test=5)

You can set ‘no_rotation’ to True if you believe that the pdb is already correctly oriented - the structure is already flat on the XY plane.

You can also set plot3d to True if you want to see the 3d plots of points making up the structure. First you will see the original orientation of the pdb - feel free to look at it from all angles, then close it to see the best orientation that the program has found - the structure should lie flat on the XY plane; close the plot to obtain the max diameter along the XY plane.

The test parameter specifies the radius of the structure (from its centre) that is expected to stay hollow provided we have found the right orientation for the structure.

Then you can query PDB to retrieve all structures of rotational symmetry Cn (specify n); returns a pandas data-frame with parameters calculated for the structures:

>>> getDiametersCn(13)
Retrieving list of PDBs that match the selected criteria...
    2JES,2X2V,3JVO,4CBJ,4CBK,4V2T,4XJN,6GY6
    Downloading PDB 2JES
    Reading 2JES PDB file
    Obtaining approximate orientation by testing rotations about X and Y axes every 10 degrees...
    (...)
            Diameter label1 label2  Eff. radus  Cn
    2JES  162.626456   G:30   U:29   81.913051  13
    2X2V   60.312264   G:40   M:40   30.425173  13
    3JVO  110.369143    C:1   I:50   55.239389  13
    4CBJ   60.344003   F:40   M:40   30.422166  13
    4CBK   60.169909   E:40   L:40   30.276677  13
    4V2T  220.978870   C:82   X:82  111.307835  13
    4XJN  193.364481  B:110  M:110   97.363493  13
    6GY6  249.636369  I:151  S:151  125.730877  13

The full list of options is as follows: res_min & res_max are the minimum and maximum structure resolution thresholds - defaults 0.0 and 3.0, respectively:

>>>getDiametersCn(n, res_min = 0.0, res_max = 3.0, plot=True, bin_=3, test=5)

Licence

MIT

Authors

Jan Zaucha

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

calcDiameter-0.17.tar.gz (7.4 kB view details)

Uploaded Source

File details

Details for the file calcDiameter-0.17.tar.gz.

File metadata

  • Download URL: calcDiameter-0.17.tar.gz
  • Upload date:
  • Size: 7.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.7

File hashes

Hashes for calcDiameter-0.17.tar.gz
Algorithm Hash digest
SHA256 4c28962e65a29e3f621f8bff4c4bebe4c25e3364b75a423f13b166f8cec286fa
MD5 2f6db619ebaf9c8125e2d8d2fd82ed5c
BLAKE2b-256 b0a24de4785dfcd0466406ced17972a68682ed55967d9accd44caf5b03f876f5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page