Awesome Open Source
Awesome Open Source
Sponsorship

|Anaconda Version| |Anaconda Downloads| |Documentation| |PyPi|

DeepGraph

DeepGraph is a scalable, general-purpose data analysis package. It implements a network representation <https://en.wikipedia.org/wiki/Network_theory>_ based on pandas <http://pandas.pydata.org/>_ DataFrames <http://pandas.pydata.org/pandas-docs/stable/generated/pandas.DataFrame.html>_ and provides methods to construct, partition and plot networks, to interface with popular network packages and more.

It is based on a new network representation introduced here <http://arxiv.org/abs/1604.00971>. DeepGraph is also capable of representing multilayer networks <http://deepgraph.readthedocs.io/en/latest/tutorials/terrorists.html>.

Main Features

This network package is targeted specifically towards Pandas <http://pandas.pydata.org/>_ users. Utilizing one of Pandas' primary data structures, the DataFrame <http://pandas.pydata.org/pandas-docs/stable/generated/pandas.DataFrame.html>_, we represent the (super)nodes of a graph by one set of tables, and their pairwise relations (i.e. the (super)edges of a graph) by another set of tables. DeepGraph's main features are

  • Create edges <https://deepgraph.readthedocs.io/en/latest/api_reference.html#creating-edges>_: Methods that enable an iterative, yet vectorized computation of pairwise relations (edges) between nodes using arbitrary, user-defined functions on the nodes' properties. The methods provide arguments to parallelize the computation and control memory consumption, making them suitable for very large data-sets and adjustable to whatever hardware you have at hand (from netbooks to cluster architectures).

  • Partition nodes, edges or a graph <https://deepgraph.readthedocs.io/en/latest/api_reference.html#graph-partitioning>_: Methods to partition nodes, edges or a graph by the graph’s properties and labels, enabling the aggregation, computation and allocation of information on and between arbitrary groups of nodes. These methods also let you express elaborate queries on the information contained in a deep graph.

  • Interfaces to other packages <https://deepgraph.readthedocs.io/en/latest/api_reference.html#graph-interfaces>_: Methods to convert to common network representations and graph objects of popular Python network packages (e.g., SciPy sparse matrices, NetworkX graphs, graph-tool graphs).

  • Plotting <https://deepgraph.readthedocs.io/en/latest/api_reference.html#plotting-methods>_: A number of useful plotting methods for networks, including drawings on geographical map projections.

Quick Start

DeepGraph can be installed via pip from PyPI <https://pypi.python.org/pypi/deepgraph>_

::

$ pip install deepgraph

or if you're using Conda <http://conda.pydata.org/docs/>_, install with

::

$ conda install -c conda-forge deepgraph

Then, import and get started with::

import deepgraph as dg help(dg)

Documentation

The official documentation is hosted here: http://deepgraph.readthedocs.io

The documentation provides a good starting point for learning how to use the library. Expect the docs to continue to expand as time goes on.

Development

So far the package has only been developed by me, a fact that I would like to change very much. So if you feel like contributing in any way, shape or form, please feel free to contact me, report bugs, create pull requestes, milestones, etc. You can contact me via email: [email protected]

Bug Reports

To search for bugs or report them, please use the bug tracker: https://github.com/deepgraph/deepgraph/issues

Citing DeepGraph

Please acknowledge and cite the use of this software and its authors when results are used in publications or published elsewhere. You can use the following BibTex entry

::

@Article{traxl-2016-deep, author = {Dominik Traxl AND Niklas Boers AND J"urgen Kurths}, title = {Deep Graphs - A general framework to represent and analyze heterogeneous complex systems across scales}, journal = {Chaos}, year = {2016}, volume = {26}, number = {6}, eid = {065303}, doi = {http://dx.doi.org/10.1063/1.4952963}, eprinttype = {arxiv}, eprintclass = {physics.data-an, cs.SI, physics.ao-ph, physics.soc-ph}, eprint = {http://arxiv.org/abs/1604.00971v1}, version = {1}, date = {2016-04-04}, url = {http://arxiv.org/abs/1604.00971v1} }

Licence

Distributed with a BSD license <LICENSE.txt>_::

Copyright (C) 2017-2020 DeepGraph Developers
Dominik Traxl <[email protected]>

.. |Anaconda Version| image:: https://anaconda.org/conda-forge/deepgraph/badges/version.svg :target: https://anaconda.org/conda-forge/deepgraph

.. |Anaconda Downloads| image:: https://anaconda.org/conda-forge/deepgraph/badges/downloads.svg :target: https://anaconda.org/conda-forge/deepgraph

.. |Anaconda Install| image:: https://anaconda.org/conda-forge/deepgraph/badges/installer/conda.svg :target: https://anaconda.org/conda-forge/deepgraph

.. |Documentation| image:: https://readthedocs.org/projects/deepgraph/badge/?version=latest :target: http://deepgraph.readthedocs.io/en/latest/?badge=latest

.. |PyPi| image:: https://badge.fury.io/py/DeepGraph.svg :target: https://badge.fury.io/py/DeepGraph


Get A Weekly Email With Trending Projects For These Topics
No Spam. Unsubscribe easily at any time.
python (48,431
data-science (778
network (430
data-visualization (388
data-structures (341
data-analysis (242
pandas (234
data-mining (155
parallel (131
network-analysis (86
graphs (75
graph-database (70
graphviz (63
network-visualization (35
graph-theory (27
networkx (21

Find Open Source By Browsing 7,000 Topics Across 59 Categories