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
A = np.random.randint(0, 2, size=(N, N, V))

# Ensure the adjacency matrices are symmetric (undirected)
for v in range(V):
    A[..., v] = np.tril(A[..., v], -1) + np.tril(A[..., 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(A)

# 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.2.0.tar.gz (11.0 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.2.0-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for mimisbm-0.2.0.tar.gz
Algorithm Hash digest
SHA256 471fdda5a5b2f3cf70eea96abbfafd433757577cc55bacc2675e039f5a641464
MD5 f0e28dca3d21103818c4de383f4bf745
BLAKE2b-256 e2d0d7fff3a30dc32b1d7d83d5a8c2561d2a1a9d936fd54990b2aad0d3aa9b0e

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mimisbm-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 7.1 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a02a2e212a1c6b64d5e6e44b543e2b781071d7e0fbe7aa6171188c63923b0891
MD5 2a833c597397e65f6e61c44fc5ff80e0
BLAKE2b-256 c1627c176271e5e8aa499b65600c87379da2a04a3d2578ef581770e47c6737ab

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