Note: If you encounter OutOfMemory Error, please save the trained modules after training in the jupyter notebook (especially z_net), restart the process, and load the modules right after the training part and continue.

An example of the loading codes:

z_net = Regressor(input_size=x_dim, hidden_size=z_dim*50, output_size = z_dim).cuda()
z_net.load_state_dict(torch.load('results/fair/z_net.pt'))



In this folder, we include all the demo of the experiments in our paper.
Section 5.1: InfoSub_LV.ipynb
Section 5.2: InfoSub.ipynb
Section 5.3: InfoSub_FairSyn.ipynb
Section 5.4: InfoSub_FairReal.ipynb
Section 5.5: InfoSub_FairReal.ipynb

uci_data.ipynb is for the preprocess of adult data, 
cover_data.ipynb is for the preprocess of covertype data with region 0 and 2 as training set and 1 and 3 as testing set.
cover_data2.ipynb is for the preprocess of covertype data with region 0, 2, and 3 as training set and 1 as testing set.

Generated data are all saved in \data.
Results are all saved in \results.



We acknowledge the reuse of codes from the following repository:

https://github.com/ermongroup/smile-mi-estimator

Provide the reference of architecture of SMILE

https://github.com/dcmoyer/inv-rep

Provide the reference of preprocessing adult data

https://github.com/Linear95/CLUB

https://github.com/sungyubkim/MINE-Mutual-Information-Neural-Estimation-

Provide the reference of architecture of MINE



We are very thankful for their open-sourced code.