# RPP: A Certified Poisoned-Sample Detection Framework for Backdoor Attacks under Dataset Imbalance

Currently, we have only uploaded the code for the CIFAR10 dataset; updates for other datasets will be provided next.

## To do before you start
The code requires Python >=3.6. The required packages can be installed by:
```python
pip install -r requirements.txt
```
Original CIFAR10 datasets would be automatically downloaded. 


## Usage
Step 1: Pre-train a preliminary model to detect poisoned samples. Run:
```python
python CIFAR10_train.py
```

Step2: Get calibration set. Run:
```python
python calibration_set.py
```

Step3: Detect poisoned samples. Run:
```python
python CIFAR10_detection.py
```

Similar results as in Figure 5,6 can be obtained.

