An operational framework for building neurosymbolic (NeSy) systems on top of PyTorch.
Project description
DeepLog
DeepLog is an operational framework for building neurosymbolic (NeSy) systems. Instead of presenting a monolithic stack, DeepLog provides high-performance building blocks that plug directly into PyTorch-first workflows so you can compose differentiable learning and symbolic reasoning with predictable interfaces.
Why DeepLog?
- Symbol-first modeling – declare symbolic tensors and shapes, then let DeepLog check interfaces between modules before you wire them into larger systems.
- Logic-aware modules – compile formulas into differentiable modules, wrap existing PyTorch components, and connect them to multiple reasoning backends.
- Backend flexibility – start with the pure Python engine or enable the Janus/SWI-Prolog backend for lower latency inference without changing your training code.
- Batteries included – tutorial notebooks, example projects (semantic loss, MNIST addition, …), and a Sphinx site walk you from “hello world” to custom NeSy stacks.
- Research to production – typing, validation, and extensive tests keep advanced reasoning pipelines trustworthy when you move from prototypes to production workloads.
Installation
DeepLog publishes optional extras so you can extend the base install as needed:
| Extra | Description |
|---|---|
pydeeplog[examples] |
Adds interactive notebook tooling (Jupyter) plus Lightning/torchvision/torchmetrics for tutorials. |
pydeeplog[janus_engine] |
Installs the Janus SWI-Prolog bridge for the highest performance Prolog backend. |
pydeeplog[tests] |
Adds pytest, coverage and supporting utilities for contributors. |
pydeeplog[site] |
Installs the documentation/notebook toolchain (Sphinx, PyData theme, myst-nb, nbconvert, ipykernel, Lightning/torchvision/torchmetrics, …). |
Combine extras as needed, for example pip install ".[examples,tests]".
Optional: Janus/SWI-Prolog backend
The Janus backend depends on a local SWI-Prolog installation. On Ubuntu you can install it with:
sudo apt-get install software-properties-common
sudo apt-add-repository ppa:swi-prolog/stable && sudo apt-get update
sudo apt-get install swi-prolog
Once SWI-Prolog is available, install the Python bindings via pip install "pydeeplog[janus_engine]".
Install from source
git clone https://github.com/ML-KULeuven/deeplog.git
cd deeplog
pip install -e ".[examples,tests]"
Editable installs refresh automatically when you change the source tree, which is handy when contributing.
Docker images (CPU/GPU)
The root Dockerfile builds a CPU CI base via a DEVICE build arg (default CPU). For local builds:
docker build -t deeplog:cpu --build-arg DEVICE=cpu .
CI builds a CPU image from this Dockerfile. The devcontainer image is built from the same base.
The same image definition is used in CI. For local validation, build it with the command above and then run the contributor checks from CONTRIBUTING.md in your working tree.
Quick start
import torch
from deeplog import SymTensor, WrappedModule, parse_symbol
# Wrap a plain PyTorch head with symbolic input/output shapes so DeepLog can
# validate every tensor that flows through it.
digits = SymTensor([parse_symbol("digit_a"), parse_symbol("digit_b")])
sigmoid_head = WrappedModule(torch.nn.Sigmoid(), digits, digits, name="sigmoid_head")
print(sigmoid_head(torch.tensor([[1.0, -2.0]])))
# tensor([[0.7311, 0.1192]])
WrappedModule validates tensor shapes against the symbolic specification, so interface mismatches surface as Python errors instead of silent shape bugs when you wire modules into larger reasoning pipelines.
For a taste of the symbolic side, compile a logical formula straight into a differentiable module:
from deeplog import parse_formula_to_module
# Count satisfying assignments of A ∨ B over booleans (= 3: TT, TF, FT).
module = parse_formula_to_module(
"sum(A): sum(B): =(A,true)_boolean or =(B,true)_boolean"
)
print(int(module())) # 3
See examples/ for end-to-end notebooks (MNIST addition, semantic loss, DIMACS CNF, LTN, …) and the full API reference on the docs site.
Documentation & tutorials
- Landing page & docs – All documentation lives under
site/. Build it locally with the steps in Building the documentation site. - Notebooks – Reproduces the semantic loss workflow, DeepLog module deep dives, MNIST addition with DeepProbLog, and more. Launch them from the
examples/directory after installingdeeplog[examples]. - API reference – Generated automatically via
sphinx-autoapi, covering symbols, shapes, modules, and engine utilities.
Development workflow
See CONTRIBUTING.md for code quality and testing guidelines.
Public bug reports, questions, and feature requests live on GitHub. Development and code review happen privately, and tagged releases (v*) are mirrored to the public GitHub repository after release.
Building the documentation site
The landing page and docs live under site/ (Sphinx + PyData theme). To preview them locally:
-
Install the site tooling (from the repo root):
pip install -r site/requirements.txt
-
Build the static HTML:
(cd site && make html)
-
Serve the generated pages from
site/build/html. Any static file server works, e.g.:python -m http.server --directory site/build/html 8000
Visit http://localhost:8000 to browse the site. Tools like sphinx-autobuild can provide live reloads, but the above workflow is the canonical build pipeline.
Support & community
- Bugs & questions – Open an issue on GitHub and include reproduction steps plus relevant version information.
- Security reports – Please do not file public issues for security vulnerabilities; instead reach the maintainers privately (see
CONTRIBUTING.mdfor details). - Roadmap discussions – Feature proposals, architectural questions, and broader discussions are welcome via issues.
Contributing
We welcome contributions of all kinds—bug reports, docs, examples, and new modules. Review the contributing guide for coding standards, triage practices, and tips for a smooth review cycle. If you are looking for a first issue, check the tracker for good first issue and help wanted labels.
License
DeepLog is released under the LGPL-2.1 license © DTAI Research Group, KU Leuven.
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 pydeeplog-3.0.3.tar.gz.
File metadata
- Download URL: pydeeplog-3.0.3.tar.gz
- Upload date:
- Size: 92.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b280e2d808dfa671902de1cbcc47fac7736fb1df0926679b7a311c03bc9158b
|
|
| MD5 |
fb3cdff3a31aa6d17627f174314fbb82
|
|
| BLAKE2b-256 |
91185a26641b5cad203ec9892a611f7a0c1deaa676c0f94e2aaddf77001eb386
|
Provenance
The following attestation bundles were made for pydeeplog-3.0.3.tar.gz:
Publisher:
publish.yml on ML-KULeuven/deeplog
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pydeeplog-3.0.3.tar.gz -
Subject digest:
9b280e2d808dfa671902de1cbcc47fac7736fb1df0926679b7a311c03bc9158b - Sigstore transparency entry: 1710198367
- Sigstore integration time:
-
Permalink:
ML-KULeuven/deeplog@3d5090d8f08cb1fff82014c61c7d733d0c797824 -
Branch / Tag:
refs/tags/v3.0.3 - Owner: https://github.com/ML-KULeuven
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3d5090d8f08cb1fff82014c61c7d733d0c797824 -
Trigger Event:
push
-
Statement type:
File details
Details for the file pydeeplog-3.0.3-py3-none-any.whl.
File metadata
- Download URL: pydeeplog-3.0.3-py3-none-any.whl
- Upload date:
- Size: 114.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b0bdd2eb32f59ddff455049428658a88635cf60fa4d2901f4b92f1c5f8d0be8b
|
|
| MD5 |
d6b52024498235919f3393cacb35da7b
|
|
| BLAKE2b-256 |
cdbc20e602906ab36eec41e6055cc33887030a7a8fb25a6bfb6d907d30e35a9b
|
Provenance
The following attestation bundles were made for pydeeplog-3.0.3-py3-none-any.whl:
Publisher:
publish.yml on ML-KULeuven/deeplog
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pydeeplog-3.0.3-py3-none-any.whl -
Subject digest:
b0bdd2eb32f59ddff455049428658a88635cf60fa4d2901f4b92f1c5f8d0be8b - Sigstore transparency entry: 1710198467
- Sigstore integration time:
-
Permalink:
ML-KULeuven/deeplog@3d5090d8f08cb1fff82014c61c7d733d0c797824 -
Branch / Tag:
refs/tags/v3.0.3 - Owner: https://github.com/ML-KULeuven
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3d5090d8f08cb1fff82014c61c7d733d0c797824 -
Trigger Event:
push
-
Statement type: