================================================================================================
============= Computer Assisted Proof for Learning Read-once DNFs with Gradient Descent ========
================================================================================================

++++++++++++++++++++++++++ Introduction ++++++++++++++++++++++++++++++++++++++++++++++++++++++++

This code implements the computer assisted proof as described here:
https://openreview.net/forum?id=G0VouKj9HUG

The simulation learns balanced read-once DNFs using a convex neural network and gradient descent.
The simulation performs all calculations in integers.

The simulation performs the following steps:
	1. Goes over all the balanced read-once DNF of size D with terms of size at least 2.
	2. Generates all the data of dimension D (i.e., population setting) and labels it with respect 
	   to a read-once DNF.
	3. Trains a convex network using all the data until the network gets to zero loss.
	4. Prunes the network using a constant value (as described in the paper).
	5. Rounds the pruned network using a constant value (as described in the paper).
	6. Checks if the resulting network is a DNF-recovery solution.

++++++++++++++++++++++++++ Files +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

consts.py 		- Contains all the simulation's parameters
data.py         - Contains the read-once DNF data functions and functions to create all the data
defs.py 		- Contains all the imports for external libraries
main.py 		- The main file of this simulation
network.py 		- Contains the network class
README 			- This file
utils.py 	- Contains all the functionality of the pruning and reconstruction process

++++++++++++++++++++++++++ How to ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

All the parameters of the simulation are defined in consts.py.

To run the simulation, run the following command:
python main.py
