Skip to main content

Network Optimization Python Code

Project description

Project generated with PyScaffold Documentation Status codecov

🔀 digraphx

Efficient directed graph algorithms for network optimization in Python

digraphx is a Python library that provides high-performance implementations of directed graph algorithms, optimized for large-scale network optimization problems. It extends NetworkX with specialized data structures and algorithms for negative cycle detection, cycle ratio optimization, and parametric network analysis.

Note that digraphx does not directly handle multi-edges (same as networkx)

Features

  • High-performance graph storage: TinyDiGraph with memory-efficient MapAdapter backend
  • Negative cycle detection: Howard's algorithm for finding negative cycles in weighted directed graphs
  • Minimum/Maximum Cycle Ratio: Efficient algorithms for finding cycles with optimal cost/time ratios
  • Parametric network optimization: Generic framework for ratio-based optimization problems
  • Type-safe: Full type hints throughout codebase
  • Well-tested: Comprehensive test coverage with pytest

When to Use digraphx vs NetworkX

Use digraphx when:

  • Working with very large graphs (thousands to millions of nodes)
  • Need memory-efficient storage for graphs with known node counts
  • Optimizing cycles based on cost/time ratios
  • Finding negative cycles in weighted graphs
  • Implementing parametric optimization algorithms

Use standard NetworkX when:

  • Need a general-purpose graph library
  • Working with small to medium-sized graphs
  • Need extensive graph algorithms not in digraphx
  • Dynamic graph operations (frequent node/edge additions/removals)

Installation

From PyPI

pip install digraphx

From Source

git clone https://github.com/luk036/digraphx.git
cd digraphx
pip install -e .

Dependencies

Quick Start

Detect Negative Cycles

from digraphx import NegCycleFinder

# Create a directed graph with a negative cycle
digraph = {
    'a': {'b': 7, 'c': 5},
    'b': {'a': 0, 'c': 3},
    'c': {'a': 2, 'b': 1}
}

# Initialize distances
dist = {node: 0 for node in digraph}

# Find negative cycles using Howard's algorithm
finder = NegCycleFinder(digraph)
for cycle in finder.howard(dist, lambda edge: edge):
    print(f"Found negative cycle: {cycle}")

Minimum Cycle Ratio

from digraphx import MinCycleRatioSolver
from digraphx import DiGraphAdapter
from fractions import Fraction

# Create a graph with cost and time attributes
graph = DiGraphAdapter()
graph.add_edge('a', 'b', cost=5, time=1)
graph.add_edge('b', 'c', cost=3, time=1)
graph.add_edge('c', 'a', cost=-2, time=1)

# Solve for minimum cycle ratio
solver = MinCycleRatioSolver(graph)
dist = {node: Fraction(0) for node in graph}
ratio, cycle = solver.run(dist, Fraction(10))
print(f"Minimum cycle ratio: {ratio}")

High-Performance Graph with TinyDiGraph

from digraphx import TinyDiGraph

# Create a graph optimized for 1000 nodes
graph = TinyDiGraph()
graph.init_nodes(1000)

# Add edges efficiently
for i in range(1000):
    for j in range(i+1, min(i+10, 1000)):
        graph.add_edge(i, j, weight=i+j)

# Access graph properties
print(f"Nodes: {graph.number_of_nodes()}")
print(f"Edges: {graph.number_of_edges()}")

Algorithms Implemented

Core Algorithms

  • Howard's Algorithm: Efficient negative cycle detection using policy iteration
  • Bellman-Ford: Shortest paths with negative edge weights
  • Parametric Optimization: Generic framework for ratio-based objectives
  • Cycle Ratio: Find cycles with minimum/maximum cost/time ratios

Data Structures

  • TinyDiGraph: Memory-efficient directed graph for fixed-size node sets
  • DiGraphAdapter: NetworkX compatibility layer with custom storage
  • MapAdapter: List-based dictionary for O(1) node/edge access

Documentation

Full API documentation is available at https://digraphx.readthedocs.io/

Testing

Run's test suite:

# Run all tests
pytest

# Run specific test file
pytest tests/test_tiny_digraph.py

# Run with coverage
pytest --cov=digraphx --cov-report=html

Development

# Install development dependencies
pip install -e ".[testing]"

# Run linting
pre-commit run --all-files

# Format code
black src/digraphx tests
isort src/digraphx tests

# Build package
tox -e build

Contributing

Contributions are welcome! Please ensure:

  • All tests pass
  • Code follows the project's style guidelines (see AGENTS.md)
  • New features include tests and documentation
  • Pre-commit hooks pass before pushing

License

This project is licensed under the MIT License - see the LICENSE.txt file for details.

Acknowledgments

Built on top of NetworkX Uses PyScaffold for project structure

Contact

Citation

If you use digraphx in your research, please cite:

@software{digraphx,
  title = {digraphx: Directed Graph X in Python},
  author = {Luk, Wai-Shing},
  url = {https://github.com/luk036/digraphx},
  year = {2026}
}

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

digraphx-0.3.tar.gz (178.7 kB view details)

Uploaded Source

Built Distribution

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

digraphx-0.3-py3-none-any.whl (25.1 kB view details)

Uploaded Python 3

File details

Details for the file digraphx-0.3.tar.gz.

File metadata

  • Download URL: digraphx-0.3.tar.gz
  • Upload date:
  • Size: 178.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for digraphx-0.3.tar.gz
Algorithm Hash digest
SHA256 00f3bc9c6e198104c682340855d1c971cab6a38d88b65654e31e2ba8b24381d7
MD5 47bf3ea7c56aabb50ae37b0900d921be
BLAKE2b-256 e2d17d0c6673183816a45f2fdca2d8f3065f1d9d3b6646fd208823843122a3da

See more details on using hashes here.

Provenance

The following attestation bundles were made for digraphx-0.3.tar.gz:

Publisher: python-publish.yml on luk036/digraphx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file digraphx-0.3-py3-none-any.whl.

File metadata

  • Download URL: digraphx-0.3-py3-none-any.whl
  • Upload date:
  • Size: 25.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for digraphx-0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5bb5249e841b9b3b2829bf0ad9bc42026e36b59b4d28083ad042ea0e1d6296b2
MD5 072935a8d76e365a5c69636c44daa8c6
BLAKE2b-256 299ec02c624de5ab9b3abeeabc4e88126b4b4144fe3500d9d8c1360ed092837b

See more details on using hashes here.

Provenance

The following attestation bundles were made for digraphx-0.3-py3-none-any.whl:

Publisher: python-publish.yml on luk036/digraphx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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