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

使用python和yolo方法實(shí)現(xiàn)yolo標(biāo)簽自動(dòng)標(biāo)注

 更新時(shí)間:2024年11月15日 11:23:38   作者:Jumbuck_10  
本文介紹了基于YOLOv10的自動(dòng)標(biāo)注方法,從初階的固定標(biāo)注到高階的基于YOLO檢測(cè)結(jié)果的自動(dòng)標(biāo)注,兩者相比,高階方法顯著提高了標(biāo)注的準(zhǔn)確性,并減少了人工操作的時(shí)間,</P><P>

yolo代碼自動(dòng)標(biāo)注

1.引言

在圖像處理與機(jī)器視覺(jué)領(lǐng)域,標(biāo)注數(shù)據(jù)的質(zhì)量和數(shù)量對(duì)于模型的訓(xùn)練至關(guān)重要。然而,手動(dòng)標(biāo)注大量圖像是一項(xiàng)繁瑣且耗時(shí)的工作。為了解決這個(gè)問(wèn)題,自動(dòng)標(biāo)注技術(shù)應(yīng)運(yùn)而生。本文將介紹如何使用YOLOv10結(jié)合傳統(tǒng)圖像處理算法進(jìn)行驗(yàn)證碼圖像的自動(dòng)標(biāo)注,從初步的自動(dòng)標(biāo)注到高階的基于檢測(cè)結(jié)果的自動(dòng)標(biāo)注。

2.初階“自動(dòng)標(biāo)注”,給每個(gè)圖像都生成一個(gè)固定的標(biāo)注文件,進(jìn)而在labglimg中對(duì)矩形框進(jìn)行微調(diào),減少標(biāo)注的工作量

在初步的自動(dòng)標(biāo)注階段,我們首先為每張圖像生成一個(gè)固定的標(biāo)注文件,這些文件的內(nèi)容通常是預(yù)設(shè)的,矩形框的位置并不精確,因此適合用作標(biāo)注的初步框架。

import os
# 圖像文件夾路徑
image_folder = 'D:'
# 標(biāo)注文件即txt文件路徑
txt_folder = 'D:'
# 基于上述兩個(gè)路徑檢索圖像和txt即yolo格式的標(biāo)注文件
image_files = [f.split('.')[0] for f in os.listdir(image_folder) if f.lower().endswith(('jpg', 'jpeg', 'png', 'bmp'))]
txt_files = [f.split('.')[0] for f in os.listdir(txt_folder) if f.lower().endswith('txt')]
# 遍歷圖像文件名
for img_name in image_files:
    # 如果某圖像沒(méi)有對(duì)應(yīng)的標(biāo)簽文件即txt文件
    if img_name not in txt_files:
        # 寫入txt文件
        txt_content = """0 0.808621 0.945652 0.072414 0.073913
                        0 0.250000 0.604348 0.093103 0.078261
                        0 0.660345 0.584783 0.086207 0.100000
                        0 0.613793 0.160870 0.117241 0.139130
                        0 0.293103 0.184783 0.103448 0.117391"""
        with open(os.path.join(txt_folder, img_name + '.txt'), 'w') as f:
            f.write(txt_content)
print("Process complete.")

由于我們對(duì)每張圖都生成的是一份固定的標(biāo)注txt文件,所以生成的文件一般都是這種的,矩形框 不在正確的位置上,雖然能夠降低一定的標(biāo)注工作量,但是我們還是想讓它更精準(zhǔn)一點(diǎn),那就需要使用訓(xùn)練好的模型了。

局限性:
矩形框位置不準(zhǔn)確,標(biāo)注結(jié)果可能與實(shí)際物體位置存在偏差。
無(wú)法自動(dòng)識(shí)別圖像中的所有物體,可能遺漏檢測(cè)。

3.高階自動(dòng)標(biāo)注,利用我們訓(xùn)練好的(但是沒(méi)有特別精準(zhǔn)的)yolo文件先對(duì)每張圖進(jìn)行檢測(cè),再手動(dòng)微調(diào)

