# Breaking Poisoned Classifier

This repository contains the code and pretrained models necessary to replicate the results in the ICLR 2021 submission:

**Poisoned classifiers are not only backdoored, they are fundamentally broken** <br>

In this paper, we demonstrate a novel attack against backdoor poisoned classifiers.
<p>
<img src="figures/pipeline.png" width="1000">
Figure 1: Overview of our attack. Given a poisoned classifier, we construct a *robustified smoothed*
classifier using *Denoised Smoothing* (Salman et al., 2020). We then extract colors or cropped patches
from adversarial examples of this robust smoothed classifier to construct novel triggers. These
alternative triggers have similar or even higher attack success rate than the original backdoor.  
</p>

<p>
<img src="figures/result.png" width="1000" align="center">
Figure 2: Results of attacking a poisoned classifier on ImageNet, where the attack success rate of the original backdoor 
is 72.60%.
</p>

To start with, clone the repository:
```
cd breaking-poisoned-classifier
``` 
Remember to download the pretrained denoisers from *Denoised Smoothing* (Follow step 4 [here](https://github.com/microsoft/denoised-smoothing#getting-started)).

## Overview of the Repository
Our code is based on the open source code of [Saha et al (2020)](https://github.com/UMBCvision/Hidden-Trigger-Backdoor-Attacks) and [Salman et al. (2020)](https://github.com/microsoft/denoised-smoothing). The contents of this repository are as follows:

* Directory [denoised-smoothing](https://github.com/microsoft/denoised-smoothing/tree/22b44470833e69ab1fdf7b7610013f7eae715c99) is the open source repository of the paper [Denoised Smoothing](https://arxiv.org/abs/2003.01908).  
* Directory [code](code) contains the code for breaking poisoned classifiers with three backdoor attack methods: [BadNet](https://arxiv.org/abs/1708.06733), [HTBA](https://arxiv.org/abs/1910.00033), [CLBD](https://people.csail.mit.edu/madry/lab/cleanlabel.pdf), as well as attacking poisoned classifiers from the TrojAI dataset.

In [code](code), there are four directories: [badnet](code/badnet), [clbd](code/clbd), [htba](code/htba) and [trojAI](code/trojAI), where we attack different poisoned classifiers. In each directory, we provide a notebook `breaking-poisoned-classifier.ipynb` which contains a demonstration of our attack method.

For detailed instructions, please go to the corresponding directories in [code](code).