Skip to main content

A package for building a hierarchy based on multiple partitions on graph nodes.

Project description

HiDeF (Hierarchical community Decoding Framework)

Documentation Status Downloads

Introduction

HiDeF is a method for robustly resolving the hierarchical structures of networks based on multiscale community detection and the concepts of persistent homology.

HiDeF is described in the following manuscript:

Zheng, F., Zhang, S., Churas, C. et al., HiDeF: identifying persistent structures in multiscale ‘omics data. Genome Biol 22, 21 (2021).

Updates

  • 1.1.5 Fixed bug where _tmp edge list temp files collide if multiple instances of hidef_finder.py are run on same machine. Made small fix to jaccard_matrix to handle scipy breaking change

  • 1.1.4 Add Colab notebooks allowing quick exploration of HiDeF results - now applicable to models based on protein-protein interaction network.

  • 1.1.3 Stable release around the time of paper publication, the first version available with pip.

Installation (Python package)

With pip:
pip install hidef

From source:
python setup.py install

Usage

Running HiDeF from Cytoscape

Best for small/medium networks < 10k nodes and < 50k edges.

HiDeF has been fully integrated with the Cytoscape platform, via our recently published Community Detection APplication and Service (CDAPS) framework.

With this option users can access unique features in the CDAPS framework, including (1) interacting with the source network to visualize the subnetwork of any detected community (2) performing gene set enrichment analysis (when the vertices of the source network are proteins/genes) (3) sharing the models via the NDEx database.

Running HiDeF as a command-line tool

First, install the package as instructed above.

Using the codes in this repository, HiDeF can be used as a command-line tool. There are two main components of the scripts: hidef_finder.py and weaver.py.

To sweep the resolution profile and generate an optimized hierarchy based on pan-resolution community persistence, run the following command in a terminal:

python hidef_finder.py --g $graph --maxres $n --o $out [--options]

  • $graph: a tab delimited file with 2-3 columns: nodeA, nodeB, weight (optional).
  • $maxres: the upper limit of the sampled range of the resolution parameter.
  • $out: a prefix string for the output files.

Other auxiliary parameters are explained in the manuscript.

Outputs

  • $out.nodes: A TSV file describing the content (nodes in the input network) of each community. The last column of this file contains the persistence of each community.
  • $out.edges: A TSV file describing the parent-child relationships of communities in the hierarchy. The parent communities are in the 1st column and the children communities are in the 2nd column.
  • $out.gml: A file in the GML format that can be opened in Cytoscape to visualize the hierarchy (using "yFiles hierarchic layout" in Cytoscape)

Using HiDeF as a python package

For documents, please see https://hidef.readthedocs.io.

The following example shows how to build a hierarchical view of a network based on pre-computed communities, by using HiDeF as a Python package. This workflow only involves weaver.py.

First, the user needs to provide the clustering results on these data points. These results may be obtained from any multilevel clustering algorithm of the user's choice. In this example, suppose we have 8 data points and define 7 ways of partitioning them (in a Python terminal),

P = ['11111111',
  '11111100',
  '00001111',
  '11100000',
  '00110000',
  '00001100',
  '00000011']

Then the hierarchical view can be obtained by

from hidef import weaver
wv = weaver.Weaver()
H = wv.weave(P, cutoff=1.0)

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

hidef-1.1.5.tar.gz (30.4 kB view details)

Uploaded Source

Built Distribution

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

hidef-1.1.5-py3-none-any.whl (39.0 kB view details)

Uploaded Python 3

File details

Details for the file hidef-1.1.5.tar.gz.

File metadata

  • Download URL: hidef-1.1.5.tar.gz
  • Upload date:
  • Size: 30.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.2

File hashes

Hashes for hidef-1.1.5.tar.gz
Algorithm Hash digest
SHA256 06710d30f15cb29f28ad60d3345f51d38e119692eb4fdb602009a06f803601aa
MD5 d9f2e230c7923c6b8899d6e44ee90218
BLAKE2b-256 a17584aa89f8630879b73bc8332fb7b248077b752c8ca806e1dead8631d81dbb

See more details on using hashes here.

File details

Details for the file hidef-1.1.5-py3-none-any.whl.

File metadata

  • Download URL: hidef-1.1.5-py3-none-any.whl
  • Upload date:
  • Size: 39.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.2

File hashes

Hashes for hidef-1.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 9af01b44ac4d1166e3082c8950e164a317c01440aff8a62a0bcffb4d47cf8c55
MD5 a570b8e4a304fe04da66375fddd0f0ad
BLAKE2b-256 21c30977e55bfc74479fc1ea4aea6d553b2b6dffb3ae9c2176097b6ef244be7d

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