Skip to main content

XGI is a Python package for higher-order networks.

Project description

XGI

Project Status: Active – The project has reached a stable, usable state and is being actively developed. Supports Python versions 3.10 and above. Test Status codecov Good First Issue DOI pyOpenSci Benchmarks

Sign up for our mailing list and follow XGI on Twitter or Mastodon!

Table of Contents:

What is XGI?

CompleX Group Interactions (XGI) is a Python package for higher-order networks (If you want more information on what higher-order networks are, see our brief introduction).

XGI is a software designed to streamline working with higher-order networks from start to finish. XGI can

  • Create synthetic datasets from many generative models
  • Read and write higher-order datasets in a user-friendly way
  • Represent hypergraphs, directed hypergraphs, and simplicial complexes with efficient and flexible data structures
  • Analyze higher-order networks with measures and algorithms
  • Manipulate node and edge statistics in a flexible and customizable way.
  • Draw higher-order networks in a variety of visually striking ways (See our gallery for several examples.)

Installation

XGI runs on Python 3.10 or higher.

To install the latest version of XGI, run the following command:

pip install xgi

To install this package locally:

  • Clone this repository
  • Navigate to the folder on your local machine
  • Run the following command:
pip install -e .["all"]
  • If that command does not work, you may try the following instead
pip install -e ."[all]"

For more installation options, see the guide.

Getting Started

To get started, take a look at the user guides illustrating the library's basic functionality.

XGI-DATA

A number of higher-order datasets are available in the XGI-DATA repository and can be easily accessed with the load_xgi_data() function.

How to Contribute

If you want to contribute to this project, please make sure to read the contributing guidelines. We expect respectful and kind interactions by all contributors and users as laid out in our code of conduct.

The XGI community always welcomes contributions, no matter how small. We're happy to help troubleshoot XGI issues you run into, assist you if you would like to add functionality or fixes to the codebase, or answer any questions you may have.

Some concrete ways that you can get involved:

  • Get XGI updates by following the XGI Twitter account, signing up for our mailing list, or starring this repository.
  • Spread the word when you use XGI by sharing with your colleagues and friends.
  • Request a new feature or report a bug by raising a new issue.
  • Create a Pull Request (PR) to address an open issue or add a feature.
  • Join our Zulip channel to be a part of the daily goings-on of XGI.

How to Cite

We acknowledge the importance of good software to support research, and we note that research becomes more valuable when it is communicated effectively. To demonstrate the value of XGI, we ask that you cite the XGI paper in your work. You can cite XGI either by going to our repository page repository page (if you haven't already) and clicking the "cite this repository" button on the right sidebar (which will generate a citation in your preferred format) or by copying the following BibTeX entry:

@article{Landry_XGI_2023,
    author = {Landry, Nicholas W. and Lucas, Maxime and Iacopini, Iacopo and Petri, Giovanni and Schwarze, Alice and Patania, Alice and Torres, Leo},
    title = {{XGI: A Python package for higher-order interaction networks}},
    doi = {10.21105/joss.05162},
    journal = {Journal of Open Source Software},
    publisher = {The Open Journal},
    year = {2023},
    month = may,
    volume = {8},
    number = {85},
    pages = {5162},
    url = {https://doi.org/10.21105/joss.05162},
}

License

Released under the 3-Clause BSD license (see LICENSE.md)

Copyright (C) 2021-2025 XGI Developers

Support

NSF XGI

See details here.

Other Resources

This library may not meet your needs and if this is this case, consider checking out our list of other resources.

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

xgi-0.10.1.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

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

xgi-0.10.1-py3-none-any.whl (1.2 MB view details)

Uploaded Python 3

File details

Details for the file xgi-0.10.1.tar.gz.

File metadata

  • Download URL: xgi-0.10.1.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for xgi-0.10.1.tar.gz
Algorithm Hash digest
SHA256 9bbe4eba4507c8b432f2b8058e23c87e53f81966e8aa3f5a85f2721caa12f214
MD5 bd78067a9896aa7ff705c06862dbc09d
BLAKE2b-256 da2a370153e845664606d5f459d5206cc37087fb5fed7a8ea2643aa7df071a52

See more details on using hashes here.

File details

Details for the file xgi-0.10.1-py3-none-any.whl.

File metadata

  • Download URL: xgi-0.10.1-py3-none-any.whl
  • Upload date:
  • Size: 1.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for xgi-0.10.1-py3-none-any.whl
Algorithm Hash digest
SHA256 473db9766fdbae1118ec1c00e4a30f79d62460276af619065c48912ae3183a6a
MD5 b2aa05cf2a96a826d3803c3a4674cbf2
BLAKE2b-256 cb230c406372eca6f8d9af41fd0ec67eead4284aa8c070994ade5f67b4c8fbee

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