Python implementation of Hypergraph-MT algorithm described in:
[1] Contisciani M., Battiston F., and De Bacco C. (2022). Inference of hyperedges and overlapping communities in hypergraphs, Nature Communications, 13:7229, 2022.
If you use this code please cite [1]. Details can be found in the published version or in the preprint.
This is a probabilistic generative model that infers overlapping communities in hypergraphs. Thus, it is a mixed-membership model where we assume an assortative structure. The inference is performed using an efficient expectation-maximization (EM) algorithm that exploits the sparsity of the network, leading to an efficient and scalable implementation.
Notice that when applied to graphs (considering only pairwise interactions), Hypergraph-MT reduces to MultiTensor with assortative affinity matrices, as presented in De Bacco et al. (2017).
Copyright (c) 2022 Martina Contisciani and Caterina De Bacco.
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
code
: Contains the Python implementation of Hypergraph-MT algorithm, the code to run the inference and the hyperedge prediction task, and a Jupyter-notebook to show how to analyse the results.data/input
: Contains the Workplace dataset used in the manuscript (source).data/output
: Contains some results.
In order to be able to run the code, you need to install the packages contained in requirements.txt
. We suggest to create a conda environment with
conda create --name Hypergraph-MT --no-default-packages
, activate it with conda activate Hypergraph-MT
, and install all the dependencies by running (inside Hypergraph-MT
directory):
pip install -r requirements.txt
To test the program on the given example file, type:
cd code
python main.py
It will use the Workplace dataset contained in data/input
.
See the demo jupyter notebook for an example on how to analyse the output results, including visualizing the inferred communities.
- -f : Path of the input folder, (default='../data/input/')
- -d : Name of the dataset to analyse, (default='workplace')
- -K : Number of communities, (default=5)
- -v : Flag to print details, (default=1)
- -b : Flag to run the baselines, (default=1)
- -D : Threshold for the highest degree (size hyperedge) to keep, (default=None')
You can find this list by running (inside code
directory):
python main.py --help
In addition to the listed parameters, main.py
and main_cv.py
take in input a yaml file. This setting_<dataset>.yaml
file contains additional parameters to pass to the model, that are:
- seed : Number to set the seed of the random number generator
-
constraintU : Flag to normalize the community matrix
$u$ such that every row sums to 1. -
fix_communities : Flag to set the communities
$u$ as the input file and fix them during the inference. -
fix_w : Flag to set the affinity matrix
$w$ as the input file and fix it during the inference. -
gammaU : Constant to regularize the communities
$u$ . -
gammaW : Constant to regularize the affinity matrix
$w$ . -
initialize_u : Option to initialize the communities
$u$ different from random. -
initialize_w: Option to initialize the affinity matrix
$w$ different from random. - out_inference : Flag to output the inference results.
- out_folder : Path of the output folder.
- end_file : Suffix of the output file.
- plot_loglik : Flag to plot the log-likelihood.
The network should be stored in a .npz file, containing:
-
A : Array of length
$E$ , containing the weights of the hyperedges -
B : Incidence matrix of dimension
$N \times E$ -
hye : Array of length
$E$ , containing the sets of hyperedges (as tuples)
where
The algorithm returns a compressed file inside the data/output
folder. To load and print the membership matrix:
import numpy as np
theta = np.load('theta_file_name.npz')
print(theta['u'])
theta contains the