generated from jtr13/cctemplate
-
Notifications
You must be signed in to change notification settings - Fork 139
/
Copy pathhive_plots_ggraph_hiver.Rmd
185 lines (132 loc) · 8.82 KB
/
hive_plots_ggraph_hiver.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
# Hive plots with the ggraph and hiver packages
Ben Zimnick
```{R message = FALSE}
library('ggraph')
library('igraph')
library('ggplot2')
library('tidygraph')
library('dplyr')
library('HiveR')
library('grid')
```
## Networks
### Network Definition
A network is a collection of connected objects. Networks are often called graphs.
### Node
Nodes are the connected objects in a network. Nodes are often called vertices.
### Edge
Edges are the connections between nodes. Edges are often called links.
### Directed Graph
The edges have directions. If a and b are nodes, they can be connected by an edge from a to b and/or an edge from b to a. Directed edges are often represented with arrows pointing from one node to another.
### Undirected Graph
The edges do not have directions; the relationship goes both ways. If a and b are connected nodes, the edge goes from a to b and from b to a.
### Degree
The degree of a node is the number of edges that are incident to the node. In directed graphs, the in-degree is the number of edges going into the node; the out-degree is the number of edges exiting the node.
### General Graph Example
The New York City subway system is a network. The stations (nodes) are connected by tunnels (edges). If all of the trains run in both directions, the subway would be an undirected graph. Otherwise, it would be a directed graph.
### Directed Graph Example
A family tree is a directed graph. The people (nodes) are connected by their relationships to each other (edges). The relationships go from parent to child. While a person could be a parent and a child, she/he would not be a parent and child of the same person.
### Undirected Graph Example
A network of friends is an undirected graph. The friends (nodes) are connected by their relationships to each other (edges). But their relationships do not have an inherent ordering like the relationships between parents and children.
## Hive Plots
### Hive Plot Definition
A hive plot is a method for visualizing networks. The nodes are located on lines that are distributed radially around the center of the plot (like hands on a clock). Edges are represented as curved lines between nodes.
### Creating Hive Plots
There is not a clear method for organizing the nodes. It is up to the person creating the graph to decide what works best for the data. But the nodes are typically ordered by degree on the axes.
### ggraph
ggraph is the most recent method for creating hive plots in R. The cran documentation was updated on February 23, 2021.
There are two main ways to create hive plots using ggraph. The first relies on the igraph package; the second relies on the dplyr and tidygraph packages.
The first example (which I needed to adjust slightly--I included an explanation in the 'note' section below) is from r-bloggers.com. The second example is from rdocumentation.org. The sources are in the 'sources' section.
Both examples use the highschool data set, which is built into the ggraph package. The data set shows friendships among high school boys. In 1957 and again in 1958, the boys were asked which other boys they were friends with. In the hive plots, the nodes are boys, and the edges are friendships.
I used the highschool data set because it is what most resources explaining network plots, including the ggraph cran documentation, use. Additionally, as one of the three data sets built into the ggraph package (the other two are the flare and whigs data sets), the highschool data set is convenient to work with.
### igraph method
This method usses the ggraph and igraph packages.
The graph_from_data_frame function in the igraph package creates an igraph graph from a data frame.
```{R}
graph <- graph_from_data_frame(highschool)
```
The degree degree of a node (or vertex) is its number of adjacent edges. For each node, the degree function gives the number of edges going into the node ('in'), the number of edges going out of the node ('out'), or the total degree ('all').
```{R}
V(graph)$friends <- degree(graph, mode = 'in')
```
The nodes are going to be located on three axes--few, many, medium--corresponding to the number of edges going into the node. In this example, the nodes are kids; the edges are friendships.
```{R}
V(graph)$friends <- ifelse(V(graph)$friends < 5, 'few',
ifelse(V(graph)$friends >= 15, 'many', 'medium'))
```
ggraph is an extension of ggplot2 that deals with graphs. ggraph sets the type of plot (hive) and the axis variable (friends). ggraph also sorts the nodes by degree.
geom_edge_hive draws edges between the nodes. colour is one of the many adjustable parameters.
geom_axis_hive edits the axes.
```{R}
ggraph(graph, 'hive', axis = friends, sort.by = 'degree') +
geom_edge_hive(aes(colour = factor(year))) +
geom_axis_hive(aes(colour = friends), size = 3, label = FALSE) +
coord_fixed()
```
### tidygraph method
This step uses the ggraph, ggplot2, tidygraph, and dplyr packages.
as_tbl_graph converts a data set to a tbl_graph, a wrapper that makes it possible to manipulate igraph objects in a tidy API.
centrality_degree gives the degree of the degree of the node.
```{R}
graph <- as_tbl_graph(highschool) %>%
mutate(degree = centrality_degree())
```
Create a friends column that divides the nodes (kids) by their degrees (number of friends).
```{R}
graph <- graph %>%
mutate(friends = ifelse(
centrality_degree(mode = 'in') < 5, 'few',
ifelse(centrality_degree(mode = 'in') >= 15, 'many', 'medium')
))
```
ggraph is an extension of ggplot2 that deals with graphs. ggraph sets the type of plot (hive) and the axis variable (friends). ggraph also sorts the nodes by degree. Unlike in the previous example, degree is not in quotes.
```{R}
ggraph(graph, 'hive', axis = friends, sort.by = degree) +
geom_edge_hive(aes(colour = factor(year))) +
geom_axis_hive(aes(colour = friends), size = 3, label = FALSE) +
coord_fixed()
```
### Faceting
facet_edges allows you to split the plots based on edge attributes. The nodes are repeated in every subplot. facet_edges is equivalent to facet_wrap in ggplot.
facet_nodes allows you to create subplots based on node attributes.
```{R}
ggraph(graph, 'hive', axis = friends, sort.by = degree) +
geom_edge_hive(aes(colour = factor(year))) +
geom_axis_hive(aes(colour = friends), size = 3, label = FALSE) +
coord_fixed() +
facet_edges(~year)
```
### Note
Most resources with the igraph example have quotes around degree in the first line of the ggraph section of the code. I needed to remove the quotes to get the code to work.
## HiveR
HiveR is another package for creating hive plots. HiveR does not seem as popular as ggraph. HiveR was first published in 2011; it was updated in 2020.
HiveR contains two plant-pollinator data sets--Arroyo and Safari-- that give the number of visits for each plant-pollinator pair. The data sets were taken from a 2003 paper by Vazquez and Simberloff. The Safari data were taken from an undisturbed area; the Arroyo data were collected in an area that was grazed by cattle.
I used the Arroyo data for the example.
This step uses the HiveR and grid packages.
Load the Arroyo data.
```{R}
data("Arroyo")
```
plotHive creates a hive plot from a HivePlotData object.
The rank method orders the nodes by degree. bkgnd sets the background color. axLabs sets the axis labels. axLab.pos sets the axis label positions. And axLab.gpar sets features (color, size, etc.) of the labels.
```{R}
plotHive(Arroyo,
method = 'rank', bkgnd = 'white',
axLabs = c('pollinators','plants'),
axLab.pos = c(10,7),
axLab.gpar = gpar(col = "black"))
```
## Sources
### Networks
- “Math Insight.” An Introduction to Networks - Math Insight, https://mathinsight.org/network_introduction.
- Networks and Graphs. Columbia University, https://kc.columbiasc.edu/ICS/icsfs/Networks.pdf?target=a96539a9-4cfd-44a5-baf2-fd798e1772ea.
### Hive Plots
- Krzywinski, Martin. Hive Plots: Rational Network Visualization - A Simple, Informative and Pretty Linear Layout for Network Analytics. http://www.hiveplot.com/.
### ggraph
- “GGRAPH.” RDocumentation, https://www.rdocumentation.org/packages/ggraph/versions/2.0.5.
- Pedersen, Thomas L. Package 'Ggraph'. CRAN, 23 Feb. 2021, https://cran.r-project.org/web/packages/ggraph/ggraph.pdf.
- “Introduction to Ggraph: Layouts.” Data Imaginist, 6 Feb. 2017, https://www.data-imaginist.com/2017/ggraph-introduction-layouts/.
- “Introduction to Ggraph: Layouts: R-Bloggers.” R-Bloggers, 18 Feb. 2017, https://www.r-bloggers.com/2017/02/introduction-to-ggraph-layouts/.
### HiveR
- Hanson, Bryan A. Package 'HiveR'. Depauw University, 15 Feb. 2013, http://www2.uaem.mx/r-mirror/web/packages/HiveR/HiveR.pdf.
- Hanson, Bryan A. The HiveR Package. Depauw University, 25 June 2012, http://www2.uaem.mx/r-mirror/web/packages/HiveR/vignettes/HiveR.pdf.