Metadata-Version: 2.1
Name: abcd-graph
Version: 0.3.0
Summary: A python library for generating ABCD graphs.
Home-page: https://github.com/AleksanderWWW/abcd-graph
License: MIT
Author: Aleksander Wojnarowicz
Requires-Python: >=3.10,<4.0
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Provides-Extra: all
Provides-Extra: dev
Provides-Extra: extended
Provides-Extra: igraph
Provides-Extra: matplotlib
Provides-Extra: networkx
Provides-Extra: scipy
Requires-Dist: igraph ; extra == "igraph" or extra == "all"
Requires-Dist: matplotlib (>=3.9.0,<4.0.0) ; extra == "matplotlib" or extra == "all" or extra == "extended"
Requires-Dist: networkx (>=3.3,<4.0) ; extra == "networkx" or extra == "all"
Requires-Dist: numpy (>=1.26.4,<2.0.0)
Requires-Dist: pre-commit (>=3.7.0,<4.0.0) ; extra == "dev" or extra == "all"
Requires-Dist: pytest (>=8.1.1,<9.0.0) ; extra == "dev" or extra == "all"
Requires-Dist: pytest-cov (>=5.0.0,<6.0.0) ; extra == "dev" or extra == "all"
Requires-Dist: scipy (>=1.0.0,<2.0.0) ; extra == "scipy" or extra == "all" or extra == "extended"
Requires-Dist: typing-extensions (>=4.10.0,<5.0.0)
Project-URL: Repository, https://github.com/AleksanderWWW/abcd-graph
Description-Content-Type: text/markdown

# abcd-graph
A python library for generating ABCD graphs.

## Installation

### Using `pip`
```bash
pip install abcd-graph
```
Project available at [PyPI](https://pypi.org/project/abcd-graph/).

### From source
```bash
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

```python
from abcd_graph import ABCDGraph, ABCDParams

params = ABCDParams()
graph = ABCDGraph(params, n=1000, logger=True).build()
```

### Parameters

- `params`: An instance of `ABCDParams` class.
- `n`: Number of nodes in the graph.
- `logger` A boolean to enable or disable logging to the console. Default is `False` - no logs are shown.
- `callbacks`: A list of instances of `Callback` class. 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 |
|---------|---------|----------------------------------------------------------|---------|
| `gamma` | `float` | Power-law parameter for degrees, between 2 and 3         | 2.5     |
| `delta` | `int`   | Min degree                                               | 5       |
| `zeta`  | `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     |
| `s`     | `int`   | Min community size                                       | 20      |
| `tau`   | `float` | Parameter for max community size, between zeta and 1     | 0.8     |
| `xi`    | `float` | Noise parameter, between 0 and 1                         | 0.25    |

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 of `ABCDCommunity` objects.
- `edges` - A list of tuples representing the edges of the graph.

Example:

```python

from abcd_graph import ABCDGraph, ABCDParams

params = ABCDParams()

graph = ABCDGraph(params, n=1000, 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:

```python
from abcd_graph import ABCDGraph, ABCDParams

params = ABCDParams()
graph = ABCDGraph(params, n=1000, 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:

```python

from abcd_graph import ABCDGraph, ABCDParams

from abcd_graph.callbacks import StatsCollector, Visualizer, PropertyCollector

stats = StatsCollector()
vis = Visualizer()
props = PropertyCollector()
params = ABCDParams()
g = ABCDGraph(params, n=1000, 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:

```bash
docker build -t abcd-graph .
```

To run the image, use:

```bash
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:

```bash
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.

