Skip to main content

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:

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 or y = 0 as the new upper bound). Right now it is fixed to choosing y = 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

This version

0.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

diffabs-0.1.tar.gz (21.1 kB view details)

Uploaded Source

Built Distribution

diffabs-0.1-py3-none-any.whl (23.6 kB view details)

Uploaded Python 3

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

Hashes for diffabs-0.1.tar.gz
Algorithm Hash digest
SHA256 fd79b15f9a7f6f03f87ce11067f7336f06332b8fcb5adc08a2c03088f633db5e
MD5 8b42d3c7c54812ae3a7926b18d426133
BLAKE2b-256 b0f16754e60584e730009e6b64a7b68daae3e85200777fbc45ecbac3135f789f

See more details on using hashes here.

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

Hashes for diffabs-0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 618ebb1cd43514ab3efe88aa2a56e70500a969c39bbc4d92327ce8990ad95132
MD5 5e9d14fd5e9fbfd0349de7e99b951298
BLAKE2b-256 4331aac9c2e5904864d9c3b0d44af21f3476f4e054c205dc47e4ac1b72a2fc00

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page