Skip to main content

Draw RNA secondary structures in Python

Project description

draw_rna

Generate quick secondary structures of nucleic acids via jupyter notebook or command line.

A communal and continuing effort by the Das Lab, Eterna Players, M. Wu, H. Wayment-Steele.

Dependencies

The default behavior is to output the secondary structure visualization to both svg and png. The png requires Inkscape, whose directory must be set by environmental variable INKSCAPEDIR.

Install

Clone this repository to your hard drive and install as follows:

git clone git@github.com:DasLab/draw_rna.git
cd draw_rna/
python setup.py install

Warning if you see errors in using the repository, it maybe due to your draw_rna directory sitting in a folder like src/ which already is in your Python Path. in that case, rename draw_rna to draw_rna_directory and/or move it to another spot in your system.

Basic Usage

Jupyter notebook

See example_files/demo.ipynb for more. In brief:


Input file

An input file is used to specify the sequence, secondary structure, and coloring of the desired drawing. The format is as follows

filename      # image will be written to filename.svg
GTGANNNNNTCAC # nucleic acid sequence
((((.....)))) # nucleic acid secondary structure in dot-bracket notation
rrrrbbbbbgggg # optional: coloring of each base (e.g. r for red, g for green, b for blue)

Multiple sequences can be specified in one file as in example_input.txt.

Execution

The draw script can be run with

python draw_rna/draw_all.py example_files/command_line/example_input.txt

You'll get files example_contours.svg, example_sequence_colors.svg, example_specific_colors.svg. Example output available in example_files/command_line/.

Sample secondary structure diagrams:

Notes on usage

Multistrand drawing

At the moment, current practice is to include blanks between strands such as:

filename     
GTGANN NNTCAC
((((.....))))
rrrrbbwbbgggg

And then remove nucleotides corresponding to blanks afterwards. (This would be a quick fix.)

NOTE ON render_rna and render_rna_flip:

'render_rna_flip.py' is what is currently called in the main routine and where major edits have been made. render_rna.py renders 3' -> 5'. TODO: handle 3' -> 5' drawing better.

Extended options

Draw a large thing with linear exterior loop and with a custom color vector:

python draw_all.py covid19_5primeUTR.txt --large_mode --color_values perc_conserved_5UTR.txt --png

If you use --color_values with an input file with multiple structures, the same colors will be applied to all the structures.

Draw from RDAT file containing reactivity

Requires RDATkit to be in working python path. Example command:

python draw_from_rdat.py ETERNA_R69_0000.rdat 297 --png

Movie mode

More coming eventually. For now, if you generate a bunch of stills, say from a cotranscriptional simulation, can string them together with ImageMagick:

convert -delay 25 my_stills_*.png my_great_trajectory.gif

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

draw_rna-0.1.0.tar.gz (13.7 kB view details)

Uploaded Source

Built Distribution

draw_rna-0.1.0-py3-none-any.whl (17.7 kB view details)

Uploaded Python 3

File details

Details for the file draw_rna-0.1.0.tar.gz.

File metadata

  • Download URL: draw_rna-0.1.0.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for draw_rna-0.1.0.tar.gz
Algorithm Hash digest
SHA256 9b6f83adb3f92c2ad3ef63a17a895b7fe8cef1300c11fcfd484e944ba3f9c914
MD5 a7789aeab770287051a32dbe5e6a3423
BLAKE2b-256 441569b51ff8881bfa70d7ca1494cc2090ef9b98d430f31131e9822a63a49450

See more details on using hashes here.

File details

Details for the file draw_rna-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: draw_rna-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 17.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for draw_rna-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 44e99e96df0e8b92b2aab1e5194d809323b7aa4bbb96e2bbb506b3bafd8861fc
MD5 5379efd62571efd3d551f655789ff963
BLAKE2b-256 3a7ac70d84a32a2dc482b4d60ebf96b7042e0ed580a067266f898c07280932b0

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