Skip to main content

A SteinerTree library implementing several huristic and exact steiner methods.

Project description

SteinerNet

The Steiner Tree Approach refers to a method used in graph theory and network design to find the most efficient way to connect a set of points (nodes), potentially using extra intermediate points (called Steiner points) to minimize the total connection cost.

This the python eqiuivalent to SteinerNet in R. Released 10 years later on date the R version was released.

Installation PyPl Total Downloads

To install:

pip install steinernet

You can install the package locally using pip:

pip install .

Or, for development:

pip install -e .

Requirements

  • Python 3.7+
  • networkx

Usage

import networkx as nx
from steinernet import SteinerNet

# Create a sample graph
G = nx.cycle_graph(6)
terminals = [0, 2, 4]

# Initialize SteinerNet
sn = SteinerNet(G)

# Compute a Steiner tree using the random walk method
T = sn.steinertree(terminals,'ASP', repeats=1, optimize=True)

# Visualize the result
import matplotlib.pyplot as plt
nx.draw(T, with_labels=True)
plt.show()

Turorial

Check the Tutorial on tutorial file

Documentation

  • SteinerNet(graph)

    • graph: networkx.Graph, the input undirected graph (optionally weighted)
    • Returns: SteinerNet object
  • SteinerNet.random_walk_tree(terminals, seed=None)

    • terminals: list of node indices to connect
    • seed: (optional) random seed for reproducibility
    • Returns: networkx.Graph, a random graph
  • SteinerNet.steinertree(terminals, method, repeats=1, optimize=True)

  • terminals: list of node indices to connect

    • method: one of the methods SP, RSP, SPM, ASP, EXA (see their info in the Reference paper below)
      • Returns: an approximate Steiner tree made by the selected method

Readme file for parralel running of the exact algorithm exists in README_PARALLEL

Reference

Afshin Sadeghi and Holger Froehlich, "Steiner tree methods for optimal sub-network identification: an empirical study", BMC Bioinformatics 2013 14:144, doi:10.1186/1471-2105-14-144

License

This project is open source under the Apache 2.0 License. You basically can use it in any commercial or research project.

Citation

To use this package in your work, cite this article as:

@article{sadeghi2013steiner,
  title={Steiner tree methods for optimal sub-network identification: an empirical study},
  author={Sadeghi, Afshin and Fr{\"o}hlich, Holger},
  journal={BMC bioinformatics},
  volume={14},
  pages={1--19},
  year={2013},
  publisher={Springer},
  doi = {https://doi.org/10.1186/1471-2105-14-144}
}

Link to R steinerNet repository.
Link to Python SteinerNet repository.

For bug reports contact me at 🔗 LinkedIn

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

steinernet-0.2.0.tar.gz (13.8 kB view details)

Uploaded Source

Built Distribution

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

steinernet-0.2.0-py3-none-any.whl (14.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for steinernet-0.2.0.tar.gz
Algorithm Hash digest
SHA256 b08ba6dbc8fe8ddcbdc34eb6973e04ad8d73c455bbd46299f74c9a02a2b39589
MD5 59ead3c6accfe3cdce38845f93708d22
BLAKE2b-256 4182716090ac2d7d791718c072bd4b10523f3e74a7b50ddf155846646ef02c58

See more details on using hashes here.

File details

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

File metadata

  • Download URL: steinernet-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 14.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.2

File hashes

Hashes for steinernet-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5175232bf7b2739101b5095f72a5bce3061a2ba355a1fd13d8584e8b34032ad0
MD5 764d29acc31e9d4daf30df6e120c84c5
BLAKE2b-256 47843a7f8d30ac9cd90df14618b273fb88553f33e8cfe7774a1861a5df4297bc

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