Skip to main content

Mixture of Multilayer Integrator Stochastic Block Model

Project description

🕸️ MimiSBM

mimisbm is a Python package implementing the Mixture of Multilayer Integrator Stochastic Block Model proposed by the original authors. It jointly groups nodes into clusters and layers into components, providing a unified framework for identifying shared connectivity patterns across multiple network layers.


✨ Features

  • Multilayer Clustering: Jointly identifies node communities and layer components in a single probabilistic framework.
  • Variational EM: Efficient inference using a Variational Expectation-Maximization (VEM) algorithm for large-scale networks.
  • Bayesian Framework: Supports flexible Dirichlet and Beta priors, allowing for robust structure discovery under different sparsity regimes.
  • Component-wise SBMs: Groups layers sharing similar block-model structures into distinct mixture components.
  • scikit-learn API: Native BaseEstimator and ClusterMixin integration with a familiar fit / predict interface.

🚀 Installation

pip install mimisbm

🔧 Usage

Example

import numpy as np
from mimisbm import MimiSBM

# Generate a synthetic multilayer adjacency tensor (20 nodes, 5 layers)
np.random.seed(42)
N, V = 20, 5
X = np.random.randint(0, 2, size=(N, N, V))

# Ensure the adjacency matrices are symmetric (undirected)
for v in range(V):
    X[..., v] = np.tril(X[..., v], -1) + np.tril(X[..., v], -1).T

# Initialize the model with 3 node clusters and 2 layer components
model = MimiSBM(n_clusters=3, n_components=2, random_state=42)

# Fit the model to the multilayer network
model.fit(X)

# Predict node cluster and layer component assignments
node_labels, layer_labels = model.predict()

print(f"Node clusters: {node_labels}")
print(f"Layer components: {layer_labels}")
print(f"Final ELBO: {model.elbo_:.2f}")

📖 Learn More

For tutorials and detailed API reference, visit the official site:
👉 mimisbm's documentation

📚 Citation

If you use MimiSBM in your research, please cite the original authors' paper:

@article{de2024mixture,
  title={Mixture of multilayer stochastic block models for multiview clustering},
  author={De Santiago, Kylliann and Szafranski, Marie and Ambroise, Christophe},
  journal={arXiv preprint arXiv:2401.04682},
  year={2024}
}

For more details, see the corresponding Preprint: https://arxiv.org/abs/2401.04682

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mimisbm-0.1.0.tar.gz (10.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mimisbm-0.1.0-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file mimisbm-0.1.0.tar.gz.

File metadata

  • Download URL: mimisbm-0.1.0.tar.gz
  • Upload date:
  • Size: 10.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for mimisbm-0.1.0.tar.gz
Algorithm Hash digest
SHA256 d4e6c91910ee7b1e04f2a89a8e9e2e9974ecc52d290065bc185f39df399bdd9b
MD5 413ebbef165ce2afa39c3c49a167bcf3
BLAKE2b-256 2df5215efff2a7fe22f51a67cf782bd649c900e513c0255d67b8ca3c609c8de2

See more details on using hashes here.

File details

Details for the file mimisbm-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: mimisbm-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for mimisbm-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e80ea8030b3811aff3361b6b98fd55d9d69fcca69fa14fed878edb74f346b385
MD5 0d4526891962d44d2ea4ead59306b7e4
BLAKE2b-256 4e85ae12e5127338fe18a52b4e457548c4419ea28d9edc4b0cf9f321816b3115

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page