[ Scikit-image ] 利用 SSIM篩選相似度過高的圖像
之前有提到過利用 Hamming distance對兩張照片進行相似度的比對, "利用PhotoHash篩選相似度過高的圖像"。
最近發現另一個相似度的方法,這個方法叫做 SSIM(Structural Similarity Index),有興趣的可以維基一下。
好在 Scikit-image裡已經提供它的算法,參數的部份可以參考這裡。
from skimage.measure import compare_ssim import numpy as np import cv2 import os import glob def filter(member): img_list = glob.glob('./{0}/*.png'.format(member)) img_list.sort(key=lambda num: int(num.split('/')[-1].split('.')[0])) for img in img_list: img_path = img next_img = cv2.imread(img_path,0) if 'img_target' in locals(): s = compare_ssim(img_target, next_img) if s >= 0.8: if not os.path.isdir("./{0}/similar".format(member)): os.system("mkdir ./{0}/similar".format(member)) print("make dir ./{0}/similar".format(member)) os.system("mv {0} ./{1}/similar".format(img_path, member)) print("move {0} to ./{1}/similar".format(img_path, member)) continue img_target = next_img names = ["Nayeon", "Jeongyeon", "Momo", "Sana", "Jihyo", "Mina", "Dahyun", "Chaeyoung", "Tzuyu"] for member in names: filter(member) print('Done!!')辨識的結構跟上一章沒有差太多,一樣是按照順序比較,只有改變辨識的方法。
先利用 OpenCV讀取圖像並轉為 Grayscale,透過 compare_ssim方法計算相似度。
compare_ssim計算出來的值會在 -1~1之間,數字越大相似度越高。
data:image/s3,"s3://crabby-images/12099/120999641e065a9909da37040ac0657b62aaedc6" alt=""
data:image/s3,"s3://crabby-images/15430/15430ac39e7763fde0af116da0475c76c7ebc8de" alt=""
data:image/s3,"s3://crabby-images/5ab63/5ab63dc56a5f0dd10f3b7b89cd02b15e88e2abd6" alt=""
data:image/s3,"s3://crabby-images/46983/469838ad3356551f76c1c4d5f4919b8a6639b47e" alt=""
data:image/s3,"s3://crabby-images/dae0b/dae0bcd10a3a2128fb78dd0150b5653bc2f16e27" alt=""
data:image/s3,"s3://crabby-images/0cc49/0cc4967eaa077e1f65644fffd3be1ad10c96b1ae" alt=""
data:image/s3,"s3://crabby-images/b6364/b63647fdeb764b9a364dad1190189c1918207756" alt=""
data:image/s3,"s3://crabby-images/0a227/0a227f8420636b8f114b68fc8a1b7422a559dc5f" alt=""
data:image/s3,"s3://crabby-images/3863b/3863bd1a9f6ea86adf7ddd5e170963ce8f6d24d5" alt=""
data:image/s3,"s3://crabby-images/d1066/d1066d102fd3e8f6a3c8cc305750fac854a090d3" alt=""
data:image/s3,"s3://crabby-images/2144f/2144f5a52f0014f640037e828d33fc15f02a90f6" alt=""
data:image/s3,"s3://crabby-images/65940/65940a4d772089aa4cb048f0b9a6707b2dd4294b" alt=""
data:image/s3,"s3://crabby-images/fd55b/fd55b3369e21eec94d2a0010b2ded5672e1a7372" alt=""
data:image/s3,"s3://crabby-images/632ee/632eee5520330e38cedff7631746d752568037a6" alt=""
data:image/s3,"s3://crabby-images/572aa/572aa65e88c6a18562b4ae4734e2a7898700c447" alt=""
data:image/s3,"s3://crabby-images/55ebb/55ebb9f23f7edfec09364145554d032afbc5c6ea" alt=""
data:image/s3,"s3://crabby-images/d23de/d23de8c6b0ac71c8c6930ad9587c2ec76969ebc2" alt=""
data:image/s3,"s3://crabby-images/d746f/d746f363b5aa111a75ecfe54187fdc8846cb2230" alt=""
data:image/s3,"s3://crabby-images/91de9/91de95dc627310512b61e4567e2ee9dabb98d4f8" alt=""
data:image/s3,"s3://crabby-images/856b2/856b2e8953ba7cb5491962bdb62fe014464483ff" alt=""
data:image/s3,"s3://crabby-images/28bf8/28bf8882538b04ff6a610d89b6fa01a1f1fd0ae9" alt=""
data:image/s3,"s3://crabby-images/85ebe/85ebe91cf853466c05ee2708602044fb62d3ace5" alt=""
data:image/s3,"s3://crabby-images/c23db/c23dbe9fa85e230083e0dd89658e1707cf6fe2da" alt=""
data:image/s3,"s3://crabby-images/610db/610db89e98e41a5c04c14392a9306254132e4ea4" alt=""
data:image/s3,"s3://crabby-images/15589/15589c97020096e436001fafcd7da4338ce588c4" alt=""
data:image/s3,"s3://crabby-images/326af/326afba4460d3618eb45bb251bb20e3baa7df068" alt=""
data:image/s3,"s3://crabby-images/4173f/4173f12b44dd7a67b04a2c41961b393399c07fcc" alt=""
data:image/s3,"s3://crabby-images/59504/5950496c1432bf294b263b6ea8c92e150e09535f" alt=""
data:image/s3,"s3://crabby-images/39c91/39c916f7ac82a62a6c992a2394f039445f458004" alt=""
data:image/s3,"s3://crabby-images/d37b7/d37b70ad60f0c3da86e2e2c1e1c31978daa3f5fa" alt=""
盡量找了同一個 Frame開始連續十張,順便試了效果比較接近的相似值
其實兩種方式效果好像差不多,不過整體表現就要多嘗試了。
要比較全部的照片的話,只要稍微修改就可以了。
from skimage.measure import compare_ssim import numpy as np import cv2 import os import glob def filter(member): img_list = glob.glob('./{0}/*.png'.format(member)) while True: if img_list==[]: break img_target_path = img_list.pop() img_target = cv2.imread(img_target_path,0) for img_path in img_list: img = cv2.imread(img_path,0) s = compare_ssim(img_target, img) if s >= 0.8: if not os.path.isdir("./{0}/similar".format(member)): os.system("mkdir ./{0}/similar".format(member)) print("make dir ./{0}/similar".format(member)) os.system("mv {0} ./{1}/similar".format(img_path, member)) print("move {0} to ./{1}/similar".format(img_path, member)) img_list.remove(img_path) names = ["Nayeon", "Jeongyeon", "Momo", "Sana", "Jihyo", "Mina", "Dahyun", "Chaeyoung", "Tzuyu"] for member in names: filter(member) print('Done!!')
留言
張貼留言