欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實現(xiàn)對比兩張圖片并標(biāo)記差異

 更新時間:2025年04月28日 09:17:40   作者:大霸王龍  
這篇文章主要為大家詳細(xì)介紹了使用Python對比兩張CAD圖并標(biāo)記差異的解決方案,文中的示例代碼簡潔易懂,具有一定的借鑒價值,有需要的小伙伴可以參考一下

以下是使用Python對比兩張CAD圖并標(biāo)記差異的解決方案,結(jié)合圖像處理和CAD結(jié)構(gòu)分析:

一、環(huán)境準(zhǔn)備與庫選擇

圖像處理庫:使用OpenCV進(jìn)行圖像差異檢測、顏色空間轉(zhuǎn)換和輪廓分析。

CAD解析庫:若為DXF格式,使用ezdxf解析實體信息(如塊、線條、圓等)。

幾何計算庫:scikit-image用于結(jié)構(gòu)相似性(SSIM)和仿射變換匹配。

import cv2
import ezdxf
from skimage.metrics import structural_similarity

二、關(guān)鍵步驟實現(xiàn)

1. 加載與預(yù)處理

圖像格式:使用OpenCV讀取圖片并轉(zhuǎn)換為灰度圖,進(jìn)行高斯模糊去噪。

left_img = cv2.imread("left.png")
right_img = cv2.imread("right.png")
gray_left = cv2.cvtColor(left_img, cv2.COLOR_BGR2GRAY)
gray_right = cv2.cvtColor(right_img, cv2.COLOR_BGR2GRAY)

DXF格式:通過ezdxf提取實體坐標(biāo)和屬性。

doc_left = ezdxf.readfile("left.dxf")
doc_right = ezdxf.readfile("right.dxf")

2. 紅框區(qū)域檢測

顏色閾值法:在HSV空間識別紅色區(qū)域,提取紅框坐標(biāo)。

