# Use 2D cross-correlation to find the location of a template in a noisy # image: from scipy import signal from scipy import misc face = misc.face(gray=True) - misc.face(gray=True).mean() template = np.copy(face[300:365, 670:750]) # right eye template -= template.mean() face = face + np.random.randn(*face.shape) * 50 # add noise corr = signal.correlate2d(face, template, boundary='symm', mode='same') y, x = np.unravel_index(np.argmax(corr), corr.shape) # find the match import matplotlib.pyplot as plt fig, (ax_orig, ax_template, ax_corr) = plt.subplots(3, 1, figsize=(6, 15)) ax_orig.imshow(face, cmap='gray') ax_orig.set_title('Original') ax_orig.set_axis_off() ax_template.imshow(template, cmap='gray') ax_template.set_title('Template') ax_template.set_axis_off() ax_corr.imshow(corr, cmap='gray') ax_corr.set_title('Cross-correlation') ax_corr.set_axis_off() ax_orig.plot(x, y, 'ro') fig.show()