SOTAVerified

Target before Shooting: Accurate Anomaly Detection and Localization under One Millisecond via Cascade Patch Retrieval

2023-08-13Code Available1· sign in to hype

Hanxi Li, Jianfei Hu, Bo Li, Hao Chen, Yongbin Zheng, Chunhua Shen

Code Available — Be the first to reproduce this paper.

Reproduce

Code

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

DatasetModelMetricClaimedVerifiedStatus
BTADCPRDetection AUROC94.8Unverified
MVTec 3D-AD (RGB)CPRDetection AUROC88.5Unverified
MVTec ADCPR-fastDetection AUROC99.7Unverified
MVTec ADCPR-fasterDetection AUROC99.4Unverified
MVTec ADCPR-faster(TensorRT)FPS1,016Unverified
MVTec ADCPR-fast(TensorRT)FPS362Unverified
MVTec ADCPR(TensorRT)FPS130Unverified
MVTec ADCPRDetection AUROC99.7Unverified

Reproductions