Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/iankloo/sigmaNet
Render igraphs from R using Sigma.js
https://github.com/iankloo/sigmaNet
graphs r sigma visualization
Last synced: 2 months ago
JSON representation
Render igraphs from R using Sigma.js
- Host: GitHub
- URL: https://github.com/iankloo/sigmaNet
- Owner: iankloo
- License: other
- Created: 2017-07-01T19:30:20.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2018-06-28T20:38:01.000Z (over 6 years ago)
- Last Synced: 2024-08-04T03:04:51.916Z (6 months ago)
- Topics: graphs, r, sigma, visualization
- Language: R
- Homepage: https://iankloo.github.io/sigmaNet/
- Size: 1.41 MB
- Stars: 41
- Watchers: 7
- Forks: 8
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-shiny-extensions - sigmaNet - Render igraph networks using sigma.js. (Visualization / Network and Graph Data)
README
# sigmaNet
Render `igraph` networks using Sigma.js - in R - now on CRAN!
## Why?
This package is an R interface to the Sigma.js javascript library. Sigma.js was built for graph visualization and has significant advantages over other javascript libraries when creating large graph visualizations.
Benefits of this package:
1. Use familiar, well documented `igraph` objects to make visualizations
2. Easy "ggplot-like" syntax
3. Render things quickly - allowing for faster iterative graph building
4. Render large networks
5. Maintain interactivity (click, hover, zoom) with sharable html output
6. Integrate easily with Shiny applications## How?
First, install this package:
```
install.packages('sigmaNet')
```Or, use the development version:
```
devtools::install_github('iankloo/sigmaNet')
```Then, create an `igraph` network. Here we'll use the included les Miserables dataset that maps the co-appearances of characters in the novel.
Note, passing an optional layout to the `sigmaFromIgraph()` function will dramatically improve speed. Layouts are usually the most computationally intensive task when creating network visualizations. This package allows you to separate this computation from the aesthetic changes you will likely want to make to your visualization.
```
library(sigmaNet)
library(igraph)data(lesMis)
layout <- layout_with_fr(lesMis)
sig <- sigmaFromIgraph(lesMis, layout = layout)
sig
```![](img/simpleGraph.png)
If you render this at home, you'll see that you can zoom, pan, and get information on-hover for the nodes. This is just a static image to show you the basics.
## Options
You have a few options available to change the aesthetics of graphs. Options are applied in a similar way to `ggplot`, but use the pipe operator instead of the "+". Here is an example showing most of the options you can use:
```
data(lesMis)clust <- cluster_edge_betweenness(lesMis)$membership
V(lesMis)$group <- clustlayout <- layout_with_fr(lesMis)
sig <- sigmaFromIgraph(lesMis, layout = layout) %>%
addNodeLabels(labelAttr = 'label') %>%
addEdgeSize(sizeAttr = 'value', minSize = .1, maxSize = 2) %>%
addNodeSize(sizeMetric = 'degree', minSize = 2, maxSize = 8) %>%
addNodeColors(colorAttr = 'group', colorPal = 'Set1')
sig
```![](img/aesGraph.png)
Note: there is no opacity/transparency/alpha attribute! That is because webgl doesn't support transparency. To mimic transparency, set your edge size to be small - this works really well. I know this is a big trade off, but it is the only way to render large networks without sacrificing performance.
## Larger NetworksThis package was built to address the specific challenges of creating compelling visualizations with large networks. Here is an example of a larger network than we've been using (created using a graph-generating function in `igraph`):
```
g <- sample_pa(10000)layout <- layout_with_fr(g)
sig <- sigmaFromIgraph(g, layout = layout)
sig %>%
addNodeSize(oneSize = .5) %>%
addEdgeSize(oneSize = .2)
```![](img/bigGraph.png)
While we can debate the usefulness of a "hairball" graph like this, you can see that `sigmaNet` has no problem rendering a graph with 10,000 nodes nearly instantly. If you render this at home, you will also see that the graph maintains its interactivity with little to no lag.
## Shiny Support
You can use `sigmaNet` in Shiny using `renderSigmaNet()` in your server and `sigmaNetOutput()` in your ui. See the Shiny docs for more general info about Shiny - these functions drop-in just like the basic plotting examples.
Use the `addListner()` function to specify a Shiny listener. Current options are "clickNode" and "hoverNode". These are pretty self-explanitory - the first returns information about a node on-click and the second does the same on-hover.
Here's a minimal Shiny app that sends the result of an on-click event to a text box:
```
library(sigmaNet)
library(shiny)
library(magrittr)data(lesMis)
ui <- fluidPage(
sigmaNetOutput('network', height = '600px'),
textOutput('text')
)server <- function(input, output) {
output$text <- renderText({
req(input$node_data)
paste0('You clicked on: ', input$node_data$label)
})
output$network <- renderSigmaNet({
sigmaNet::sigmaFromIgraph(lesMis) %>%
addNodeLabels(labelAttr = 'label') %>%
addListener('clickNode')
})
}shinyApp(ui, server)
```## A Note on Browsers
This package uses a renderer that detects whether or not your browser supports webgl. If it does, webgl will be used to render the visualizations. If not, canvas will be used. Webgl is MUCH faster than canvas (especially with large graphs), so if you notice some performance issues, try using a modern browser that supports webgl. All but the most out-of-date browsers support webgl (except maybe Opera?), so this shouldn't be an issue for many.
## Features in development
- GUI to modify aesthetics (Shiny gadget)
Write an "issue" on the github page for this package if you want to see additional features.