Differentiable abstract domain implementations for neural network reasoning on PyTorch
Project description
DiffAbs
DiffAbs is a PyTorch implementation of multiple abstract domains that can be used in certifying or reasoning neural networks. Implemented purely using PyTorch, it is differentiable and supports GPU by default, thus amenable for safety/robustness driven training on abstract domains.
Currently, the following abstract domains are implemented:
- Vanilla interval domain;
- DeepPoly domain (https://dl.acm.org/doi/10.1145/3290354);
Domain notes
DeepPoly ReLU heuristics:
- A variant of the original DeepPoly domain is implemented where the
ReLU approximation is not heuristically choosing between two choices
(either picking
y = x
ory = 0
as the new upper bound). Right now it is fixed to choosingy = 0
, because there was Galois connection violation observed if this heuristic is enabled. Basically, it is observed in experiment that a smaller abstraction may unexpectedly incur larger safety distance than its containing larger abstraction.
Supported systems
Although it is currently tested on Mac OS X 10.15 and Ubuntu 16.04 with Python 3.7 and PyTorch 1.5, it should generalize to other platforms and older PyTorch (perhaps ≥ v1.0) smoothly.
However, Python ≤ 3.6 may be incompatible. Because type annotations
are specified everywhere and the type annotation of self class is only
supported by __future__.annotations
in Python 3.7. If using Python
3.6, this needs to use 'type string' instead.
Installation
In your virtual environment, either install directly from this repository by
git clone git@github.com:XuankangLin/DiffAbs.git
cd DiffAbs
pip install -e .
or directly install from PyPI:
pip install diffabs
Testing
Test cases for individual abstract domains are under the tests/
directory and can be run using command
pytest
Note that torchvision
is needed to run the tests for conv/maxpool layers.
License
The project is available open source under the terms of MIT License.
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
File details
Details for the file diffabs-0.1.tar.gz
.
File metadata
- Download URL: diffabs-0.1.tar.gz
- Upload date:
- Size: 21.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fd79b15f9a7f6f03f87ce11067f7336f06332b8fcb5adc08a2c03088f633db5e |
|
MD5 | 8b42d3c7c54812ae3a7926b18d426133 |
|
BLAKE2b-256 | b0f16754e60584e730009e6b64a7b68daae3e85200777fbc45ecbac3135f789f |
File details
Details for the file diffabs-0.1-py3-none-any.whl
.
File metadata
- Download URL: diffabs-0.1-py3-none-any.whl
- Upload date:
- Size: 23.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 618ebb1cd43514ab3efe88aa2a56e70500a969c39bbc4d92327ce8990ad95132 |
|
MD5 | 5e9d14fd5e9fbfd0349de7e99b951298 |
|
BLAKE2b-256 | 4331aac9c2e5904864d9c3b0d44af21f3476f4e054c205dc47e4ac1b72a2fc00 |