# Understanding-the-robustness-accuracy-tradeoff-by-rethinking-robust-fairness
This is the code of the paper "Understanding the robustness-accuracy tradeoff
by rethinking robust fairness" submitted to iclr2022, and will be public after the review process.

## train.py 

train.py is the training code of our ME-AT and ME-TRADES, and also supports
training the origin PGD-AT and TRADES with/without LS.

the mode list of train.py is:

[0:'PGD-AT',
1:'PGD-AT+LS',
2:'ME-AT',
3:'TRADES',
4:'TRADES+LS',
5:'ME-TRADES']

For example, to run the ME-AT at $\beta=0.5$:

python train.py --mode 2 --beta 0.5 --save_path your_path

## single_adv_train.py

And single_adv_train.py is the code of single AT in this paper, 
the key parameter is the args.target. The parameter determines which class
to be adversarial trained, and we can run it as:

python single_adv_train.py --target 1 --savepath single_1_at --device cuda

The visualization code of the 2-d feature representations and
the classwise errors are also provided in the notebook visualization.ipynb,
which can be easily used.




