Importing from to tRNAdb and mitotRNAdb as GRanges

Introduction

The tRNAdb and mttRNAdb (Jühling et al. 2009) is a compilation of tRNA sequences and tRNA genes. It is a follow up version of the database of Sprinzl et al.  (Sprinzl and Vassilenko 2005).

Using tRNAdbImport the tRNAdb can be accessed as outlined on the website http://trna.bioinf.uni-leipzig.de/ and the results are returned as a GRanges object.

Status 2024

The tRNAdb Server is currently not available. Some chunks of the code in this vignette are currently not avilable. See https://www.bioinf.uni-leipzig.de/services/webservices for more information.

Importing as GRanges

library(tRNAdbImport)
# accessing tRNAdb
# tRNA from yeast for Alanine and Phenylalanine
gr <- import.tRNAdb(organism = "Saccharomyces cerevisiae",
                    aminoacids = c("Phe","Ala"))
## Warning: tRNAdb Server seems to be not available.
# get a Phenylalanine tRNA from yeast
gr <- import.tRNAdb.id(tdbID = gr[gr$tRNA_type == "Phe",][1L]$tRNAdb_ID)
# find the same tRNA via blast
gr <- import.tRNAdb.blast(blastSeq = gr$tRNA_seq)
# accessing mtRNAdb
# get the mitochrondrial tRNA for Alanine in Bos taurus
gr <- import.mttRNAdb(organism = "Bos taurus", 
                      aminoacids = "Ala")
## Warning: tRNAdb Server seems to be not available.
# get one mitochrondrial tRNA in Bos taurus. 
gr <- import.mttRNAdb.id(mtdbID = gr[1L]$tRNAdb_ID)
# check that the result has the appropriate columns
istRNAdbGRanges(gr)
## Warning: Input GRanges object does not meet the requirements of the function. The following columns are expected:
## 'tRNA_length', 'tRNA_type', 'tRNA_anticodon', 'tRNA_seq', 'tRNA_str', 'tRNA_CCA.end', 'tRNAdb_ID', 'tRNAdb', 'tRNAdb_organism', 'tRNAdb_strain', 'tRNAdb_taxonomyID', 'tRNAdb_verified'.
## [1] FALSE

Importing as GRanges from the RNA database

The tRNAdb offers two different sets of data, one containing DNA sequences and one containing RNA sequences. Depending on the database selected, DNA as default, the GRanges will contain a DNAStringSet or a ModRNAStringSet as the tRNA_seq column. Because the RNA sequences can contain modified nucleotides, the ModRNAStringSet class is used instead of the RNAStringSet class to store the sequences correctly with all information intact.

gr <- import.tRNAdb(organism = "Saccharomyces cerevisiae",
                    aminoacids = c("Phe","Ala"),
                    database = "RNA")
gr$tRNA_seq

The special characters in the sequence might no exactly match the ones shown on the website, since they are sanitized internally to a unified dictionary defined in the Modstrings package. However, the type of modification encoded will remain the same (See the Modstrings package for more details).

The information on the position and type of the modifications can also be converted into a tabular format using the separate function from the Modstrings package.

separate(gr$tRNA_seq)

Further analysis

The output can be saved or directly used for further analysis.

library(Biostrings)
library(rtracklayer)
# saving the tRAN sequences as fasta file
writeXStringSet(gr$tRNA_seq, filepath = tempfile())
# converting tRNAdb information to GFF compatible values
gff <- tRNAdb2GFF(gr)
gff
# Saving the information as gff3 file
export.gff3(gff, con = tempfile())

Please have a look at the tRNA package for further analysis of the tRNA sequences.

Session info

