MyNixOS website logo
Description

Open-Source Software for 'Omic' Data Analysis and Visualization.

A tool for interactive exploration of the results from 'omics' experiments to facilitate novel discoveries from high-throughput biology. The software includes R functions for the 'bioinformatician' to deposit study metadata and the outputs from statistical analyses (e.g. differential expression, enrichment). These results are then exported to an interactive JavaScript dashboard that can be interrogated on the user's local machine or deployed online to be explored by collaborators. The dashboard includes 'sortable' tables, interactive plots including network visualization, and fine-grained filtering based on statistical significance.

CRAN status R CMD check status from GitHub Actions Monthly downloads

OmicNavigator: Open-Source Software for Omic Data Analysis and Visualization

Exploring the results of omic analyses via interactive web applications facilitates cross-disciplinary collaboration and biological discovery. OmicNavigator is open-source software for the archival and interactive exploration of results from high-throughput biology experiments. The software enables omic data analysts (typically bioinformaticians) to create customizable web applications from the results of their work using only the statistical programming language, R. OmicNavigator is an R package that contains web application code, R functions for programmatic access and data deposition, and a new container for the storage of measurements (e.g. RNAseq read counts), statistical analyses (differential expression and/or enrichment analysis), metadata, and custom plotting functions. Studies created with OmicNavigator are themselves R packages, accessible via a JavaScript dashboard that can be interrogated on the user’s local machine or deployed online to be explored by collaborators. The dashboard combines user-defined study results and feature plots with performant tables and interactive graphics common to bioinformatic analyses such as scatter, network, volcano, and barcode plots. The tool also includes dynamic, multi-set filtering across hypothesis tests based on user-defined thresholds such as statistical significance or effect size.

This repository contains the R package. To see an example of how to create an OmicNavigator study, check out the repository OmicNavigatorExample. If you're a developer interested in the web application code, check out the repository OmicNavigatorWebApp.

Features

  • Simple, yet flexible study-model-test data model for differential and/or enrichment analyses
  • Well documented data-in functions and a novel data container
  • User-defined results and feature plots
  • Richly featured tables
  • Interactive scatter/volcano plots
  • Interactive barcode plots for enrichment results
  • Dynamic network views of enriched terms
  • Multi-set filtering across hypothesis tests

Quick start

To get a quick sense of how the app works, the quick start instructions below install the package, create a very minimal study, and then starts the app. It should automatically open a new tab in your browser. When you're done, press ctrl+c or Esc to stop running the app.

# Install and load the package
install.packages("OmicNavigator", dependencies = TRUE)
library(OmicNavigator)

# Create a very minimal study with a single results table
quickstart <- createStudy("quickstart")
data("RNAseq123")
head(basal.vs.lp)
resultsTable <- basal.vs.lp[, -2:-3]
quickstart <- addResults(quickstart, list(model = list(test = resultsTable)))
installStudy(quickstart)

# (optional) Install the example study RNAseq123 which demos many of the app's
# available features
install.packages(c("gplots", "heatmaply", "iheatmapr", "plotly", "viridis"))
tarball <- "https://github.com/abbvie-external/OmicNavigatorExample/releases/latest/download/ONstudyRNAseq123.tar.gz"
install.packages(tarball, repos = NULL)

# Install and start the web app
installApp()
startApp()

To learn how to add your own data to the app, please read the User's Guide attached to the latest GitHub Release. The more data you add, the more features are automatically enabled in the app (e.g. the Enrichment Analysis tab is available once you add the results of an enrichment analysis).

Installation

OmicNavigator is a web app and R code bundled together as an R package. You can install OmicNavigator multiple ways.

Full installation in 2 steps (recommended)

This is the quickest and easiest method for you to be able to install OmicNavigator and run the web app on your local machine.

  1. Install the OmicNavigator R package directly from CRAN:

    install.packages("OmicNavigator", dependencies = TRUE)
    
  2. Install the web app:

    library(OmicNavigator)
    installApp()
    

Full installation from release tarball

Alternatively, you can install the OmicNavigator release tarball, which already includes the web app bundled with the R package.

  1. Download the tarball from the latest GitHub Release. It will look like OmicNavigator_x.x.x.tar.gz, where x.x.x corresponds to the version.

  2. Install the dependencies:

    remotes::install_deps("OmicNavigator_x.x.x.tar.gz", dependencies = TRUE)
    
  3. Install OmicNavigator from the release tarball:

    1. In the R console:

      install.packages("OmicNavigator_x.x.x.tar.gz", repos = NULL)
      
    2. In the terminal:

      R CMD INSTALL --no-multiarch --with-keep.source OmicNavigator_x.x.x.tar.gz
      

Minimal installation

If you are only using the R package functions, and don't need to run the app, you can perform a minimal installation. This is useful if you are using OmicNavigator in a data engineering pipeline or as part of a continuous integration build.

  1. Install the OmicNavigator R package directly from CRAN, without the extra dependencies required to run the app:

    install.packages("OmicNavigator")
    

