# Do We Always Need to Penalize Variance of Losses for Learning with Label Noise?

This repository is the official implementation of "Do We Always Need to Penalize Variance of Losses for Learning with Label Noise?". 

## Requirements

To install requirements:

```setup
pip install -r requirements.txt
```

## Experiments

To train the model(s) in the paper, run this command:

For Forward-VRNL:

```
python Forward-VRNL-main.py --dataset mnist  --noise_rate 0.2 --alpha 0.1
```

For Reweight-VRNL:

```
python Reweight-VRNL-main.py --dataset mnist  --noise_rate 0.2 --alpha 0.1
```

For VolMinNet-VRNL:

```
python VolMinNet-VRNL-main.py --dataset mnist  --noise_rate 0.2 --alpha 0.005
```

We use the same  [datasets](https://drive.google.com/drive/folders/1OYsRH9x37LQhbmGNv-1Ao1iYTHQN8W7F?usp=sharing) (the images and labels have been processed to .npy format) in [VolMinNet](https://github.com/xuefeng-li1/Provably-end-to-end-label-noise-learning-without-anchor-points).

