利用OpenCV和Python實(shí)現(xiàn)查找圖片差異
使用OpenCV和Python查找圖片差異
flyfish
方法1 均方誤差的算法(Mean Squared Error , MSE)

下面的一些表達(dá)與《TensorFlow - 協(xié)方差矩陣》式子表達(dá)式一樣的

擬合 誤差平方和( sum of squared errors)
residual sum of squares (RSS), also known as the sum of squared residuals (SSR) or the sum of squared errors of prediction (SSE),
also known as 就我們所說的
RSS, SSR ,SSE表達(dá)的是一個(gè)意思

def mse(imageA, imageB):
# the 'Mean Squared Error' between the two images is the
# sum of the squared difference between the two images;
# NOTE: the two images must have the same dimension
err = np.sum((imageA.astype("float") - imageB.astype("float")) ** 2)
err /= float(imageA.shape[0] * imageA.shape[1])
# return the MSE, the lower the error, the more "similar"
# the two images are
return err
方法2 SSIM
structural similarity index measurement (SSIM) system
一種衡量兩幅圖像結(jié)構(gòu)相似度的新指標(biāo),其值越大越好,最大為1。
新建一個(gè)Python文件,命名為 image_diff.py
原文
Image Difference with OpenCV and Python
原理

根據(jù)參數(shù)讀取兩張圖片并轉(zhuǎn)換為灰度:
使用SSIM計(jì)算兩個(gè)圖像之間的差異,這種方法已經(jīng)在scikit-image 庫中實(shí)現(xiàn)
在兩個(gè)圖像之間的不同部分繪制矩形邊界框。
代碼如下 已編譯通過
from skimage.measure import compare_ssim
#~ import skimage as ssim
import argparse
import imutils
import cv2
# construct the argument parse and parse the arguments
ap = argparse.ArgumentParser()
ap.add_argument("-f", "--first", required=True,
help="first input image")
ap.add_argument("-s", "--second", required=True,
help="second")
args = vars(ap.parse_args())
# load the two input images
imageA = cv2.imread(args["first"])
imageB = cv2.imread(args["second"])
'''
imageA = cv2.imread("E:\\1.png")
imageB = cv2.imread("E:\\2.png")
'''
# convert the images to grayscale
grayA = cv2.cvtColor(imageA, cv2.COLOR_BGR2GRAY)
grayB = cv2.cvtColor(imageB, cv2.COLOR_BGR2GRAY)
# compute the Structural Similarity Index (SSIM) between the two
# images, ensuring that the difference image is returned
#structural similarity index measurement (SSIM) system一種衡量兩幅圖像結(jié)構(gòu)相似度的新指標(biāo),其值越大越好,最大為1。
(score, diff) = compare_ssim(grayA, grayB, full=True)
diff = (diff * 255).astype("uint8")
print("SSIM: {}".format(score))
# threshold the difference image, followed by finding contours to
# obtain the regions of the two input images that differ
thresh = cv2.threshold(diff, 0, 255,
cv2.THRESH_BINARY_INV | cv2.THRESH_OTSU)[1]
cnts = cv2.findContours(thresh.copy(), cv2.RETR_EXTERNAL,
cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if imutils.is_cv2() else cnts[1]
# loop over the contours
for c in cnts:
# compute the bounding box of the contour and then draw the
# bounding box on both input images to represent where the two
# images differ
(x, y, w, h) = cv2.boundingRect(c)
cv2.rectangle(imageA, (x, y), (x + w, y + h), (0, 0, 255), 2)
cv2.rectangle(imageB, (x, y), (x + w, y + h), (0, 0, 255), 2)
# show the output images
cv2.imshow("Original", imageA)
cv2.imshow("Modified", imageB)
cv2.imshow("Diff", diff)
cv2.imshow("Thresh", thresh)
cv2.waitKey(0)
使用方法
python image_diff.py –first original.png –second images/modified.png
如果不想使用參數(shù)將參數(shù)代碼部分直接變成
imageA = cv2.imread(“E:\1.png”) imageB = cv2.imread(“E:\2.png”)
以上這篇利用OpenCV和Python實(shí)現(xiàn)查找圖片差異就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 用openCV和Python 實(shí)現(xiàn)圖片對比,并標(biāo)識(shí)出不同點(diǎn)的方式
- Python+OpenCV 實(shí)現(xiàn)圖片無損旋轉(zhuǎn)90°且無黑邊
- python opencv圖片編碼為h264文件的實(shí)例
- Python實(shí)現(xiàn)圖片裁剪的兩種方式(Pillow和OpenCV)
- python opencv將表格圖片按照表格框線分割和識(shí)別
- Python Opencv提取圖片中某種顏色組成的圖形的方法
- python+openCV調(diào)用攝像頭拍攝和處理圖片的實(shí)現(xiàn)
- python opencv將圖片轉(zhuǎn)為灰度圖的方法示例
- 使用Python opencv實(shí)現(xiàn)視頻與圖片的相互轉(zhuǎn)換
- python通過opencv實(shí)現(xiàn)圖片裁剪原理解析
相關(guān)文章
Python初學(xué)時(shí)購物車程序練習(xí)實(shí)例(推薦)
下面小編就為大家?guī)硪黄狿ython初學(xué)時(shí)購物車程序練習(xí)實(shí)例(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
pygame實(shí)現(xiàn)俄羅斯方塊游戲(基礎(chǔ)篇3)
這篇文章主要介紹了pygame實(shí)現(xiàn)俄羅斯方塊游戲基礎(chǔ)的第3篇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
4個(gè)必學(xué)的Python自動(dòng)化技巧分享
在當(dāng)今快節(jié)奏的工作環(huán)境中,自動(dòng)化是提升效率的重要手段,本文將介紹4個(gè)必學(xué)的Python自動(dòng)化技巧,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-12-12
python基于pygame實(shí)現(xiàn)響應(yīng)游戲中事件的方法(附源碼)
這篇文章主要介紹了python基于pygame實(shí)現(xiàn)響應(yīng)游戲中事件的方法,實(shí)例分析了Python基于pygame針對鍵盤及鼠標(biāo)事件的響應(yīng)方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
tensorflow之變量初始化(tf.Variable)使用詳解
今天小編就為大家分享一篇tensorflow之變量初始化(tf.Variable)使用詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02
OpenCV圖像縮放resize各種插值方式的比較實(shí)現(xiàn)
OpenCV提供了resize函數(shù)來改變圖像的大小,本文主要介紹了OpenCV圖像縮放resize各種插值方式的比較實(shí)現(xiàn),分享給大家,感興趣的可以了解一下2021-06-06

