A python library for generating ABCD graphs.
Project description
abcd-graph
A python library for generating ABCD graphs.
Installation
Using pip
pip install abcd-graph
Project available at PyPI.
From source
git clone https://github.com/AleksanderWWW/abcd-graph.git
# or - with ssh - git clone git@github.com:AleksanderWWW/abcd-graph.git
cd abcd-graph
pip install .
Usage
from abcd_graph import ABCDGraph, ABCDParams
params = ABCDParams(vcount=1000)
graph = ABCDGraph(params, logger=True).build()
Parameters
params: An instance ofABCDParamsclass.loggerA boolean to enable or disable logging to the console. Default isFalse- no logs are shown.callbacks: A list of instances ofCallbackclass. Default is an empty list.
Returns
The ABCDGraph object with the generated graph.
Graph generation parameters - ABCDParams
The ABCDParams class is used to set the parameters for the graph generation.
Arguments:
| Name | Type | Description | Default |
|---|---|---|---|
vcount |
int |
Number of vertices in the graph | 1000 |
gamma |
float |
Power-law parameter for degrees, between 2 and 3 | 2.5 |
min_degree |
int |
Min degree | 5 |
max_degree |
float |
Parameter for max degree, between 0 and 1 | 0.5 |
beta |
float |
Power-law parameter for community sizes, between 1 and 2 | 1.5 |
min_community_size |
int |
Min community size | 20 |
max_community_size |
float |
Parameter for max community size, between max_degree and 1 |
0.8 |
xi |
float |
Noise parameter, between 0 and 1 | 0.25 |
num_outliers |
int |
Number of outlier vertices in the resulting graph | 0 |
Parameters are validated when the object is created. If any of the parameters are invalid, a ValueError will be raised.
Communities and edges
The ABCDGraph object has two properties that can be used to access the communities and edges of the graph.
communities- A list ofABCDCommunityobjects.edges- A list of tuples representing the edges of the graph.
Example:
from abcd_graph import ABCDGraph, ABCDParams
params = ABCDParams(vcount=1000)
graph = ABCDGraph(params, logger=True).build()
print(graph.communities)
print(graph.edges)
Communities have the following properties:
- vertices - A list of vertices in the community.
- average_degree - The average degree of the community.
- degree_sequence - The degree sequence of the community.
- empirical_xi - The empirical xi of the community.
Exporting
Exporting the graph to different formats is done via the exporter property of the Graph object.
Possible formats are:
| Method | Description | Required packages | Installation command |
|---|---|---|---|
to_networkx() |
Export the graph to a networkx.Graph object. |
networkx |
pip install abcd[networkx] |
to_igraph() |
Export the graph to an igraph.Graph object. |
igraph |
pip install abcd[igraph] |
adj_matrix |
Export the graph to a numpy.ndarray object representing the adjacency matrix. |
||
to_sparse_adjacency_matrix() |
Export the graph to a scipy.sparse.csr_matrix object representing the adjacency matrix. |
scipy |
pip install abcd[scipy] |
Example:
from abcd_graph import ABCDGraph, ABCDParams
params = ABCDParams(vcount=1000)
graph = ABCDGraph(params, logger=True).build()
graph_networkx = graph.exporter.to_networkx()
Callbacks
Callbacks are used to handle diagnostics and visualization of the graph generation process. They are instances of the ABCDCallback class.
Out of the box, the library provides three callbacks:
StatsCollector- Collects statistics about the graph generation process.PropertyCollector- Collects properties of the graph.Visualizer- Visualizes the graph generation process.
Example:
from abcd_graph import ABCDGraph, ABCDParams
from abcd_graph.callbacks import StatsCollector, Visualizer, PropertyCollector
stats = StatsCollector()
vis = Visualizer()
props = PropertyCollector()
params = ABCDParams(vcount=1000)
g = ABCDGraph(params, logger=True, callbacks=[stats, vis, props]).build()
print(stats.statistics)
print(props.xi_matrix)
vis.draw_community_cdf()
Docker
To build a docker image containing the library, run:
docker build -t abcd-graph .
To run the image, use:
docker run -it abcd-graph /bin/bash
This will give you a terminal inside a container with the library installed.
Available are also installation commands for the additional packages:
docker build -t abcd-test --build-arg INSTALL_TYPE=igraph .
Possible values for INSTALL_TYPE are dev, matplotlib, networkx, igraph, scipy, all and extended.
| Value | Packages installed |
|---|---|
dev |
pytest, pre-commit, pytest-cov |
matplotlib |
matplotlib |
networkx |
networkx |
igraph |
igraph |
scipy |
scipy |
all |
networkx, igraph, scipy, pytest, pre-commit, pytest-cov, matplotlib |
extended |
scipy, matplotlib |
[!NOTE] Combinations of the above values are also possible, e.g.
igraph,networkx.
[!WARNING] If you choose and option outside the available ones, the installation will still succeed, but only the base package will be installed.
Examples
The library comes with a set of examples that show how to use the library in different scenarios.
You can find them in the examples directory in the format of Jupyter Notebooks.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file abcd_graph-0.3.1rc1.tar.gz.
File metadata
- Download URL: abcd_graph-0.3.1rc1.tar.gz
- Upload date:
- Size: 17.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.5 CPython/3.12.7 Linux/6.5.0-1025-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fcace0a8cdf7946508eaabe54d102c8186d414a7a62b6f843ef7755ea0ce197b
|
|
| MD5 |
02248e6aabe2d6d97cd640c78fc00947
|
|
| BLAKE2b-256 |
ce86cc5f16755b7faa4abb7aa8db8b5f16d32d43008a888658785417937876d0
|
File details
Details for the file abcd_graph-0.3.1rc1-py3-none-any.whl.
File metadata
- Download URL: abcd_graph-0.3.1rc1-py3-none-any.whl
- Upload date:
- Size: 33.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.5 CPython/3.12.7 Linux/6.5.0-1025-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f1c1d628c114907f1806d72a4e5052156fe10b53249aae8b82ec9d2e9cbb14e5
|
|
| MD5 |
6a830c38c2498a2a646a553f80a50adf
|
|
| BLAKE2b-256 |
fa707604a95cc473fcafa7a2d9bee51c3054254cc55c9ad0f8a039cd56c88550
|