為了提高自動(dòng)標(biāo)注的精度,我們可以使用YOLOv10模型對(duì)每張圖像進(jìn)行目標(biāo)檢測(cè),并根據(jù)檢測(cè)結(jié)果生成標(biāo)注文件。這種方式能夠提供較為準(zhǔn)確的初步標(biāo)注,用戶只需要對(duì)檢測(cè)框進(jìn)行微調(diào)即可,減少了大量的手動(dòng)標(biāo)注工作。

import os
from ultralytics import YOLOv10
# Folder paths
image_folder = 'D:'
txt_folder = 'D:'
# Load a pretrained YOLOv10n model
model = YOLOv10("\weights\\best.pt")
image_files = [f for f in os.listdir(image_folder) if f.lower().endswith(('jpg', 'jpeg', 'png', 'bmp'))]
# Perform object detection on each image file
for img_name in image_files:
    img_path = os.path.join(image_folder, img_name)
    # Perform prediction
    results = model.predict(img_path)
    # Extract detection results (assuming results[0] contains the detection)
    detections = results[0].boxes.xywh  # Get bounding box coordinates (xywh format)
    # If no .txt file exists, create a new one
    txt_path = os.path.join(txt_folder, img_name.split('.')[0] + '.txt')
    if not os.path.exists(txt_path):  # Check if .txt file already exists
        # Write detection results to the .txt file
        with open(txt_path, 'w') as f:
            for detection in detections:
                # Assuming you want the format: class_id x_center y_center width height (normalized)
                # Convert coordinates from pixels to normalized values by dividing by image width/height
                x_center, y_center, width, height = detection
                x_center /= results[0].orig_img.shape[1]  # Normalize by image width
                y_center /= results[0].orig_img.shape[0]  # Normalize by image height
                width /= results[0].orig_img.shape[1]  # Normalize by image width
                height /= results[0].orig_img.shape[0]  # Normalize by image height
                # Write to file (Assuming class id is 0 here, change based on your model)
                f.write(f"0 {x_center} {y_center} {width} {height}\n")
print("Process complete.")

代碼詳解:
1.加載YOLOv10模型:使用YOLOv10模型進(jìn)行物體檢測(cè)。通過(guò)model.predict()函數(shù)對(duì)每張圖像進(jìn)行檢測(cè)。
2.提取檢測(cè)結(jié)果:模型返回的結(jié)果中包含了檢測(cè)到的目標(biāo)的坐標(biāo)信息,采用boxes.xywh提取出目標(biāo)的位置。
3.坐標(biāo)歸一化:將檢測(cè)結(jié)果的坐標(biāo)從像素值轉(zhuǎn)換為相對(duì)圖像大小的比例(即歸一化值),以符合YOLO標(biāo)注格式。
4.生成標(biāo)注文件:根據(jù)模型檢測(cè)結(jié)果生成標(biāo)注文件,格式為class_id x_center y_center width height。

這種方式得到的數(shù)據(jù)一般是下圖這樣的,1.會(huì)有一些框不準(zhǔn),2.有一些框是重復(fù)的,3.有一些代碼沒(méi)有檢測(cè)到。此時(shí)我們只需要微調(diào)這三種情況的框即可,顯著降低了工作量。

4.總結(jié)

本文介紹了基于YOLOv10的自動(dòng)標(biāo)注方法,從初階的固定標(biāo)注到高階的基于YOLO檢測(cè)結(jié)果的自動(dòng)標(biāo)注。兩者相比,高階方法顯著提高了標(biāo)注的準(zhǔn)確性,并減少了人工操作的時(shí)間。

初階方法:快速生成標(biāo)注文件,適用于初步標(biāo)注,但需要人工微調(diào)和修正。
高階方法:通過(guò)YOLOv10檢測(cè)得到較為精準(zhǔn)的標(biāo)注結(jié)果,適合更高精度要求的任務(wù),但仍需要人工微調(diào)。
希望這些代碼能幫助大家提升標(biāo)注工作的效率和精度,降低人工標(biāo)注的成本。在未來(lái)的工作中,我們可以繼續(xù)優(yōu)化和擴(kuò)展該方法,進(jìn)一步提高自動(dòng)標(biāo)注的精度和適用范圍。

