Skip to content

Latest commit

 

History

History
31 lines (19 loc) · 1.64 KB

README.md

File metadata and controls

31 lines (19 loc) · 1.64 KB

HNM-PGD

Code for paper 'Fooling Object Detectors: Adversarial Attacks by Half-Neighbor Masks'

We propose a Half-Neighbor Masked Projected Gradient Descent (HNM-PGD) attack that can fool object detection systems under the following constraints:

  1. The maximum limit of changed pixel rate in total pixel of the original image is up to 2%, i.e., for MS COCO dataset, the maximum number of changed pixels is 5000;
  2. The number of 8-connectivity regions is not greater than 10.

We also applied the proposed HNM-PGD attack in the CIKM 2020 AnalytiCup Competition, which was ranked within the top 1% on the leaderboard (17/1701).

HNM-PGD’s workflow can be shown as:

Where we first compute a given input example's salience map, and conduct a Half-Neighbor (HN) procedure to produce a mask that meet the above constraints. The HN procedure here is inspired by K-Nearest-Neighbor algorithm. To be specific, if half of a pixel's neighbors have been chosen by the current mask, then this pixel would also be chosen, otherwise it will be discarded. Final, we employ a PGD adversary to generate adversarial patch via working with a mask.

For more details, you are welcome to check our paper and run our code as:

# download data.zip from AnalytiCup Competition's website, and unzip it.
mv hnm_gpd.py hnm_utils.py ./data/eval_code/
cd /data/eval_code
python hnm_pgd.py

The experimental requirement and dataset can be found in AnalytiCup Competition's website.