sessionInfo()
## R version 4.4.2 (2024-10-31)
## Platform: x86_64-pc-linux-gnu
## Running under: Ubuntu 24.04.1 LTS
## 
## Matrix products: default
## BLAS:   /usr/lib/x86_64-linux-gnu/openblas-pthread/libblas.so.3 
## LAPACK: /usr/lib/x86_64-linux-gnu/openblas-pthread/libopenblasp-r0.3.26.so;  LAPACK version 3.12.0
## 
## locale:
##  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
##  [3] LC_TIME=en_US.UTF-8        LC_COLLATE=C              
##  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
##  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
##  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
## [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
## 
## time zone: Etc/UTC
## tzcode source: system (glibc)
## 
## attached base packages:
## [1] stats4    stats     graphics  grDevices utils     datasets  methods  
## [8] base     
## 
## other attached packages:
##  [1] rtracklayer_1.67.0   tRNAdbImport_1.25.0  tRNA_1.25.0         
##  [4] Structstrings_1.23.1 Modstrings_1.23.0    Biostrings_2.75.3   
##  [7] XVector_0.47.2       GenomicRanges_1.59.1 GenomeInfoDb_1.43.2 
## [10] IRanges_2.41.2       S4Vectors_0.45.2     BiocGenerics_0.53.3 
## [13] generics_0.1.3       BiocStyle_2.35.0    
## 
## loaded via a namespace (and not attached):
##  [1] SummarizedExperiment_1.37.0 gtable_0.3.6               
##  [3] rjson_0.2.23                xfun_0.50                  
##  [5] bslib_0.8.0                 ggplot2_3.5.1              
##  [7] httr2_1.0.7                 lattice_0.22-6             
##  [9] Biobase_2.67.0              vctrs_0.6.5                
## [11] tools_4.4.2                 bitops_1.0-9               
## [13] curl_6.1.0                  parallel_4.4.2             
## [15] tibble_3.2.1                pkgconfig_2.0.3            
## [17] Matrix_1.7-1                lifecycle_1.0.4            
## [19] GenomeInfoDbData_1.2.13     compiler_4.4.2             
## [21] stringr_1.5.1               Rsamtools_2.23.1           
## [23] munsell_0.5.1               codetools_0.2-20           
## [25] htmltools_0.5.8.1           sys_3.4.3                  
## [27] buildtools_1.0.0            sass_0.4.9                 
## [29] RCurl_1.98-1.16             yaml_2.3.10                
## [31] pillar_1.10.1               crayon_1.5.3               
## [33] jquerylib_0.1.4             BiocParallel_1.41.0        
## [35] DelayedArray_0.33.3         cachem_1.1.0               
## [37] abind_1.4-8                 digest_0.6.37              
## [39] stringi_1.8.4               restfulr_0.0.15            
## [41] maketools_1.3.1             fastmap_1.2.0              
## [43] grid_4.4.2                  SparseArray_1.7.3          
## [45] colorspace_2.1-1            cli_3.6.3                  
## [47] magrittr_2.0.3              S4Arrays_1.7.1             
## [49] XML_3.99-0.18               scales_1.3.0               
## [51] UCSC.utils_1.3.1            rappdirs_0.3.3             
## [53] rmarkdown_2.29              httr_1.4.7                 
## [55] matrixStats_1.5.0           evaluate_1.0.3             
## [57] knitr_1.49                  BiocIO_1.17.1              
## [59] rlang_1.1.4                 glue_1.8.0                 
## [61] BiocManager_1.30.25         xml2_1.3.6                 
## [63] jsonlite_1.8.9              R6_2.5.1                   
## [65] MatrixGenerics_1.19.1       GenomicAlignments_1.43.0

References

Jühling, Frank, Mario Mörl, Roland K. Hartmann, Mathias Sprinzl, Peter F. Stadler, and Joern Pütz. 2009. “tRNAdb 2009: Compilation of tRNA Sequences and tRNA Genes.” Nucleic Acids Research 37 (suppl_1): D159–62. https://doi.org/10.1093/nar/gkn772.
Sprinzl, Mathias, and Konstantin S. Vassilenko. 2005. “Compilation of tRNA Sequences and Sequences of tRNA Genes.” Nucleic Acids Research 33 (suppl_1): D139–40. https://doi.org/10.1093/nar/gki012.