Trainable graph adjacency parameterizations with ODE integration and Lightning training helpers.
Project description
GradNet
GradNet provides differentiable parameterizations of graph adjacency matrices with explicit budget and structure constraints. It pairs these parameterizations with ODE solvers and a lightweight PyTorch Lightning training loop so you can prototype network optimization problems quickly.
Highlights
- Learn dense or sparse adjacency updates with norm, sign, and symmetry constraints.
- Projected parameterizations that stay differentiable and GPU friendly.
- Torchdiffeq-backed integration utilities for graph-driven dynamical systems.
- Minimal Lightning trainer that wraps custom loss functions in just a few lines.
Installation
Install the released package from PyPI:
pip install gradnet
To work off the latest sources instead, clone the repository and install in editable mode:
pip install -e .
GradNet targets Python 3.10+ and depends on PyTorch, PyTorch Lightning, torchdiffeq, NumPy, and tqdm (installed automatically by the command above). Install the optional NetworkX helpers with pip install gradnet[networkx] when you need conversions to networkx graphs or plotting utilities that rely on it.
Documentation
Full API documentation, tutorials, and background material live at gradnet.readthedocs.io.
Quickstart
Learn a constrained adjacency
import torch
from gradnet import GradNet
num_nodes = 10
model = GradNet(
num_nodes=num_nodes,
budget=1.0,
undirected=True,
)
adjacency = model() # full (num_nodes, num_nodes) tensor
Pass a sparse COO mask via the mask argument to switch to the sparse backend and optimize only selected edges.
Integrate a graph-driven ODE
from gradnet import integrate_ode
# simple linear dynamics \dot{x} = Ax
def vector_field(t, x, A):
return A @ x
x0 = torch.randn(num_nodes)
t_grid = torch.linspace(0.0, 1.0, 51)
sol_t, sol_x = integrate_ode(model, vector_field, x0, t_grid)
Optimize with your own loss
from gradnet import GradNet, fit
# encourage sparse, small-magnitude updates
def loss_fn(g: GradNet):
delta = g.get_delta_adj()
return delta.abs().mean()
fit(gradnet=model, loss_fn=loss_fn, num_updates=200, learning_rate=1e-2)
The trainer handles optimizer setup, logging, and checkpointing while you focus on defining the objective.
Modules at a glance
gradnet.GradNet: wraps dense and sparse parameterizations, supports directed/undirected networks, masking, custom edge-building costs etc.gradnet.integrate_ode: torchdiffeq-powered solver with adjoint and event support for adjacency-dependent dynamics.gradnet.fit: PyTorch Lightning loop that optimizes aGradNetusing user-supplied loss functions.gradnet.utils: various helpers functions.
License
GradNet is released under the BSD 3-Clause License. See LICENSE for details.
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 gradnet-0.1.4.tar.gz.
File metadata
- Download URL: gradnet-0.1.4.tar.gz
- Upload date:
- Size: 24.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a8e02e0a3a52625adb1981a6af1bf1852c4d17afacb312377bc6d6d15bb6b673
|
|
| MD5 |
ef0beec6a2fc9aa9494e1725657938cd
|
|
| BLAKE2b-256 |
66325d775fd67929f1c2d32f8f50963d0866159489be1654ee5ef1a93f0fb840
|
File details
Details for the file gradnet-0.1.4-py3-none-any.whl.
File metadata
- Download URL: gradnet-0.1.4-py3-none-any.whl
- Upload date:
- Size: 26.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
91d4877b81b1cd0e811beb101abe4c0c6434f17b93a873698cb4896cff52adb9
|
|
| MD5 |
1c6ef416952467a9fc7a8d231ca66d37
|
|
| BLAKE2b-256 |
58f18f30c5f1d87a0c7525a6a4a44b7016320d3b78d3783e35bd17b04b37f9b2
|