Skip to main content

Package for the training, pruning and verification of neural networks.

Project description

pyNeVer

Neural networks Verifier (NeVer 2) is a tool for the training, pruning and verification of neural networks. At present it supports sequential fully connected neural networks with ReLU and Sigmoid activation functions. pyNeVer is the corresponding python package providing all the main capabilities of the NeVer 2 tool and can be easily installed using pip. The PyPI project page can be found at https://pypi.org/project/pyNeVer/ whereas the github repository can be found at https://github.com/NeVerTools/pyNeVer.

REQUIREMENTS AND INSTALLATION

pyNeVer depends on several packages, which should be installed automatically. The packages required for the correct execution are the following:

  • numpy
  • ortools
  • onnx
  • torch
  • torchvision
  • pysmt

All the above packages are available via pip.

To install pyNeVer, run the command:

pip install pynever

To run some examples, further packages may be required. If an example requires a specific package, it will be detailed in the example directory.

DOCUMENTATION

The documentation related to the pyNeVer package can be found in the directory docs/pynever/ as html files.

SUPPORTED INPUTS

At present the pyNeVer package supports only the abstraction and verification of fully connected neural networks with ReLU and Sigmoid activation functions. The training, pruning and conversion supports also batch normalization layers. A network with batchnorm layers following fully connected layers can be converted to a "pure" fully connected neural networks using the capabilities provided in the utilities.py module.
The conversion.py provides the capabilities for the conversion of PyTorch and ONNX networks: therefore this kind of networks can be loaded using the respective frameworks and then converted to the internal representation used by pyNeVer. The properties for the verification and abstraction of the networks must be defined either in python code following the specification which can be found in the documentation, or via an SMT-LIB file compliant to the VNN-LIB standard. Examples of the python specification of the properties can be found in all the scripts in the directory examples/submissions/ATVA2021/.

EXAMPLES

NB: All the scripts should be executed INSIDE the related directory!

  • The directory examples/ contains some examples of application of the pyNeVer package. In particular the jupyter notebook shows a graphical example of the application of the abstraction module for the reachability of a small network with bi-dimensional input and outputs.

  • The pruning_example.py script show how to train and prune some small fully connected neural networks with relu activation function. It also show how it is possible to combine batch norm layer and fully connected layers to make the networks compliant with the requirements of the verification and abstraction modules.

  • The directory examples/submissions/ATVA2021 contains the experimental setup used for the experimental evaluation in our ATVA2021 paper. The experiments can be easily replicated by executing the python scripts acas_experiment.py from within the ATVA2021/ directory. The log files will be generated and will be saved in the logs/ directory.

CONTRIBUTORS

The main contributors of pyNeVer are Dario Guidotti and Armando Tacchella, further contributions are provided by Stefano Demarchi.

Students contributions:

  • Alessandro Drago - TensorFlow conversion

Project details


Download files

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

Source Distribution

pyNeVer-0.1.1a2.tar.gz (53.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyNeVer-0.1.1a2-py3-none-any.whl (58.5 kB view details)

Uploaded Python 3

File details

Details for the file pyNeVer-0.1.1a2.tar.gz.

File metadata

  • Download URL: pyNeVer-0.1.1a2.tar.gz
  • Upload date:
  • Size: 53.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for pyNeVer-0.1.1a2.tar.gz
Algorithm Hash digest
SHA256 5a7456d34fd6e757a34cac83f3a6e09a48a08b3abff1e769850958a116f4548c
MD5 5d8cfb72e7609298f8100700ac3fbadd
BLAKE2b-256 23e3a81c5575dc4ed00891815b86966b2445e23ddd430ca27dfbfe6410012b4c

See more details on using hashes here.

File details

Details for the file pyNeVer-0.1.1a2-py3-none-any.whl.

File metadata

  • Download URL: pyNeVer-0.1.1a2-py3-none-any.whl
  • Upload date:
  • Size: 58.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for pyNeVer-0.1.1a2-py3-none-any.whl
Algorithm Hash digest
SHA256 d33e0de2b0a9db1a4feac0560c6ca2bcd57b575496686319611f11eff93ac817
MD5 9b86d17d5307d25d92f1c30e3aa7b946
BLAKE2b-256 e88be7c64948fb5d5bd3625858a2ec952c40cc5f4f2f8f8d96c4c03418465aaa

See more details on using hashes here.

Supported by

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