Crates.io | rnapkin |
lib.rs | rnapkin |
version | 0.3.9 |
source | src |
created_at | 2022-11-22 00:12:58.364339 |
updated_at | 2023-05-10 10:27:51.239327 |
description | CLI utility for drawing RNA secondary structure |
homepage | |
repository | https://github.com/ukmrs/rnapkin |
max_upload_size | |
id | 720534 |
size | 102,135 |
rnapkin accepts a file containing secondary structure and optionally sequence and a name. For example you could have this marvelous RNA molecule sitting peacefully in a file called "guaniners"
>fantastic guanine riboswitch
AAUAUAAUAGGAACACUCAUAUAAUCGCGUGGAUAUGGCACGCAAGUUUCUACCGGGCAC
..........(..(.((((.((((..(((((.......)))))..........((((((.
CGUAAAUGUCCGACUAUGGGUGAGCAAUGGAACCGCACGUGUACGGUUUUUUGUGAUAUC
......)))))).....((((((((((((((((((........))))))...........
AGCAUUGCUUGCUCUUUAUUUGAGCGGGCAAUGCUUUUUUUA
..)))))))))))).)))).)))).)..).............
Then, if you wish to visualize it, you could invoke rnapkin thus:
rnapkin guaniners
Surely rnapkin would respond with the name of a file it has just drawn to:
fantastic_guanine_riboswitch.svg
And this scalable vector graphic would be produced:
I happen to quite enjoy the outcome, so I would say:
that's pretty neat
Your mileage may vary though.
If you'd like to see this or any other RNA molecule upside-down, tilted or what have you, there are some options listed below that you can use and combine:
-a / --angle <DEGREES> | starting Angle / boils down to clockwise rotation
--mx | Mirror along X axis / aka vertical flip
--my | Mirror along Y axis / aka horizontal flip
color themes can be changed by -t option as demonstrated; a config file allowing to define custom color themes is planned though unimplemented!()
I plan to offer precompiled binaries but for now you'll need rust. Easiest way to acquire rust is via rustup :crab:
cargo install rnapkin
Fontconfig is the default Fontmanagement utility on Linux and Unix but WSL may not have them installed;
sudo apt-get install libfontconfig libfontconfig1-dev
cargo install rnapkin
input can be served to rnapkin as a file or be piped in:
rnapkin cmolecule.fa -a 20 -o crab
echo ".......(((((......))))).....(((((......)))))......." | rnapkin -a 20 -o crab
input is quite flexible; it should contain secondary_structure and optionally name and sequence. Name has to start with ">" and can be overwritten with -o flag which has priority. Here are some variations of valid input files:
# you can add .png to the name to request png instead of svg
@ the same of course can be achieved with -o flag.
* this is a comment btw: any symbol other than ">.()" works but prefer "#"
>simple molecule.png
((((((((((..((((((.........))))))......).((((((.......))))))..)))))))))
CGCUUCAUAUAAUCCUAAUGAUAUGGUUUGGGAGUUUCUACCAAGAGCCUUAAACUCUUGAUUAUGAAGUG
There are 9 available colors denoted by 1-9, while 0 means None. For example consider input below representing SAM riboswitch in the OFF conformation according to smFRET study by Manz et al. 2017. By using numbers in the input we can mark aptamer forming helices P1, P2, P3, P4 #2-#5 and the TERMINATOR #1.
> offsam
0000022222222223333333333333333333333333333333333444444444444444444444444444444
AUAUCCGUUCUUAUCAAGAGAAGCAGAGGGACUGGCCCGACGAUGCUUCAGCAACCAGUGUAAUGGCGAUCAGCCAUGA
.......((((((((....(((((...(((.....)))......)))))(((..(((((...(((((.....))))).)
4444444444555555555555555555555555555522222222222211111111111111111111111111111
CUAAGGUGCUAAAUCCAGCAAGCUCGAACAGCUUGGAAGAUAAGAAGAGACAAAAUCACUGACAAAGUCUUCUUCUUAA
))..)).)))........((((((.....))))))...)))))))).................((((((.((((...))
111111111111
GAGGACUUUUUU
)).))))))...
.........(((..((((((...((((((((.....((((((((((...)))))).....
(((((((...))))))).))))(((.....)))...)))).)))).))))))..)))..(
(((.(((((..(((......))).)))))..))))(((((((((((((....))))))))
))))).....
sequence and secondary structure can be separate, mixed and aligned, everything should work.
using -p / --points flag you can make rnapkin print calculated coordinates of nucleotide bubbles (with 0.5 unit radius). You can then plot it yourself if you need to do something specific;
If you happen to clone the repository, there is an example python script using matplotlib that you can pipe the input to.
cargo run -- atelier/example_inputs/guaniners -p | atelier/plot.py
You can also combine -p flag with --mx --my and -a
The wordsmithing proccess was arduous. It involved googling "words starting with na" and looking for anything drawing related. Once the word was found, unparalled strength was employed to slap it on top of "rna" ultimately creating this glorious amalgamation.
You ever heard of all those physicists, mathematicians and the like, scribbling formulas on the
back of a napkin or a book margin? There is even a wikipedia page about it.
It doesn't take much mental gymnastic to imagine a biologist frantically scrambling together rna structure on a napkin. I am currently working on baiting my biologist friend into heated rna debate while in close proximity to abundant napkin source in order to produce a proof of concept.