hsv = cv2.cvtColor(right_img, cv2.COLOR_BGR2HSV)
lower_red = np.array([0, 50, 50])
upper_red = np.array([10, 255, 255])
mask = cv2.inRange(hsv, lower_red, upper_red)
contours, _ = cv2.findContours(mask, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

3. 差異檢測

圖像差異法:通過像素對比標(biāo)記新增部件。

diff = cv2.absdiff(gray_left, gray_right)
_, thresh = cv2.threshold(diff, 30, 255, cv2.THRESH_BINARY)

實體對比法(DXF):遍歷右圖實體,檢查是否存在于左圖。

right_entities = {entity.dxf.handle for entity in doc_right.modelspace()}
left_entities = {entity.dxf.handle for entity in doc_left.modelspace()}
new_entities = right_entities - left_entities

4. 旋轉(zhuǎn)匹配檢測

仿射變換匹配:對左圖零件進(jìn)行旋轉(zhuǎn),與右圖紅框區(qū)域計算相似度。

(height, width) = right_roi.shape[:2]
center = (width // 2, height // 2)
rotation_matrix = cv2.getRotationMatrix2D(center, angle=90, scale=1)
rotated_left = cv2.warpAffine(left_roi, rotation_matrix, (width, height))
ssim_score = structural_similarity(rotated_left, right_roi)
if ssim_score > 0.8:  # 閾值可調(diào)整
    cv2.rectangle(right_img, (x, y), (x+w, y+h), (0, 255, 0), 2)  # 標(biāo)記為旋轉(zhuǎn)后的零件

5. 結(jié)果標(biāo)記

在右圖中用綠色框標(biāo)記旋轉(zhuǎn)后的零件,用紅色框標(biāo)記完全新增的零件。

for (x, y, w, h) in new_contours:
    cv2.rectangle(right_img, (x, y), (x+w, y+h), (0, 0, 255), 2)

三、優(yōu)化與注意事項

閾值調(diào)整:根據(jù)實際圖像質(zhì)量調(diào)整SSIM相似度閾值(如0.7-0.9)。

多角度旋轉(zhuǎn)匹配:若旋轉(zhuǎn)角度未知,可遍歷0°-360°以尋找最大匹配值。

矢量數(shù)據(jù)優(yōu)先:若為DXF文件,直接對比實體屬性更高效。

示例輸出效果

紅色框:右圖新增的獨立零部件。

綠色框:左圖零件經(jīng)旋轉(zhuǎn)后存在于右圖的區(qū)域。

通過結(jié)合圖像差異和幾何變換匹配,可精準(zhǔn)識別新增與變換的零件。若需完整代碼或參數(shù)調(diào)優(yōu)細(xì)節(jié),可進(jìn)一步提供CAD樣本文件。

四、方法補充

1.基于openCV和python的skimage查找并標(biāo)記兩張圖片的不同

代碼實現(xiàn)

導(dǎo)入圖像處理庫

from skimage.metrics import structural_similarity as compare_ssim
import imutils
import cv2
import numpy as np

讀取圖片

image = "C:/Users/ts/Desktop/img/screenshot.png"
imageCompare = "C:/Users/ts/Desktop/img/screenshot1.png"
image= cv2.imdecode(np.fromfile(image, dtype=np.uint8), -1)
image_compare= cv2.imdecode(np.fromfile(image_compare, dtype=np.uint8), -1)

調(diào)整對比的兩張圖片尺寸一樣

h1, w1,c1 = image.shape
h2, w2,c2= imageCompare.shape
image_compare = cv2.resize(image_compare ,dsize=(w1,h1))

圖片轉(zhuǎn)灰度圖

gray_image= cv2.cvtColor(image,cv2.COLOR_BGR2GRAY)
gray_image_ompare = cv2.cvtColor(image_compare ,cv2.COLOR_BGR2GRAY)

使用structural_similarity對比獲取圖像相似度和不同

(score,diff) = compare_ssim(gray_image,gray_image_ompare ,full = True)
diff = (diff *255).astype("uint8")
retval,thresh = cv2.threshold(diff,200,255,cv2.THRESH_BINARY_INV)
 #參數(shù)thresh:閾值,用于確定像素是否應(yīng)該被視為前景或背景,調(diào)測下來200比較合適
cnts=cv2.findContours(thresh.copy(),cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[1] if imutils.is_cv3() else cnts[0]
loacation_list =[]
for c in cnts:
      (x,y,w,h) = cv2.boundingRect(c)  
      loacation_list.append((x,y,x+w,y+h))

圈出不同并標(biāo)記序號

for index,item in enumerate(loacation_list):
    #圈出不同    
    x,y,x1,y1 = item
    cv2.rectangle(imageA,(x,y),(x1,y1),(0,0,255),2)
    cv2.rectangle(imageB,(x,y),(x1,y1),(0,0,255),2)
    #不同處添加序號
    imageA = cv2.putText(imageA,str(index+1), (x,y+24), cv2.FONT_HERSHEY_DUPLEX, 1, (0, 0, 255))

2.使用OpenCV比較兩張圖片的相似度

實現(xiàn)代碼

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfFloat;
import org.opencv.core.MatOfInt;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

import java.util.Arrays;

public class ImageSimilarity {

   static {
        // 設(shè)置庫路徑
        System.setProperty("java.library.path", "D:\\anzhuang\\opencv\\opencv\\build\\java\\x64");
        // 加載 OpenCV 庫
        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
    }

    /**
     * 比較兩張圖片的相似度
     * @param imgPath1 圖片1的路徑
     * @param imgPath2 圖片2的路徑
     * @return 相似度值(范圍:0到1,1表示完全相同)
     */
    public static double compareImages(String imgPath1, String imgPath2) {
        // 加載圖片
        Mat img1 = Imgcodecs.imread(imgPath1);
        Mat img2 = Imgcodecs.imread(imgPath2);

        // 轉(zhuǎn)換為灰度圖
        Mat grayImg1 = new Mat();
        Mat grayImg2 = new Mat();
        Imgproc.cvtColor(img1, grayImg1, Imgproc.COLOR_BGR2GRAY);
        Imgproc.cvtColor(img2, grayImg2, Imgproc.COLOR_BGR2GRAY);

        // 計算直方圖
        Mat hist1 = new Mat();
        Mat hist2 = new Mat();
        MatOfInt histSize = new MatOfInt(256); // 直方圖大小
        MatOfFloat ranges = new MatOfFloat(0f, 256f); // 像素值范圍
        Imgproc.calcHist(Arrays.asList(grayImg1), new MatOfInt(0), new Mat(), hist1, histSize, ranges);
        Imgproc.calcHist(Arrays.asList(grayImg2), new MatOfInt(0), new Mat(), hist2, histSize, ranges);

        // 比較直方圖
        return Imgproc.compareHist(hist1, hist2, Imgproc.CV_COMP_CORREL);
    }

    public static void main(String[] args) {
        String imgPath1 = "path/to/image1.jpg";
        String imgPath2 = "path/to/image2.jpg";

        double similarity = compareImages(imgPath1, imgPath2);
        System.out.println("圖片相似度: " + similarity);
    }
}

到此這篇關(guān)于Python實現(xiàn)對比兩張圖片并標(biāo)記差異的文章就介紹到這了,更多相關(guān)Python圖片對比內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python設(shè)計模式結(jié)構(gòu)型代理模式

    Python設(shè)計模式結(jié)構(gòu)型代理模式

    這篇文章主要介紹了Python設(shè)計模式結(jié)構(gòu)型代理模式,代理模式即Proxy?Pattern,為其他對象提供一種代理以控制對這個對象的訪問,下文內(nèi)容詳細(xì)介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-02-02
  • 使用Python操作ArangoDB的方法步驟

    使用Python操作ArangoDB的方法步驟

    這篇文章主要介紹了使用Python操作ArangoDB的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • Python實現(xiàn)將通信達(dá).day文件讀取為DataFrame

    Python實現(xiàn)將通信達(dá).day文件讀取為DataFrame

    今天小編就為大家分享一篇Python實現(xiàn)將通信達(dá).day文件讀取為DataFrame,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • Python實現(xiàn)制作透明背景的電子印章

    Python實現(xiàn)制作透明背景的電子印章

    這篇文章主要為大家詳細(xì)介紹了如何利用Python語言實現(xiàn)制作透明背景的電子印章,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以嘗試一下
    2022-09-09
  • Python實現(xiàn)破解猜數(shù)游戲算法示例

    Python實現(xiàn)破解猜數(shù)游戲算法示例

    這篇文章主要介紹了Python實現(xiàn)破解猜數(shù)游戲算法,簡單描述了猜數(shù)游戲的原理,并結(jié)合具體實例形式分析了Python破解猜數(shù)游戲的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2017-09-09
  • Python 中拼音庫 PyPinyin 用法詳解

    Python 中拼音庫 PyPinyin 用法詳解

    很多朋友問小編怎樣把一批中文文件轉(zhuǎn)拼音命名呢?下面就讓我們來了解 Python 的一個庫 PyPinyin 吧,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • Python的網(wǎng)絡(luò)編程庫Gevent的安裝及使用技巧

    Python的網(wǎng)絡(luò)編程庫Gevent的安裝及使用技巧

    Gevent庫的奧義在于并發(fā)式的高性能網(wǎng)絡(luò)程序設(shè)計支持,這里我們將來講解Python的網(wǎng)絡(luò)編程庫Gevent的安裝及使用技巧,來看一下Gevent支持的多進(jìn)程程序編寫:
    2016-06-06
  • selenium 多窗口切換的實現(xiàn)(windows)

    selenium 多窗口切換的實現(xiàn)(windows)

    這篇文章主要介紹了selenium 多窗口切換的實現(xiàn)(windows),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • python圖的深度優(yōu)先和廣度優(yōu)先算法實例分析

    python圖的深度優(yōu)先和廣度優(yōu)先算法實例分析

    這篇文章主要介紹了python圖的深度優(yōu)先和廣度優(yōu)先算法,結(jié)合實例形式分析了圖的深度優(yōu)先算法與廣度優(yōu)先算法相關(guān)概念、原理、實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2019-10-10
  • Django中自定義admin Xadmin的實現(xiàn)代碼

    Django中自定義admin Xadmin的實現(xiàn)代碼

    這篇文章主要介紹了Django中自定義admin---Xadmin的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-08-08

最新評論