Install development version from GitHub

If you need access to the latest changes to OmicNavigator, you can install the development version of the package directly from GitHub.

  1. Install the OmicNavigator R package directly from GitHub:

    remotes::install_github("abbvie-external/OmicNavigator", dependencies = TRUE)
    
  2. Install the web app:

    library(OmicNavigator)
    installApp()
    

Installation troubleshooting

Some of the R package dependencies require external software libraries to already be installed on your machine (e.g. the R package curl requires the system library libcurl). Unfortunately R is unable to install these for you automatically. If you are using Linux/macOS, you will need to install these system libraries yourself first.

Note that recent versions of macOS do not come with the X Window System. Please install XQuartz to prevent plotting issues. See here for more information.

If you are using Debian/Ubuntu, you can install all of the required system libraries using the commands below:

sudo apt update
sudo apt install \
  libcurl4-openssl-dev \
  libssl-dev \
  libprotobuf-dev \
  protobuf-compiler \
  libxml2-dev

Here is a table of the known system dependencies that you will need to install.

R packageSystem libraryOperating systemInstallation
curllibcurlDebian/Ubuntulibcurl4-openssl-dev
curllibcurlFedora/CentOS/RHELlibcurl-devel
curllibcurlSolarislibcurl_dev
opensslopensslDebian/Ubuntulibssl-dev
opensslopensslFedora/CentOS/RHELopenssl-devel
opensslopensslSolarislibssl_dev
opensslopensslmacOS (Homebrew)[email protected]
protoliteprotobufDebian/Ubuntulibprotobuf-dev
protoliteprotobufFedora/CentOS/RHELprotobuf-devel
protoliteprotobufSolarisprotobuf_dev
protoliteprotobufmacOS (Homebrew)protobuf
protoliteprotobuf-compilerDebian/Ubuntuprotobuf-compiler
protoliteprotobuf-compilerFedora/CentOS/RHELprotobuf-compiler
xml2libxml-2.0Debian/Ubuntulibxml2-dev
xml2libxml-2.0Fedora/CentOS/RHELlibxml2-devel
xml2libxml-2.0Solarislibxml2_dev

Acknowledgements

OmicNavigator is deployed as an OpenCPU app. The OpenCPU system enables embedded scientific computing with R.

OmicNavigator development is influenced by many existing bioinformatics and data visualization tools, including the set analysis visualization tool UpSet and the enrichment analysis network visualization tool EnrichmentMap

Contributing and Code of Conduct

Please note that the OmicNavigator project is released with guidelines on how to best contribute and a code of conduct. You can find these documents in CONTRIBUTING.md and .github/CODE_OF_CONDUCT.md.

Metadata

Version

1.13.13

License

Unknown

Platforms (77)

    Darwin
    FreeBSD
    Genode
    GHCJS
    Linux
    MMIXware
    NetBSD
    none
    OpenBSD
    Redox
    Solaris
    WASI
    Windows
Show all
  • aarch64-darwin
  • aarch64-freebsd
  • aarch64-genode
  • aarch64-linux
  • aarch64-netbsd
  • aarch64-none
  • aarch64-windows
  • aarch64_be-none
  • arm-none
  • armv5tel-linux
  • armv6l-linux
  • armv6l-netbsd
  • armv6l-none
  • armv7a-darwin
  • armv7a-linux
  • armv7a-netbsd
  • armv7l-linux
  • armv7l-netbsd
  • avr-none
  • i686-cygwin
  • i686-darwin
  • i686-freebsd
  • i686-genode
  • i686-linux
  • i686-netbsd
  • i686-none
  • i686-openbsd
  • i686-windows
  • javascript-ghcjs
  • loongarch64-linux
  • m68k-linux
  • m68k-netbsd
  • m68k-none
  • microblaze-linux
  • microblaze-none
  • microblazeel-linux
  • microblazeel-none
  • mips-linux
  • mips-none
  • mips64-linux
  • mips64-none
  • mips64el-linux
  • mipsel-linux
  • mipsel-netbsd
  • mmix-mmixware
  • msp430-none
  • or1k-none
  • powerpc-netbsd
  • powerpc-none
  • powerpc64-linux
  • powerpc64le-linux
  • powerpcle-none
  • riscv32-linux
  • riscv32-netbsd
  • riscv32-none
  • riscv64-linux
  • riscv64-netbsd
  • riscv64-none
  • rx-none
  • s390-linux
  • s390-none
  • s390x-linux
  • s390x-none
  • vc4-none
  • wasm32-wasi
  • wasm64-wasi
  • x86_64-cygwin
  • x86_64-darwin
  • x86_64-freebsd
  • x86_64-genode
  • x86_64-linux
  • x86_64-netbsd
  • x86_64-none
  • x86_64-openbsd
  • x86_64-redox
  • x86_64-solaris
  • x86_64-windows