PrincetonComputer SciencePIXL GroupPublications → [Barnes et al. 2011] Local Access
The PatchMatch Randomized Matching Algorithm for Image Manipulation

Communications of the ACM, November 2011

Connelly Barnes, Dan B Goldman,
Eli Shechtman, Adam Finkelstein
Abstract

This paper presents a new randomized algorithm for quickly finding approximate nearest neighbor matches between image patches. Our algorithm offers substantial performance improvements over the previous state of the art (20–100×), enabling its use in new interactive image editing tools, computer vision, and video applications. Previously, the cost of computing such matches for an entire image had eluded efforts to provide interactive performance. The key insight driving our algorithm is that the elements of our search domain—patches of image pixels—are correlated, and thus the search strategy takes advantage of these statistics. Our algorithm uses two principles: first, that good patch matches can be found via random sampling, and second, that natural coherence in the imagery allows us to propagate such matches quickly to surrounding areas. Our simple algorithm allows finding a single nearest neighbor match across translations only, whereas our general algorithm additionally allows matching of k-nearest neighbors, across all rotations and scales, and matching arbitrary descriptors. This one simple algorithm forms the basis for a variety of applications including image retargeting, completion, reshuffling, object detection, digital forgery detection, and video summarization.
Links
Citation

Connelly Barnes, Dan B Goldman, Eli Shechtman, and Adam Finkelstein.
"The PatchMatch Randomized Matching Algorithm for Image Manipulation."
Communications of the ACM 54(11):103-110, November 2011.

BibTeX

@article{Barnes:2011:TPR,
   author = "Connelly Barnes and Dan B Goldman and Eli Shechtman and Adam Finkelstein",
   title = "The {PatchMatch} Randomized Matching Algorithm for Image Manipulation",
   journal = "Communications of the ACM",
   year = "2011",
   month = nov,
   volume = "54",
   number = "11",
   pages = "103--110"
}