

## :star:PAC-Bayes Information Bottleneck

This repo provides the demonstration of our recent paper on identifying information in deep neural networks through *PAC-Bayes Information Bottleneck*.



### :fire:For reproducing the phase transition phenomenon captured by PAC-Bayes IB

1. please refer to the jupyter notebook **demo_track_information.ipynb**.

<p float="left">
  <img src="./figure/mlp_1_info.png" width="250" />
  <img src="./figure/mlp_2_info.png" width="250" />
</p>

<p float="left">
  <img src="./figure/mlp_3_info.png" width="250" />
  <img src="./figure/mlp_4_info.png" width="250" />
</p>

we can see that deeper layer accelerate the fitting and compressing of deep neural networks!



### :fire:For reproducing the information in weights w.r.t. batch size and generalization gap

1. please refer to the jupyter notebook **demo_batch_size_info.ipynb**.

   <p float="left">
     <img src="./figure/info_batch_size.png" width="600" />
   </p>

we can see that the IIW corresponds to the generalization gap (train acc - test acc) on the left hand side!



### :fire:For comparing the performance of the PIB-based SGD algorithm:

1. download CIFAR10 from http://www.cs.toronto.edu/~kriz/cifar.html
2. unzip the file under **./data/cifar-10-python**
3. use `python run_vgg_PIB.py`


or refer to **demo_track_pac_bayes_ibpynb** for a look.



