Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ropensci/iheatmapr
Complex, interactive heatmaps in R
https://github.com/ropensci/iheatmapr
data-visualization heatmap interactive-visualizations peer-reviewed plotly r r-package rstats
Last synced: about 2 months ago
JSON representation
Complex, interactive heatmaps in R
- Host: GitHub
- URL: https://github.com/ropensci/iheatmapr
- Owner: ropensci
- License: other
- Created: 2017-03-16T17:44:27.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2024-08-13T10:13:32.000Z (5 months ago)
- Last Synced: 2024-08-14T11:45:37.010Z (5 months ago)
- Topics: data-visualization, heatmap, interactive-visualizations, peer-reviewed, plotly, r, r-package, rstats
- Language: R
- Homepage: https://docs.ropensci.org/iheatmapr
- Size: 21.1 MB
- Stars: 267
- Watchers: 24
- Forks: 35
- Open Issues: 51
-
Metadata Files:
- Readme: README.md
- Changelog: NEWS.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Codemeta: codemeta.json
Awesome Lists containing this project
- jimsghstars - ropensci/iheatmapr - Complex, interactive heatmaps in R (R)
README
[![R-CMD-check](https://github.com/ropensci/iheatmapr/workflows/R-CMD-check/badge.svg?branch=main)](https://github.com/ropensci/iheatmapr/actions?query=workflow%3AR-CMD-check)
[![iheatmapr peer review status in ROpenSci](https://badges.ropensci.org/107_status.svg)](https://github.com/ropensci/onboarding/issues/107)
[![JOSS](http://joss.theoj.org/papers/10.21105/joss.00359/status.svg)](http://joss.theoj.org/papers/10.21105/joss.00359)
[![CRAN](https://www.r-pkg.org/badges/version/iheatmapr)](https://cran.r-project.org/package=iheatmapr)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)# iheatmapr
`iheatmapr` is an R package for building complex, interactive heatmaps using modular building blocks. "Complex" heatmaps are heatmaps in which subplots along the rows or columns of the main heatmap add more information about each row or column. For example, a one column additional heatmap may indicate what group a particular row or column belongs to. Complex heatmaps may also include multiple side by side heatmaps which show different types of data for the same conditions. Interactivity can improve complex heatmaps by providing tooltips with information about each cell and enabling zooming into interesting features. `iheatmapr` uses the [plotly](https://plotly.com) library for interactivity.
While there are already plenty of awesome R packages for making heatmaps, including several great packages for making relatively simple interactive heatmaps ([heatmaply](https://github.com/talgalili/heatmaply) and [d3heatmap](https://github.com/rstudio/d3heatmap)) or complex static heatmaps ([ComplexHeatmap](https://github.com/jokergoo/ComplexHeatmap)), `iheatmapr` seeks to make it easy to make complex interactive heatmaps.
## Installation
To install the CRAN version of `iheatmapr`:
```r
install.packages("iheatmapr")
```To install the github version of `iheatmapr`:
```r
devtools::install_github("ropensci/iheatmapr")
```## Example Complex Heatmap
As an example of a complex heatmap, we can make a version of the famous vaccines plot from the Wall Street Journal that has been recreated in several other heatmap frameworks in R.
![A graphical demo of an iheatmap in the RStudio plot viewer](https://raw.githubusercontent.com/ropensci/iheatmapr/master/vaccine.gif)
The code to create this heatmap is:
```R
library(iheatmapr)
data(measles, package = "iheatmapr")main_heatmap(measles, name = "Measles
Cases", x_categorical = FALSE,
layout = list(font = list(size = 8))) %>%
add_col_groups(ifelse(1930:2001 < 1961,"No","Yes"),
side = "bottom", name = "Vaccine
Introduced?",
title = "Vaccine?",
colors = c("lightgray","blue")) %>%
add_col_labels(ticktext = seq(1930,2000,10),font = list(size = 8)) %>%
add_row_labels(size = 0.3,font = list(size = 6)) %>%
add_col_summary(layout = list(title = "Average
across
states"),
yname = "summary") %>%
add_col_title("Measles Cases from 1930 to 2001", side= "top") %>%
add_row_summary(groups = TRUE,
type = "bar",
layout = list(title = "Average
per
year",
font = list(size = 8)))
```Modular components of the plot are added in an iterative fashion to the top, right, left, or bottom of the heatmap. `iheatmapr` also contains a function (`iheatmap`) to make a fairly standard heatmap with optional dendrograms and row or column annotation heatmaps (See vignette).
All the plots aligned with the main heatmap horizontally share the same y axis and thus zooming in the y direction within the heatmap will also zoom in to those subplots. The plots aligned vertically share an x axis with that heatmap and zooming horizontally within those plots will be linked.
Hovering over the heatmaps yields a tooltip with the name of the row and column as well as the value represented.
# Documentation
See the [vignette](https://docs.ropensci.org/iheatmapr/articles/full_vignettes/iheatmapr.html) for a more thorough introduction to the package.
# Acknowledgements
This package includes the open source Plotly.js library, which does much of the work of making these interactive plots possible! In creating this package, I also drew inspiration & some code from the great plotly R package; in particular, the code for the `iheatmapr` htmlwidget is adapted from an earlier version of the plotly R package. Additionally, numerous people at Genentech helped provide feedback and guidance for this project, including but not limited to Justin Finkle, August Guang, Michael Lawrence, Gabe Becker, Steve Lianoglou, Pete Haverty... thanks to all who helped review code and/or provide feedback! This package also went through the on-boarding process for rOpensci -- thanks to the reviewers Carl Ganz and Andee Kaplan and editor Maëlle Salmon for all their helpful feedback!
[![ropensci_footer](http://ropensci.org/public_images/github_footer.png)](http://ropensci.org)