到此這篇關(guān)于使用python和yolo方法實(shí)現(xiàn)yolo標(biāo)簽自動(dòng)標(biāo)注的文章就介紹到這了,更多相關(guān)python yolo標(biāo)簽自動(dòng)標(biāo)注內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python正則表達(dá)式指南 推薦

    Python正則表達(dá)式指南 推薦

    本文介紹了Python對(duì)于正則表達(dá)式的支持,包括正則表達(dá)式基礎(chǔ)以及Python正則表達(dá)式標(biāo)準(zhǔn)庫(kù)的完整介紹及使用示例。本文的內(nèi)容不包括如何編寫高效的正則表達(dá)式、如何優(yōu)化正則表達(dá)式,這些主題請(qǐng)查看其他教程。
    2018-10-10
  • 中秋快到了利用 python 繪制中秋禮物

    中秋快到了利用 python 繪制中秋禮物

    眼看中秋又快到了,中秋回家,帶什么禮物更讓家人歡心?今天小編就利用python幫你帶個(gè)對(duì)象回家,感興趣的小伙伴趕快來(lái)看,要記得收藏起來(lái)以免迷路
    2021-09-09
  • pycharm通過(guò)ssh連接遠(yuǎn)程服務(wù)器教程

    pycharm通過(guò)ssh連接遠(yuǎn)程服務(wù)器教程

    今天小編就為大家分享一篇pycharm通過(guò)ssh連接遠(yuǎn)程服務(wù)器教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-02-02
  • Python 中的 typing 模塊常見(jiàn)用法

    Python 中的 typing 模塊常見(jiàn)用法

    Python的typing模塊提供類型提示功能,增強(qiáng)代碼可讀性和類型安全性,通過(guò)定義變量、參數(shù)、返回值的類型,可以幫助IDE和靜態(tài)分析工具提高代碼質(zhì)量,支持List、Dict、Tuple等類型定義,以及Optional、Union、Any等高級(jí)用法,還可以使用mypy等工具進(jìn)行類型檢查
    2024-09-09
  • python中ndarray數(shù)組的索引和切片的使用

    python中ndarray數(shù)組的索引和切片的使用

    本文主要介紹了python中ndarray數(shù)組的索引和切片的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Python使用logging實(shí)現(xiàn)多進(jìn)程安全的日志模塊

    Python使用logging實(shí)現(xiàn)多進(jìn)程安全的日志模塊

    這篇文章主要為大家詳細(xì)介紹了Python如何使用標(biāo)準(zhǔn)庫(kù)logging實(shí)現(xiàn)多進(jìn)程安全的日志模塊,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下
    2024-01-01
  • Matplotlib繪圖基礎(chǔ)之幾何圖形的繪制詳解

    Matplotlib繪圖基礎(chǔ)之幾何圖形的繪制詳解

    除了繪制各類分析圖形(比如柱狀圖,折線圖,餅圖等等)以外,matplotlib?也可以在畫布上任意繪制各類幾何圖形,下面小編就來(lái)和大家講講如何繪制常見(jiàn)的幾種幾何圖形吧
    2023-08-08
  • 用python實(shí)現(xiàn)一個(gè)簡(jiǎn)單的驗(yàn)證碼

    用python實(shí)現(xiàn)一個(gè)簡(jiǎn)單的驗(yàn)證碼

    這篇文章主要介紹了用python實(shí)現(xiàn)一個(gè)簡(jiǎn)單的驗(yàn)證碼的方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-12-12
  • python比較2個(gè)xml內(nèi)容的方法

    python比較2個(gè)xml內(nèi)容的方法

    這篇文章主要介紹了python比較2個(gè)xml內(nèi)容的方法,涉及Python操作XML文件的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • 30行Python代碼打造一款簡(jiǎn)單的人工語(yǔ)音對(duì)話

    30行Python代碼打造一款簡(jiǎn)單的人工語(yǔ)音對(duì)話

    使用gtts和speech_recognition實(shí)現(xiàn)簡(jiǎn)單的人工語(yǔ)音對(duì)話,通過(guò)將語(yǔ)音變成文本,然后文本變成語(yǔ)音,僅用30行代碼,超級(jí)簡(jiǎn)單,對(duì)Python人工語(yǔ)音對(duì)話的實(shí)現(xiàn)過(guò)程及完整代碼感興趣的朋友一起看看吧
    2021-05-05

最新評(píng)論