使用误差平方和算法(Sum of Squared Difference,简称SSD)进行模式匹配(Template Matching).
在这里我们使用误差平方和进行模式匹配。将imori_part.jpg
在imori.jpg
中匹配的图像使用红框框出来。
模式匹配,即寻找待匹配图像和全体图像中最相似的部分,用于物体检测任务。现在虽然使用卷积神经网络(CNN
)来检测物体,但是模式识别仍然是最基本的处理方法。
下面介绍具体算法。原图像记为,待匹配图像为:
- 对于图像:,
for ( j = 0, H-h) for ( i = 0, W-w)
在一次移动1像素的过程中,原图像I的一部分与待匹配图像计算相似度。 - S最大或最小的地方即为匹配的位置。
S的计算方法主要有 SSD
、SAD
、NCC
、ZNCC
等。对于不同的方法,我们需要选择出最大值或者最小值。
在这里我们使用误差平方和SSD
(Sum of Squared Difference)。SSD
计算像素值的差的平方和,S取误差平方和最小的地方。
顺便说一句,像模式匹配这样,从图像的左上角开始往右进行顺序查找的操作一般称作光栅扫描(Raster Scan)或者滑动窗口扫描。这样的术语在图像处理邻域经常出现。
可以使用cv2.rectangle ()
来画矩形。另外,imori_part.jpg
稍微改变了颜色。
python实现:
输入(imori.jpg):
template图像(imori_part.jpg):
输出: