-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path2-netdiffuser.qmd
122 lines (88 loc) · 3.43 KB
/
2-netdiffuser.qmd
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
---
title: "Introduction to the package"
author: "George G. Vega Yon"
date: "2024-12-05"
date-modified: "2024-12-05"
---
```{r setup, echo=FALSE, message=FALSE, warning=FALSE}
library(netdiffuseR)
knitr::opts_chunk$set(comment = "#")
```
* One of the cannonical concepts is the **network threshold**. Network thresholds (Valente, 1995; 1996), $\tau$, are defined as the required proportion or number of neighbors that leads you to adopt a particular behavior (innovation), $a=1$. In (very) general terms\pause
$$
a_i = \left\{\begin{array}{ll}
1 &\mbox{if } \tau_i\leq E_i \\
0 & \mbox{Otherwise}
\end{array}\right. \qquad
E_i \equiv \frac{\sum_{j\neq i}\mathbf{X}_{ij}a_j}{\sum_{j\neq i}\mathbf{X}_{ij}}
$$
Where $E_i$ is i's exposure to the innovation and $\mathbf{X}$ is the adjacency matrix (the network).
* This can be generalized and extended to include covariates and other network weighting schemes (that's what __netdiffuseR__ is all about).
# netdiffuseR
## Overview
__netdiffuseR__ is an R package that:
* Is designed for Visualizing, Analyzing and Simulating network diffusion data (in general).
* Depends on some pretty popular packages:
* _RcppArmadillo_: So it's fast,
* _Matrix_: So it's big,
* _statnet_ and _igraph_: So it's not from scratch
* Can handle big graphs, e.g., an adjacency matrix with more than 4 billion elements (PR for RcppArmadillo)
* Already on CRAN with ~6,000 downloads since its first version, Feb 2016,
* A lot of features to make it easy to read network (dynamic) data, making it a nice companion of other net packages.
## Datasets
- __netdiffuseR__ has the three classic Diffusion Network Datasets:
- `medInnovationsDiffNet` Doctors and the innovation of Tetracycline (1955).
- `brfarmersDiffNet` Brazilian farmers and the innovation of Hybrid Corn Seed (1966).
- `kfamilyDiffNet` Korean women and Family Planning methods (1973).
```{r printing}
brfarmersDiffNet
medInnovationsDiffNet
kfamilyDiffNet
```
## Visualization methods
```{r viz, cache=TRUE, eval=TRUE}
set.seed(12315)
x <- rdiffnet(
n = 400, t = 6,
rgraph.args = list(k=6, p=.3),
seed.graph = "small-world",
seed.nodes = "central",
rewire = FALSE,
threshold.dist = 1/4
)
x
```
Diffusion networks can visualized using many methods included in the package. Here are some of them:
```{r}
#| label: plot-methods
plot(x)
plot_diffnet(x)
plot_diffnet2(x)
plot_adopters(x)
plot_threshold(x)
plot_infectsuscep(x, K=2)
plot_hazard(x)
```
# Problems
1. Using the diffnet object in [`intro.rda`](files/intro.rda), use the function `plot_threshold` specifying shapes and colors according to the variables ItrustMyFriends and Age. Do you see any pattern? (<a href="files/intro-solutions.r" target="_blank">solution script</a> and <a href="files/intro-solutions.png" target="_blank">solution plot</a>)
```{r datasim, echo=FALSE, eval=TRUE}
set.seed(1252)
dat <- data.frame(
ItrustMyFriends = sample(c(0,1), 200, TRUE),
Age = 10 + rpois(200, 4)
)
net <- rgraph_er(200, p = .05)
# net <- diag_expand(list(net, net))
# net[cbind(1:20, 101:120)] <- 1
# Generating the process
diffnet <- rdiffnet(
threshold.dist = 4 - dat$ItrustMyFriends*3,
seed.graph = net,
t=6,
seed.nodes = c(9:25),
exposure.args = list(normalized=FALSE),
rewire = FALSE)
diffnet[["ItrustMyFriends"]] <- dat$ItrustMyFriends
diffnet[["Age"]] <- dat$Age
save(diffnet, file = "files/intro.rda")
```