---
title: "glow"
output:
html_vignette:
keep_md: no
rmarkdown::github_document: default
vignette: >
%\VignetteIndexEntry{glow}
\usepackage[utf8]{inputenc}
%\VignetteEngine{knitr::rmarkdown}
---
```{r, setup, echo=FALSE}
IS_GITHUB <- Sys.getenv("IS_GITHUB") != ""
```
```{r results='asis', echo=FALSE, eval=IS_GITHUB}
cat('
[data:image/s3,"s3://crabby-images/4ac26/4ac26215a0ba4b66ee19a2ed2e7b2193038401f9" alt="R-CMD-check"](https://github.com/traversc/glow/actions)
[data:image/s3,"s3://crabby-images/707a7/707a7adbf746926d9f033baf12cba702297aaea7" alt="CRAN-Status-Badge"](https://cran.r-project.org/package=glow)
[data:image/s3,"s3://crabby-images/fa55a/fa55a2e59d7b38a3f65a714abc14fc005cce517d" alt="CRAN-Downloads-Badge"](https://cran.r-project.org/package=glow)
[data:image/s3,"s3://crabby-images/c1abb/c1abb27e25bfbcc3783b7ba957f0d19c4a3382ab" alt="CRAN-Downloads-Total-Badge"](https://cran.r-project.org/package=glow)
')
```
### A package for making glow-y plots
The `glow` package is a framework for creating plots with glowing points as an alternative way of plotting large point clouds.
## Gallery
```{r results='asis', echo=FALSE}
output <- '
|Methylation 450K Volcano Plot |Diamonds |
|-|-|
|data:image/s3,"s3://crabby-images/c6fee/c6fee1619808f8a57d585206ec8dbdd5a5efc5d5" alt=""{height=240px} |data:image/s3,"s3://crabby-images/87cca/87ccaf4e613def1a3fcc7a083f270344f562ce5c" alt=""{height=240px} |
| Milky Way Galaxy (6.1 million stars) |
|-|
| data:image/s3,"s3://crabby-images/7b4bc/7b4bcec76a2ee787ea9c4f0179fc5749bcf32dcc" alt=""{height=300px} |
| OpenStreetMap GPS traces (2.8 billion points) |
|-|
| data:image/s3,"s3://crabby-images/75bb8/75bb850d24dea9df02cc9413407ea5b20f91a686" alt=""{height=300px} |
| Clifford strange attractor (1 billion points) |
|-|
| data:image/s3,"s3://crabby-images/cc0b4/cc0b41aa03fd7dfed6714f938a03ca123ff53b75" alt=""{height=300px} |
| Airline Dataset (145 million points) | Glow-y Spiral |
|-|-|
| data:image/s3,"s3://crabby-images/5ae41/5ae412ddd2c8331e224b08dd376e7dc14dafb71d" alt=""{height=240px} | data:image/s3,"s3://crabby-images/ff20d/ff20d567980d2a5ffed983e208521736c410c0c9" alt=""{height=240px} |
| U.S. Coronavirus Cases (2021) |
|-|
| data:image/s3,"s3://crabby-images/04a72/04a7266899df990a8fbb71d51b7f1e4dda18e87d" alt=""{height=300px} |
'
if(IS_GITHUB) {
cat(output)
} else {
cat(gsub("vignettes/", "", output))
}
```
## Installation
```{r eval=FALSE}
remotes::install_github("traversc/glow")
```
### Some advantages over traditional techniques
* Naturally displays point density
* `glow` plots don't depend on the order of points in the data (points are commutative and associative)
* Multi-threaded, can be faster than geom_point depending on settings
* No loss of individual points compared to binning procedures
* Naturally works with larger-than-memory datasets (See "Airline" dataset in `inst/examples/examples.r`)
## Usage
Creating a glow plot is done through the `GlowMapper` or `GlowMapper4` classes, which utilize the `R6` class framework.
The class function `$map` creates a raster that can be plotted with `ggplot`'s `geom_raster` or output directly using the `EBImage` library.
See the help files and `inst/examples/notes.txt` for more information on each example.
### ggplot example using the diamonds dataset
```{r eval=FALSE}
library(glow)
library(ggplot2)
library(viridisLite) # Magma color scale
# Number of threads
nt <- 4
data(diamonds)
gm <- GlowMapper$new(xdim=800, ydim = 640, blend_mode = "screen", nthreads=nt)
# relx(0.002) makes point size relative to x-axis, e.g. each point radius is 0.2% of the y-axis
gm$map(x=diamonds$carat, y=diamonds$price, intensity=1, radius = rely(0.002))
pd <- gm$output_dataframe(saturation = 1)
# Dark color theme
ggplot() +
geom_raster(data = pd, aes(x = pd$x, y = pd$y, fill = pd$value), show.legend = FALSE) +
scale_fill_gradientn(colors = additive_alpha(magma(12))) +
coord_fixed(gm$aspect(), xlim = gm$xlim(), ylim = gm$ylim()) +
labs(x = "carat", y = "price") +
theme_night(bgcolor = magma(12)[1])
```
```{r results='asis', echo=FALSE}
if(IS_GITHUB) {
cat('data:image/s3,"s3://crabby-images/b8e12/b8e1257f62877252cb22d1deb21191ce6e0b2a27" alt=""{height=240px}')
} else {
cat('data:image/s3,"s3://crabby-images/fa725/fa7250a783c585d33943a203d4c9d62295357f9e" alt=""{height=240px}')
}
```
```{r eval=FALSE}
# light "heat" color theme
light_colors <- light_heat_colors(144)
ggplot() +
geom_raster(data = pd, aes(x = pd$x, y = pd$y, fill = pd$value), show.legend = FALSE) +
scale_fill_gradientn(colors = additive_alpha(light_colors)) +
coord_fixed(gm$aspect(), xlim = gm$xlim(), ylim = gm$ylim()) +
labs(x = "carat", y = "price") +
theme_bw(base_size = 14)
```
```{r results='asis', echo=FALSE}
if(IS_GITHUB) {
cat('data:image/s3,"s3://crabby-images/1f4c3/1f4c3ae59f96c01754b89ea2cdb776d527c26592" alt=""{height=240px}')
} else {
cat('data:image/s3,"s3://crabby-images/f6203/f6203565ea7def6874f04d88c76cf1a8b62667cb" alt=""{height=240px}')
}
```
```{r eval=FALSE}
# light "cool" color theme
light_colors <- light_cool_colors(144)
ggplot() +
geom_raster(data = pd, aes(x = pd$x, y = pd$y, fill = pd$value), show.legend = FALSE) +
scale_fill_gradientn(colors = additive_alpha(light_colors)) +
coord_fixed(gm$aspect(), xlim = gm$xlim(), ylim = gm$ylim()) +
labs(x = "carat", y = "price") +
theme_bw(base_size = 14)
```
```{r results='asis', echo=FALSE}
if(IS_GITHUB) {
cat('data:image/s3,"s3://crabby-images/75007/750077079759cc1fc3d34ba96dcf990a92d48622" alt=""{height=240px}')
} else {
cat('data:image/s3,"s3://crabby-images/6d24c/6d24c015b867f2dfe04bdb05921cac6a1c03a685" alt=""{height=240px}')
}
```
### Writing a raster image directly
Instead of using ggplot, you can also output a raster image directly using the `EBImage` Bioconductor library.
```{r eval=FALSE}
library(EBImage)
# Generate data
cliff_points <- clifford_attractor(1e6, 1.886,-2.357,-0.328, 0.918, 0.1, 0)
color_pal <- circular_palette(n=144, pal_function=rainbow)
cliff_points$color <- map_colors(color_pal, cliff_points$angle, min_limit=-pi, max_limit=pi)
# Create raster
gm <- GlowMapper4$new(xdim=480, ydim = 270, blend_mode = "additive", nthreads=4)
gm$map(x=cliff_points$x, y=cliff_points$y, radius=1e-3, color=cliff_points$color)
pd <- gm$output_raw(saturation = 1)
# Output raster with EBImage
image_array <- array(1, dim=c(480, 270, 3))
image_array[,,1] <- pd[[1]]*pd[[4]]
image_array[,,2] <- pd[[2]]*pd[[4]]
image_array[,,3] <- pd[[3]]*pd[[4]]
img <- EBImage::Image(image_array, colormode='Color')
plot(img)
writeImage(img, "plots/clifford_vignette.png")
```
```{r results='asis', echo=FALSE}
if(IS_GITHUB) {
cat('data:image/s3,"s3://crabby-images/bcdd6/bcdd674dee4fc93d7553ed2f63d8aa1e5d91cac6" alt=""{height=240px}')
} else {
cat('data:image/s3,"s3://crabby-images/31af2/31af23857b5695e047f8e8ab3223bf019778c61e" alt=""{height=240px}')
}
```