Name Mode Size
..
Rdisop.Rmd 100644 10 kb
Rdisop.bib 100644 8 kb
README.md
<!-- README.md is generated from README.Rmd. Please edit that file --> # Rdisop <!-- badges: start --> [![R-CMD-check](https://github.com/sneumann/Rdisop/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/sneumann/Rdisop/actions/workflows/R-CMD-check.yaml) [![DOI](https://img.shields.io/badge/doi-10.1093/bioinformatics/btm631-yellow.svg)](https://doi.org/10.1093/bioinformatics/btm631) <!-- badges: end --> In high resolution mass spectrometry (HR-MS), the measured masses can be decomposed into potential element combinations (chemical sum formulas). Where additional mass/intensity information of respective isotopic peaks is available, decomposition can take this information into account to better rank the potential candidate sum formulas. To compare measured mass/intensity information with the theoretical distribution of candidate sum formulas, the latter needs to be calculated. This package implements fast algorithms to address both tasks, the calculation of isotopic distributions for arbitrary sum formulas (assuming a HR-MS resolution of roughly 30,000), and the ranked list of sum formulas fitting an observed peak or isotopic peak set. ## Installation You can install the development version of **Rdisop** using: ``` r # install.packages("devtools") devtools::install_github("sneumann/Rdisop") ``` ## Example The user can use built in sets of chemical elements or define such sets specifically and get informations on a specified sum formula, *i.e.* the isotopic distribution which would be observed in HR-MS. ``` r ele <- initializeElements(c("C","H","N","O","Mg")) chlorophyll <- getMolecule("C55H72MgN4O5H", elements = ele) getIsotope(chlorophyll, 1:4) #> [,1] [,2] [,3] [,4] #> [1,] 893.5431390 894.5459934 895.546247 896.54752708 #> [2,] 0.4140648 0.3171228 0.178565 0.06773657 ``` For individual masses, potential molecules can be calculated. ``` r decomposeMass(mass = 46.042, ppm = 20, maxisotopes = 4) #> $formula #> [1] "C2H6O" #> #> $score #> [1] 1 #> #> $exactmass #> [1] 46.04186 #> #> $charge #> [1] 0 #> #> $parity #> [1] "e" #> #> $valid #> [1] "Valid" #> #> $DBE #> [1] 0 #> #> $isotopes #> $isotopes[[1]] #> [,1] [,2] [,3] [,4] #> [1,] 46.0418648 47.04534542 48.04631711 4.904960e+01 #> [2,] 0.9749152 0.02293559 0.00210353 4.540559e-05 ``` This decomposition can also be performed for measurements containing several isotopes. ``` r # glutamic acid (C5H9NO4) mol <- decomposeIsotopes(masses = c(147.053, 148.056), intensities = c(93, 5.8)) data.frame(getFormula(mol), getScore(mol), getValid(mol)) #> getFormula.mol. getScore.mol. getValid.mol. #> 1 C5H9NO4 1.000000e+00 Valid #> 2 C3H17P2S 1.935336e-09 Invalid ```