Skip to main content

CORNETO: A Unified Framework for Omics-Driven Network Inference

Project description

corneto logo

CORNETO: Unified knowledge-driven network inference from omics data.

Paper | Documentation | Notebooks

GitHub stars main


CORNETO is a Python framework for inferring biological networks from omics data by framing them as optimisation problems. It provides a unified, flexible, and extensible API to solve a wide range of network inference problems, including signalling pathway and metabolic model reconstruction.

Why CORNETO?

Feature Why it matters
🧩 Unified optimisation core Express causal signaling, FBA, PCSF & more with the same primitives.
🎯 Exact, solver-backed answers LP/MILP formulations guarantee optimality
📊 Multi-sample power Borrow strength across conditions for cleaner, comparable subnetworks.
🔧 Modular & extensible Plug-in new constraints, priors, or scoring functions in a few lines of code.
Multi-backend Supports CVXPY and PICOS backends with dozens of mathematical solvers.

🚀 Installation

Recommended Installation

For most users, we recommend creating a conda environment and installing the research flavor:

conda create -n corneto python>=3.10
conda activate corneto
conda install python-graphviz
pip install corneto[research]

This installs CORNETO with all research dependencies including Gurobi, PICOS, and visualization libraries.

Standard Installation

The minimal installation via pip provides core functionalities:

pip install corneto

Optional dependencies

CORNETO provides several optional dependency groups:

  • research: Full research stack with Gurobi, PICOS, visualization, and network tools
  • os: Open-source solvers (SCIP, HiGHS) with visualization and network tools
  • ml: Machine learning dependencies (JAX, Keras, scikit-learn)

Install any combination with:

pip install corneto[research,ml]  # Multiple extras

Gurobi Installation

For research problems, we strongly recommend using the Gurobi solver. Gurobi is a commercial solver that offers free academic licences. To install and configure Gurobi, please refer to the official Gurobi documentation. After installation, you can verify that Gurobi is correctly set up by running:

from corneto.utils import check_gurobi
check_gurobi()

Development Installation

If you plan to contribute to CORNETO, we recommend using Poetry for dependency management.

git clone https://github.com/saezlab/corneto.git
cd corneto
poetry install --with dev

Legacy Compatibility

The stable version used by LIANA+ and NetworkCommons remains available. However, we recommend using the latest version for new projects to access the latest features and improvements described in our manuscript.

🧪 Experiments

Notebooks with the experiments presented in the manuscript are available here: https://github.com/saezlab/corneto-manuscript-experiments

🎓 How to cite

@article{Rodriguez-Mier2025,
	author = {Rodriguez-Mier, Pablo and Garrido-Rodriguez, Martin and Gabor, Attila and Saez-Rodriguez, Julio},
	title = {Unifying multi-sample network inference from prior knowledge and omics data with CORNETO},
	journal = {Nature Machine Intelligence},
	year = {2025},
	doi = {10.1038/s42256-025-01069-9},
	url = {https://www.nature.com/articles/s42256-025-01069-9}
}

🙏 Acknowledgements

CORNETO is developed at the Institute for Computational Biomedicine (Heidelberg University). We acknowledge funding from the European Unions Horizon 2020 Programme under the grant agreement No 951773 (PerMedCoE https://permedcoe.eu/) and under grant agreement No 965193 (DECIDER https://www.deciderproject.eu/)

Saez lab logo UKHD logo PerMedCoE logo UKHD logo

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

corneto-1.0.0b6.tar.gz (230.4 kB view details)

Uploaded Source

Built Distribution

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

corneto-1.0.0b6-py3-none-any.whl (288.4 kB view details)

Uploaded Python 3

File details

Details for the file corneto-1.0.0b6.tar.gz.

File metadata

  • Download URL: corneto-1.0.0b6.tar.gz
  • Upload date:
  • Size: 230.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for corneto-1.0.0b6.tar.gz
Algorithm Hash digest
SHA256 a6832220ed220f1c33f1fa07da40448300deb6a8a1fb696f99886ee71855b845
MD5 bba09691292afc8e4b24eca46ad23992
BLAKE2b-256 6e3f61e3a5fea930a29d72d6b289ac0f97153a768e04640d04a37dffb3b9f856

See more details on using hashes here.

Provenance

The following attestation bundles were made for corneto-1.0.0b6.tar.gz:

Publisher: build-and-publish.yml on saezlab/corneto

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

File details

Details for the file corneto-1.0.0b6-py3-none-any.whl.

File metadata

  • Download URL: corneto-1.0.0b6-py3-none-any.whl
  • Upload date:
  • Size: 288.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for corneto-1.0.0b6-py3-none-any.whl
Algorithm Hash digest
SHA256 98ea3754871c181f6369a037d2c0704e62f5ab2c4477c51a443c9d73193ce201
MD5 d3f0f55e1add803c6d60a464f30bde25
BLAKE2b-256 2cfb90157c123d5b837464c7027909302d639cc12326a756a9f2438e45a6a8e5

See more details on using hashes here.

Provenance

The following attestation bundles were made for corneto-1.0.0b6-py3-none-any.whl:

Publisher: build-and-publish.yml on saezlab/corneto

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