-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathREADME.Rmd
63 lines (43 loc) · 2.95 KB
/
README.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
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# GREMLINS
<!-- badges: start -->
[![R build status](https://github.com/Demiperimetre/GREMLINS/workflows/R-CMD-check/badge.svg)](https://github.com/Demiperimetre/GREMLINS/actions)
<!-- badges: end -->
The goal of GREMLINS is to perform statistical analysis of multipartite networks through a block model approach. Note that we encourage you to prefer using the package `sbm` which depends on GREMLINS but includes many more models, plot functions and examples...
Multipartite networks consist in the joint observation of several networks implying some common individuals. The individuals (or entities represented by nodes) at stake are partitioned into groups defined by their nature.
In what follows, these groups will be referred to as \emph{functional groups}.
## Installation
You can install the released version of GREMLINS [GitHub](https://github.com/) with:
``` r
#devtools::install_github("Demiperimetre/GREMLINS")
library(GREMLINS)
```
## Mathematical Background
### A collection of networks
Assume that $Q$ functional groups of individuals are at stake; Let $n_q$ be the number of individuals in the $q$-th functional group.
A multipartite network is a collection of networks: each network may be simple (relations inside a functional group) or bipartite (relations between individuals of two functional groups). We index the collection of networks by pairs of functional groups $(q,q')$.
The set $E$ denotes the list of pairs of functional groups for which we observe an interaction network.
For any pair $(q,q') \in E$, the interaction network is encoded in a matrix $X^{qq'}$ : $X^{qq'}_{ii'} \neq 0 $ if there is an edge from unit $i$ of functional group
$q$ to unit $i'$ of functional group $q'$, $0$ otherwise.
- If $q \neq q'$, $X^{qq'}$ is said to be an \emph{incidence matrix}.
- $X^{qq}$ is an \emph{adjacency matrix}: it is symmetric if the relation inside the functional group $q$ is non-oriented, non-symmetric otherwise.
### A block model
Assume that, each functional group $q$ is divided into $K_q$ blocks (or equivalently clusters). $\forall q\in \{1,\ldots,Q\}$ and $ \forall i \in \{1,\ldots,n_q\}$, let $Z^{q}_i$ be
the latent random variable such that $Z^ q_i =k$ if individual $i$ of functional group $q$ belongs to cluster $k$.
The random variables $Z^{q}_i$'s are assumed to be independent and such that: $\forall k \in \{1,\ldots,K_q\}, \forall q \in \{1,\ldots,Q\}, \forall i \in \{1,\ldots,n_q\}$:
\begin{equation}\label{eq:mod2}
\Prob(Z^{q}_i=k) = \pi^{q}_k,
\end{equation}
with $\sum_{k=1}^{K_q}\pi^{q}_k=1$, $\forall q \in \{1,\ldots,Q\}$.
Let $\bZ = \left(Z^{q}_i\right)_{i\in \{1,\ldots,n_q\}, q \in \{1,\ldots,Q\}}$ denote the set of latent variables.