Target before Shooting: Accurate Anomaly Detection and Localization under One Millisecond via Cascade Patch Retrieval
Hanxi Li, Jianfei Hu, Bo Li, Hao Chen, Yongbin Zheng, Chunhua Shen
Code Available — Be the first to reproduce this paper.
ReproduceCode
- github.com/flyinghu123/cprOfficialIn paperpytorch★ 116
Abstract
In this work, by re-examining the "matching" nature of Anomaly Detection (AD), we propose a new AD framework that simultaneously enjoys new records of AD accuracy and dramatically high running speed. In this framework, the anomaly detection problem is solved via a cascade patch retrieval procedure that retrieves the nearest neighbors for each test image patch in a coarse-to-fine fashion. Given a test sample, the top-K most similar training images are first selected based on a robust histogram matching process. Secondly, the nearest neighbor of each test patch is retrieved over the similar geometrical locations on those "global nearest neighbors", by using a carefully trained local metric. Finally, the anomaly score of each test image patch is calculated based on the distance to its "local nearest neighbor" and the "non-background" probability. The proposed method is termed "Cascade Patch Retrieval" (CPR) in this work. Different from the conventional patch-matching-based AD algorithms, CPR selects proper "targets" (reference images and locations) before "shooting" (patch-matching). On the well-acknowledged MVTec AD, BTAD and MVTec-3D AD datasets, the proposed algorithm consistently outperforms all the comparing SOTA methods by remarkable margins, measured by various AD metrics. Furthermore, CPR is extremely efficient. It runs at the speed of 113 FPS with the standard setting while its simplified version only requires less than 1 ms to process an image at the cost of a trivial accuracy drop. The code of CPR is available at https://github.com/flyinghu123/CPR.
Tasks
Benchmark Results
| Dataset | Model | Metric | Claimed | Verified | Status |
|---|---|---|---|---|---|
| BTAD | CPR | Detection AUROC | 94.8 | — | Unverified |
| MVTec 3D-AD (RGB) | CPR | Detection AUROC | 88.5 | — | Unverified |
| MVTec AD | CPR-fast | Detection AUROC | 99.7 | — | Unverified |
| MVTec AD | CPR-faster | Detection AUROC | 99.4 | — | Unverified |
| MVTec AD | CPR-faster(TensorRT) | FPS | 1,016 | — | Unverified |
| MVTec AD | CPR-fast(TensorRT) | FPS | 362 | — | Unverified |
| MVTec AD | CPR(TensorRT) | FPS | 130 | — | Unverified |
| MVTec AD | CPR | Detection AUROC | 99.7 | — | Unverified |