Home

Awesome

R package for drawing alluvial diagrams

<!-- badges: start -->

R-CMD-check rstudio mirror
downloads cran
version

<!-- badges: end -->

What are alluvial diagrams? See for example:

This package use base R graphics (R Core Team 2021) package. For Grammar of Graphics implementation see ggalluvial (Brunson and Read 2020; Brunson 2020).

Examples

Alluvial diagram of datasets::Titanic data made with alluvial(). Notice how each category block becomes a stacked barchart showing relative frequency of survivors.

tit <- tibble::as_tibble(Titanic)

tit %>% head() %>% knitr::kable()
ClassSexAgeSurvivedn
1stMaleChildNo0
2ndMaleChildNo0
3rdMaleChildNo35
CrewMaleChildNo0
1stFemaleChildNo0
2ndFemaleChildNo0
alluvial(
    select(tit, Survived, Sex, Age, Class),
    freq=tit$n,
    col = ifelse(tit$Survived == "Yes", "orange", "grey"),
    border = ifelse(tit$Survived == "Yes", "orange", "grey"),
    layer = tit$Survived != "Yes",
    alpha = 0.8,
    blocks=FALSE
  )

<!-- -->

Alluvial diagram for multiple time series / cross-sectional data based on alluvial::Refugees data made with alluvial_ts().

Refugees %>% head() %>% knitr::kable()
countryyearrefugees
Afghanistan20032136043
Burundi2003531637
Congo DRC2003453465
Iraq2003368580
Myanmar2003151384
Palestine2003350568
set.seed(39) # for nice colours
cols <- hsv(h = sample(1:10/10), s = sample(3:12)/15, v = sample(3:12)/15)

alluvial_ts(Refugees, wave = .3, ygap = 5, col = cols, plotdir = 'centred', alpha=.9,
            grid = TRUE, grid.lwd = 5, xmargin = 0.2, lab.cex = .7, xlab = '',
            ylab = '', border = NA, axis.cex = .8, leg.cex = .7,
            leg.col='white', 
            title = "UNHCR-recognised refugees\nTop 10 countries (2003-13)\n")

<!-- -->

Installation

Install stable version from CRAN using

install.packages("alluvial")

or development version from GitHub using remotes::install_github():

remotes::install_github("mbojan/alluvial", build_vignettes=TRUE)

References

<div id="refs" class="references csl-bib-body hanging-indent"> <div id="ref-ggalluvial-article" class="csl-entry">

Brunson, Jason Cory. 2020. “<span class="nocase">ggalluvial</span>: Layered Grammar for Alluvial Plots.” Journal of Open Source Software 5 (49): 2017. https://doi.org/10.21105/joss.02017.

</div> <div id="ref-r-ggalluvial" class="csl-entry">

Brunson, Jason Cory, and Quentin D. Read. 2020. “Ggalluvial: Alluvial Plots in ’Ggplot2’.” http://corybrunson.github.io/ggalluvial/.

</div> <div id="ref-r-graphics" class="csl-entry">

R Core Team. 2021. R: A Language and Environment for Statistical Computing. Vienna, Austria: R Foundation for Statistical Computing. https://www.R-project.org/.

</div> </div>