# SNOV: A Scalable Near-global Optimal  Verifier for Neural Networks 

## Introduction
SNOV (Scalable Near-global Optimal  Verifier for Neural Networks) is an efficient verifier within a branch-and-bound (BaB) framework that tightens bounds from the upper band lower directions: an NLP (nonlinear optimization)-based upper bound (via complementarity constraints) rapidly rejects unsafe instances, while a realaxation-based lower bound (e.g. $\beta-$CROWN) certifies safe ones. This repository contains the $\alpha-\beta-$CROWN (referring to https://github.com/Verified-Intelligence/alpha-beta-CROWN) to compute the lower bounds. Add our functions into their library before running. 

## Structure
- `main_ours.py`: contains the SNOV algorithm implemented on CIFAR10 data.
- `main_mip_cmp.py`: compare our upper bounds SNOV$_u$ with MIP on CIFAR10 datasets. 
- `snov_confis/cifar_test/cifar_small`: contains the configration of SNOV that users can change. 
- `snov_confis/cifar_test/best_NN_cifar10_256.pth`: contains the saved NN model. 
- `libary_other_architecture`: contains the implementation of other architecture like CNN.
- `- `snov_confis/cifar_test/cifar_trainnew.pt` is the datasets for training, which is too large and is available upon request

## Installation

```bash
git clone https://github.com/your-repository/SNOV.git
cd SNOV
pip install - r requirements.txt