gpt4 book ai didi

Opencv检测不同时间拍摄的两张照片之间的变化

转载 作者:太空宇宙 更新时间:2023-11-03 21:03:59 25 4
gpt4 key购买 nike

我们有该商品的一张原始图片/照片。 (即雕塑)。

我们会不时地为该项目拍摄新照片。照片总是与元素成 90 度角。但是

  • 会有一些轻微的上下/左右移动是同一物体的不同长度(我们用线相机和在它前面移动的物体,所以不时的速度对象发生变化,因此最终图像将比原创)

灯光也会变化,所以颜色和闪电也不总是一样。元素上时不时会有泥土、不同的小 object 。

我很乐意听取您的建议和解决方案,以使用 opencv 检测和标记新图片上对象的不同部分。

我们尝试了 resemblejs,但它显示所有部分都因颜色、长度等差异而发生了变化。但是对象是一样的

谢谢

代码:

from skimage.measure import compare_ssim
import argparse
import imutils
import cv2
import numpy as np


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())

imageA = cv2.imread(args["first"])
imageB = cv2.imread(args["second"])

grayA = cv2.cvtColor(imageA, cv2.COLOR_BGR2GRAY)
grayB = cv2.cvtColor(imageB, cv2.COLOR_BGR2GRAY)


(score, diff) = compare_ssim(grayA, grayB, full=True)
diff = (diff * 55).astype("uint8")
print("SSIM: {}".format(score))

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]

for c in cnts:
(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)

cv2.imshow("Diff", diff)
cv2.waitKey(0)

编辑 1

Link测试图像

最佳答案

想到了几种方法。

  1. 计算帧之间的差异。 OpenCV 提供 absdiff因为这样做。从那里findContours得到的差异矩阵然后draw他们。

  2. This教程使用scikit-image图像差异

  3. 您还可以查看 meanStdDev来完成这个。计算两帧的标准差并检查是否超过某个阈值。

关于Opencv检测不同时间拍摄的两张照片之间的变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44785958/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com