Skip to main content

A compact Python library for modeling, analyzing, and visualizing optical network topologies.

Project description

Topolib 🚀

Python Version License Issues Develop coverage Documentation Status

Topolib is a compact, modular Python library for modeling, analyzing, and visualizing optical network topologies.
Goal: Provide researchers and engineers with a simple, extensible toolkit for working with nodes, links, metrics, and map-based visualizations.

🌐 Model | 📊 Analyze | 🗺️ Visualize | 🧩 Extend


📂 Examples

Explore ready-to-run usage examples in the examples/ folder!


🧭 Overview

Topolib is organized into four main modules:

  • 🧱 Elements: Node, Link — basic building blocks
  • 🕸️ Topology: Topology, Path — manage nodes, links, paths, and adjacency
  • 📈 Analysis: Metrics, TrafficMatrix — compute node degree, link stats, connection matrices, and traffic demand matrices
  • 🖼️ Visualization: MapView — interactive maps with Folium and PyQt6, clean PNG exports

✨ Features

  • Modular, extensible design
  • Easy-to-use classes for nodes, links, and paths
  • Built-in metrics and analysis helpers
  • Traffic demand matrix generation with three models (gravitational, MPT, RAM)
  • Homogeneous and heterogeneous multi-period traffic growth projections
  • Returns NumPy arrays for efficient mathematical operations
  • Interactive map visualization with Folium and PyQt6
  • Clean PNG export without external dependencies (no Selenium required)
  • Paper format export with white background for academic publications
  • Resource caching for faster map rendering
  • JSON import/export and interoperability
  • 60+ built-in topologies available as downloadable CSV files from the Topology Repository (no Python environment required)
  • Fully compatible with Jupyter Notebook - Folium maps display inline for interactive analysis
  • Ready for Sphinx, Read the Docs, and PyPI

⚡ Quickstart

python -m venv .venv
source .venv/bin/activate
pip install -U pip
pip install topolib

📚 Documentation

Full documentation: https://topolib.readthedocs.io/


📝 Basic usage

Creating a topology

from topolib.elements.node import Node
from topolib.topology.topology import Topology

n1 = Node(1, 'A', 10.0, 20.0)
n2 = Node(2, 'B', 11.0, 21.0)
topo = Topology(nodes=[n1, n2])
# Add links, compute metrics, visualize, etc.

Generating traffic matrices

from topolib.topology import Topology
from topolib.analysis import TrafficMatrix

# Load a topology
topo = Topology.load_default_topology("Germany-14nodes")

# Generate traffic matrix using gravitational model
matrix = TrafficMatrix.gravitational(topo, rate=0.015)
# Returns NumPy array: matrix[i, j] = traffic from node i to j (Gbps)

# Export to CSV
TrafficMatrix.to_csv(matrix, topo, "traffic_matrix.csv")

# Export to JSON (list of demands with src, dst, required fields)
TrafficMatrix.to_json(matrix, topo, "traffic_matrix.json")

Multi-period traffic growth

from topolib.analysis import TrafficMatrix

# Homogeneous growth: the whole network uses the same growth distribution
matrices = TrafficMatrix.multiperiod(
    matrix,
    num_periods=10,
    base_growth_rate=0.10,
    random_variation=0.02,
    seed=42,
)

# Heterogeneous growth: selected matrix nodes can use different distributions
heterogeneous = TrafficMatrix.multiperiod_heterogeneous(
    matrix,
    num_periods=10,
    default_growth={"distribution": "fixed", "value": 0.0},
    node_growth={
        2: {"distribution": "normal", "mean": 0.30, "variance": 0.0009},
        5: {"distribution": "fixed", "value": -0.10},
    },
    direction="outgoing",
    seed=42,
)

node_growth keys are matrix indices, not topology IDs. With direction="outgoing", node 2 scales matrix[2, :], affecting traffic from that node to all destinations. Negative growth is allowed; traffic is clipped at zero.


🛠️ Development

See CONTRIBUTING.md for development guidelines, commit message rules, and pre-commit setup.


� Acknowledgments

Topolib builds upon excellent open-source projects:

Core Dependencies:

  • NumPy (BSD-3-Clause) — numerical computing
  • NetworkX (BSD-3-Clause) — graph analysis
  • SciPy (BSD-3-Clause) — scientific computing
  • Folium (MIT) — interactive maps
  • jsonschema (MIT) — JSON validation

Visualization:

All dependencies are compatible with Topolib's MIT license. PyQt6 is used only for optional interactive visualization features and is not required for core topology modeling and analysis functionality.


�📄 License

MIT — see LICENSE for details.

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

topolib-0.21.0.tar.gz (120.1 kB view details)

Uploaded Source

Built Distribution

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

topolib-0.21.0-py3-none-any.whl (171.0 kB view details)

Uploaded Python 3

File details

Details for the file topolib-0.21.0.tar.gz.

File metadata

  • Download URL: topolib-0.21.0.tar.gz
  • Upload date:
  • Size: 120.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.11.15 Linux/5.15.154+

File hashes

Hashes for topolib-0.21.0.tar.gz
Algorithm Hash digest
SHA256 efbeb60d9ef58991b085a6dd58b36d37045ee968c7241a106368ea6e2e3781bc
MD5 00060c4bfea5822a346dcecd303d31ec
BLAKE2b-256 fbecb9cf9e222df8ff076e94d4ba2742a4adc49cd8365015cd375fceb59098c3

See more details on using hashes here.

File details

Details for the file topolib-0.21.0-py3-none-any.whl.

File metadata

  • Download URL: topolib-0.21.0-py3-none-any.whl
  • Upload date:
  • Size: 171.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.11.15 Linux/5.15.154+

File hashes

Hashes for topolib-0.21.0-py3-none-any.whl
Algorithm Hash digest
SHA256 48cac5a853f6d518ea6a0632fbe667150d6cecff22ebe13c39dbe70495ca56ce
MD5 8349fa7ba329cd8ef537f61c463f4b78
BLAKE2b-256 38c0a251d331645780e895121e64e12c0920716709a7123eddfc36873f0b78a1

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