README file for "Robust Classification with Noisy Labels Based on Posterior Learning"


**Argmin experiments**
To run the code, run the script "main.py" in the folder argmin.

**f_PML without correction**
To run the code, the user must run the script "train_cifar.py" in the folder f_PML specifying (either as args or in the script) the config file corresponding to the experiment that has to be run.
For instance, when running the experiments for CIFAR-10, specifying "-c config_cifar10.json".
All the main hyperparameters can be modified in the config files.
However, the divergence type and noise percentage have to be specified in the script, because otherwise it automatically runs the experiments for both GAN and SL divergences, for noise rates 20%, 30%, and 40%.
The choice of the divergence is between ["Jensen-Shannon", "SL"] when not using the change of variable, and ["JS_s", "SL_s"]  when using the change of variable (which has to be specified in the config file).

**f_PML with correction**
To run the code, the user must run the script "main.py" in the folder f_PML_Corr. For example, 
```
python3 main.py --dataset CIFAR10 --noise_type sym --noisy_ratio 0.2 --class_method TForward_Sample --mode f-PML --div Jensen-Shannon
```
For more information on the variables that can be changed, we refer to "argument.py" in f_PML_Corr.

**f_PML_Pro**
To run the code, the user must run the script "Train_promix.py" specifying the args as written in "run.sh" and according to the paper. 
The script runs for both GAN and SL divergences sequentially.


The code implementation is based on:
- https://github.com/shengliu66/SOP
- https://github.com/Justherozen/ProMix
- https://github.com/nicolaNovello/discriminative-classification-fDiv
- https://github.com/weijiaheng/Robust-f-divergence-measures
- https://github.com/Virusdoll/Active-Negative-Loss
- https://github.com/BaeHeeSun/RENT
- https://github.com/allan-z/label_noise_ignorance
