2021-12-09 21:10:05 +08:00
# [AAAI 2022] FCA: Learning a 3D Full-coverage Vehicle Camouflage for Multi-view Physical Adversarial Attack
2021-09-12 16:33:38 +08:00
2021-12-09 21:10:05 +08:00
## Overview
2021-12-07 20:48:32 +08:00
This is the official implementation and case study of the Full-coverage Vehicle Camouflage(FCA) method proposed in our AAAI 2022 paper [FCA: Learning a 3D Full-coverage Vehicle Camouflage for Multi-view Physical Adversarial Attack ](https://arxiv.org/abs/2109.07193 ).
2021-11-13 15:51:56 +08:00
2021-12-07 20:48:32 +08:00
Source code can be find in [here ](https://github.com/idrl-lab/Full-coverage-camouflage-adversarial-attack/tree/gh-pages/src ).
2021-09-12 16:33:38 +08:00
2021-12-09 21:10:05 +08:00
## Abstract
2021-12-09 22:05:25 +08:00
Physical adversarial attacks in object detection have attracted increasing attention. However, most previous works focus on hiding the objects from the detector by generating an individual adversarial patch, which only covers the planar part of the vehicle’ s surface and fails to attack the detector in physical scenarios for multi-view, long-distance and partially occluded objects. To bridge the gap between digital attacks and physical attacks, we exploit the full 3D vehicle surface to propose a robust Full-coverage Camouflage Attack (FCA) to fool detectors. Specifically, we first try rendering the nonplanar camouflage texture over the full vehicle surface. To mimic the real-world environment conditions, we then introduce a transformation function to transfer the rendered camouflaged vehicle into a photo realistic scenario. Finally, we design an efficient loss function to optimize the camouflage texture. Experiments show that the full-coverage camouflage attack can not only outperform state-of-the-art methods under various test cases but also generalize to different environments, vehicles, and object detectors. The code of FCA will be available at: https://idrl-lab.github.io/Full-coveragecamouflage adversarial-attack/.
2021-09-12 16:33:38 +08:00
2021-12-09 21:10:05 +08:00
## Framework
![image-20211209204327675 ](https://gitee.com/freeneuro/PigBed/raw/master/img/image-20211209204327675.png )
2021-09-13 09:41:14 +08:00
2021-12-09 21:10:05 +08:00
## Cases of Digital Attack
2021-09-13 09:43:00 +08:00
2021-12-09 21:13:57 +08:00
### Multi-view Attack: Carmear distance is 3
2021-09-13 09:43:00 +08:00
2021-12-09 21:57:04 +08:00
< table frame = void cellspacing = "0" cellpadding = "0" >
2021-12-09 21:10:05 +08:00
< tr >
< td > < / td >
< td > Elevation 0< / td >
< td > Elevation 30< / td >
< td > Elevation 50< / td >
< / tr >
2021-09-12 16:45:31 +08:00
< tr >
2021-12-09 21:10:05 +08:00
< td > Original< / td >
2021-09-12 16:52:17 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_3_elevation_0_ori_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 17:46:10 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_3_elevation_30_ori_pred.gif?raw=true' / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_3_elevation_50_ori_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 16:52:17 +08:00
< / tr >
< tr >
2021-12-09 21:10:05 +08:00
< td > FCA< / td >
2021-09-12 17:46:10 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_3_elevation_0_adv_pred.gif?raw=true' / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_3_elevation_30_adv_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 16:52:17 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_3_elevation_50_adv_pred.gif?raw=true' / > < / center > < / td >
< / tr >
2021-09-12 16:54:51 +08:00
< / table >
2021-12-09 21:13:57 +08:00
### Multi-view Attack: Carmear distance is 5
2021-12-09 21:10:05 +08:00
2021-09-12 19:40:57 +08:00
< table border = 0 >
2021-12-09 21:10:05 +08:00
< tr >
< td > < / td >
< td > Elevation 20< / td >
< td > Elevation 40< / td >
< td > Elevation 50< / td >
< / tr >
2021-09-12 16:54:51 +08:00
< tr >
2021-12-09 21:10:05 +08:00
< td > Original< / td >
2021-09-12 16:52:17 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_5_elevation_20_ori_pred.gif?raw=true' / > < / center > < / td >
2021-12-09 21:10:05 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_5_elevation_40_ori_pred.gif?raw=true' / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_5_elevation_50_ori_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 16:52:17 +08:00
< / tr >
< tr >
2021-12-09 21:10:05 +08:00
< td > FCA< / td >
2021-09-12 17:46:10 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_5_elevation_20_adv_pred.gif?raw=true' / > < / center > < / td >
2021-12-09 21:10:05 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_5_elevation_40_adv_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 16:52:17 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_5_elevation_50_adv_pred.gif?raw=true' / > < / center > < / td >
< / tr >
2021-09-12 16:54:51 +08:00
< / table >
2021-12-09 21:13:57 +08:00
### Multi-view Attack: Carmear distance is 10
2021-12-09 21:10:05 +08:00
2021-09-12 16:54:51 +08:00
< table >
2021-09-12 16:52:17 +08:00
< tr >
2021-12-09 21:10:05 +08:00
< td > < / td >
< td > Elevation 30< / td >
< td > Elevation 40< / td >
< td > Elevation 50< / td >
< / tr >
< tr >
< td > Original< / td >
2021-09-12 16:52:17 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_10_elevation_30_ori_pred.gif?raw=true' / > < / center > < / td >
2021-12-09 21:22:25 +08:00
< td > < center > < img src = 'https://github.com/idrl-lab//Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_10_elevation_40_ori_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 17:46:10 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_10_elevation_50_ori_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 16:52:17 +08:00
< / tr >
< tr >
2021-12-09 21:10:05 +08:00
< td > FCA< / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_10_elevation_30_adv_pred.gif?raw=true' / > < / center > < / td >
2021-12-09 21:22:25 +08:00
< td > < center > < img src = 'https://github.com/idrl-lab/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_10_elevation_40_adv_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 16:52:17 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/distance_10_elevation_50_adv_pred.gif?raw=true' / > < / center > < / td >
2021-09-12 16:45:31 +08:00
< / tr >
2021-09-12 16:54:51 +08:00
< / table >
2021-12-09 21:44:20 +08:00
### Multi-view Attack: different distance, elevation and azimuth
< table >
< tr >
< td > Original< / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_5_elevation_10_57_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_5_elevation_30_66_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_10_elevation_0_135_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_10_elevation_20_177_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_15_elevation_20_330_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_15_elevation_50_327_ori.png?raw=true' width = "100" / > < / center > < / td >
< / tr >
< tr >
< td > FCA< / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_5_elevation_10_57_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_5_elevation_30_66_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_10_elevation_0_135_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_10_elevation_20_177_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_15_elevation_20_330_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_15_elevation_50_327_adv.png?raw=true' width = "100" / > < / center > < / td >
< / tr >
< / table >
2021-12-09 21:10:05 +08:00
### Partial occlusion
2021-09-12 17:46:10 +08:00
2021-09-12 17:39:58 +08:00
< table >
< tr >
2021-12-09 21:10:05 +08:00
< td > Original< / td >
2021-09-12 19:29:55 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_6_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_42_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_54_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_126_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_10_330_ori.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_20_78_ori.png?raw=true' width = "100" / > < / center > < / td >
2021-09-12 17:39:58 +08:00
< / tr >
< tr >
2021-12-09 21:10:05 +08:00
< td > FCA< / td >
2021-09-12 19:29:55 +08:00
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_6_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_42_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_54_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_0_126_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_10_330_adv.png?raw=true' width = "100" / > < / center > < / td >
< td > < center > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/camera_distance_1.5_elevation_20_78_adv.png?raw=true' width = "100" / > < / center > < / td >
2021-09-12 17:39:58 +08:00
< / tr >
< / table >
2021-09-12 16:33:38 +08:00
### Ablation study
#### Different combination of loss terms
2021-09-12 16:39:39 +08:00
< img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/abaltion_study_loss.png?raw=true' / >
2021-09-12 16:40:56 +08:00
2021-09-13 09:35:21 +08:00
As we can see from the Figure, different loss terms plays different roles in attacking. For example, the camouflaged car generated by `obj+smooth (we omit the smooth loss, and denotes as obj)` can hidden the vehicle successfully, while the camouflaged car generated by `iou` can successfully suppress the detecting bounding box of the car region, and finally the camouflaged car generated by `cls` successfully make the detector to misclassify the car to anther category.
2021-09-12 18:50:32 +08:00
#### Different initialization ways
2021-09-12 19:03:28 +08:00
< table >
< tr >
2021-09-12 19:11:46 +08:00
< td > original < / td >
< td > basic initialization< / td >
< td > random initialization< / td >
< td > zero initialization< / td >
2021-09-12 19:22:32 +08:00
< / tr >
2021-09-12 19:11:46 +08:00
< tr >
2021-09-12 19:27:33 +08:00
< td > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/data13311_ori.png?raw=true' width = "200" / > < / td >
< td > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/data13311_adv_basic.png?raw=true' width = "200" / > < / td >
< td > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/data13311_adv_random.png?raw=true' width = "200" / > < / td >
< td > < img src = 'https://github.com/winterwindwang/Full-coverage-camouflage-adversarial-attack/blob/gh-pages/assets/data13311_adv_zero.png?raw=true' width = "200" / > < / td >
2021-09-12 19:03:28 +08:00
< / tr >
< / table >
2021-12-09 21:10:05 +08:00
## Cases of Phyical Attack
2021-12-09 21:22:25 +08:00
2022-03-16 14:21:30 +08:00
### Case in the simulator environment
2021-12-09 21:54:50 +08:00
2022-03-16 14:57:25 +08:00
< iframe src = "//player.bilibili.com/player.html?aid=937368019&bvid=BV1dT4y1U75b&cid=550826852&page=1" scrolling = "no" border = "0" frameborder = "no" framespacing = "0" allowfullscreen = "true" > < / iframe >
2022-03-16 14:21:30 +08:00
### Case in the real world
2022-03-16 15:01:13 +08:00
< iframe src = "//player.bilibili.com/player.html?aid=852356546&bvid=BV1RL4y1T723&cid=550828041&page=1" scrolling = "no" border = "0" frameborder = "no" framespacing = "0" allowfullscreen = "true" > < / iframe >