用Python和OpenCV為對(duì)象檢測(cè)任務(wù)實(shí)現(xiàn)最流行、最高效的數(shù)據(jù)擴(kuò)充
數(shù)據(jù)擴(kuò)充是一種增加數(shù)據(jù)集多樣性的技術(shù),無(wú)需收集更多真實(shí)數(shù)據(jù),但仍有助于提高模型精度并防止模型過(guò)擬合。
在本文中,你將學(xué)習(xí)使用Python和OpenCV為對(duì)象檢測(cè)任務(wù)實(shí)現(xiàn)最流行、最高效的數(shù)據(jù)擴(kuò)充過(guò)程。
即將引入的一組數(shù)據(jù)擴(kuò)充方法包括:
1.隨機(jī)裁剪
2.Cutout
3.顏色抖動(dòng)
4.增加噪音
5.過(guò)濾
首先,在繼續(xù)之前,讓我們導(dǎo)入幾個(gè)庫(kù)并準(zhǔn)備一些必要的子例程。
import os
import cv2
import numpy as np
import random
def file_lines_to_list(path):
'''
### 在TXT文件里的行轉(zhuǎn)換為列表 ###
path: 文件路徑
'''
with open(path) as f:
content = f.readlines()
content = [(x.strip()).split() for x in content]
return content
def get_file_name(path):
'''
### 獲取Filepath的文件名 ###
path: 文件路徑
'''
basename = os.path.basename(path)
onlyname = os.path.splitext(basename)[0]
return onlyname
def write_anno_to_txt(boxes, filepath):
'''
### 給TXT文件寫(xiě)注釋 ###
boxes: format [[obj x1 y1 x2 y2],...]
filepath: 文件路徑
'''
txt_file = open(filepath, "w")
for box in boxes:
print(box[0], int(box[1]), int(box[2]), int(box[3]), int(box[4]), file=txt_file)
txt_file.close()
下面的圖片是在這篇文章中使用的示例圖片。

隨機(jī)裁剪隨機(jī)裁剪隨機(jī)選擇一個(gè)區(qū)域并進(jìn)行裁剪以生成新的數(shù)據(jù)樣本,裁剪后的區(qū)域應(yīng)具有與原始圖像相同的寬高比,以保持對(duì)象的形狀。

從上圖中,左側(cè)圖像表示具有邊界框(紅色)的原始圖像,通過(guò)裁剪橙色框內(nèi)的區(qū)域創(chuàng)建一個(gè)新樣本作為右側(cè)圖像。在新示例的注釋中,將刪除與左側(cè)圖像中的橙色框不重疊的所有對(duì)象,并細(xì)化位于橙色框邊界上的對(duì)象的坐標(biāo),使其適合新圖像示例。原始圖像的隨機(jī)裁剪輸出為新裁剪圖像及其注釋。


Cutout
Terrance DeVries和Graham W.Taylor在2017年的論文中介紹了Cutout,它是一種簡(jiǎn)單的正則化技術(shù),用于在訓(xùn)練過(guò)程中隨機(jī)屏蔽輸入的方塊區(qū)域,可用于提高卷積神經(jīng)網(wǎng)絡(luò)的魯棒性和整體性能。
這種方法不僅非常容易實(shí)現(xiàn),而且還表明它可以與現(xiàn)有形式的數(shù)據(jù)擴(kuò)充和其他正則化工具結(jié)合使用,以進(jìn)一步提高模型性能。
如本文所述,剪切用于提高圖像識(shí)別(分類)的準(zhǔn)確性,因此,如果我們將相同的方案部署到對(duì)象檢測(cè)數(shù)據(jù)集中,可能會(huì)導(dǎo)致丟失對(duì)象的問(wèn)題,尤其是小對(duì)象。
在下圖中,cutout區(qū)域(黑色區(qū)域)內(nèi)的大量小對(duì)象被移除,這不符合數(shù)據(jù)擴(kuò)充的精神。

為了使這種方式適用于對(duì)象檢測(cè),我們可以進(jìn)行簡(jiǎn)單的修改,而不是僅使用一個(gè)蒙版并將其放置在圖像中的隨機(jī)位置。當(dāng)我們隨機(jī)選擇一半數(shù)量的對(duì)象并將剪切應(yīng)用于這些對(duì)象區(qū)域時(shí),效果會(huì)更好。增強(qiáng)圖像如下圖中的右圖所示。

剪切輸出是新生成的圖像,我們不移除對(duì)象或更改圖像大小,則生成圖像的注釋與原始圖像相同。
def cutout(img, gt_boxes, amount=0.5):
'''
### Cutout ###
img: 圖像
gt_boxes: format [[obj x1 y1 x2 y2],...]
amount: 蒙版數(shù)量/對(duì)象數(shù)量
'''
out = img.copy()
ran_select = random.sample(gt_boxes, round(amount*len(gt_boxes)))
for box in ran_select:
x1 = int(box[1])
y1 = int(box[2])
x2 = int(box[3])
y2 = int(box[4])
mask_w = int((x2 - x1)*0.5)
mask_h(yuǎn) = int((y2 - y1)*0.5)
mask_x1 = random.randint(x1, x2 - mask_w)
mask_y1 = random.randint(y1, y2 - mask_h(yuǎn))
mask_x2 = mask_x1 + mask_w
mask_y2 = mask_y1 + mask_h(yuǎn)
cv2.rectangle(out, (mask_x1, mask_y1), (mask_x2, mask_y2), (0, 0, 0), thickness=-1)
return out
顏色抖動(dòng)
ColorJitter是另一種簡(jiǎn)單的圖像數(shù)據(jù)增強(qiáng),我們可以隨機(jī)改變圖像的亮度、對(duì)比度和飽和度。我相信這個(gè)技術(shù)很容易被大多數(shù)讀者理解。



增加噪聲在一般意義上,噪聲被認(rèn)為是圖像中的一個(gè)意外因素,然而,幾種類型的噪聲(例如高斯噪聲、椒鹽噪聲)可用于數(shù)據(jù)增強(qiáng),在深度學(xué)習(xí)中添加噪聲是一種非常簡(jiǎn)單和有益的數(shù)據(jù)增強(qiáng)方法。在下面的示例中,為了增強(qiáng)數(shù)據(jù),將高斯噪聲和椒鹽噪聲添加到原始圖像中。

對(duì)于那些無(wú)法識(shí)別高斯噪聲和椒鹽噪聲之間差異的人,高斯噪聲的值范圍為0到255,具體取決于配置,因此,在RGB圖像中,高斯噪聲像素可以是任何顏色。相比之下,椒鹽噪波像素只能有兩個(gè)值0或255,分別對(duì)應(yīng)于黑色(PEPER)或白色(salt)。


濾波本文介紹的最后一個(gè)數(shù)據(jù)擴(kuò)充過(guò)程是濾波。與添加噪聲類似,濾波也簡(jiǎn)單且易于實(shí)現(xiàn)。實(shí)現(xiàn)中使用的三種類型的濾波包括模糊(平均)、高斯和中值。


總結(jié)

在這篇文章中,向大家介紹了一個(gè)關(guān)于為對(duì)象檢測(cè)任務(wù)實(shí)現(xiàn)數(shù)據(jù)增強(qiáng)的教程。你們可以在這里找到完整實(shí)現(xiàn)。
發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
圖片新聞
-

落地?zé)o錫!京東首個(gè)物流機(jī)器人超級(jí)工廠來(lái)了
-

OpenAI發(fā)布的AI瀏覽器,市場(chǎng)為何反應(yīng)強(qiáng)烈?
-

馬云重返一線督戰(zhàn),阿里重啟創(chuàng)始人模式
-

機(jī)器人奧運(yùn)會(huì)戰(zhàn)報(bào):宇樹(shù)機(jī)器人摘下首金,天工Ultra搶走首位“百米飛人”
-

存儲(chǔ)圈掐架!江波龍起訴佰維,索賠121萬(wàn)
-

長(zhǎng)安汽車(chē)母公司突然更名:從“中國(guó)長(zhǎng)安”到“辰致科技”
-

豆包前負(fù)責(zé)人喬木出軌BP后續(xù):均被辭退
-

字節(jié)AI Lab負(fù)責(zé)人李航卸任后返聘,Seed進(jìn)入調(diào)整期
最新活動(dòng)更多
-
6月30日立即申請(qǐng)?jiān)囉?> 【免費(fèi)試用】旭之源工業(yè)電源一一機(jī)器人的穩(wěn)定“心臟“
-
精彩回顧立即查看>> 【限時(shí)免費(fèi)】物理場(chǎng)仿真助力生物醫(yī)學(xué)領(lǐng)域技術(shù)創(chuàng)新
-
精彩回顧立即查看>> 【直播】 智測(cè)未來(lái)·2026海克斯康春季產(chǎn)品創(chuàng)新日
-
精彩回顧立即查看>> 【線下論壇】新唐科技×芯唐南京 2026 年度研討會(huì)
-
精彩回顧立即查看>> OFweek 2026(第十五屆)中國(guó)機(jī)器人產(chǎn)業(yè)大會(huì)
-
精彩回顧立即查看>> 維科杯· OFweek 2025中國(guó)機(jī)器人行業(yè)年度評(píng)選
推薦專題
-
2 華為,重大突破!
- 1 人形機(jī)器人“第一股”來(lái)了!宇樹(shù)科技即將上會(huì)
- 2 全球股市陷AI獨(dú)大結(jié)構(gòu)性瘋狂
- 3 AI狂歡遇上油價(jià)破百,全球股市還能漲多久? | 產(chǎn)聯(lián)看全球
- 4 DeepSeek融資500億,梁文鋒難逃資本局
- 5 谷歌2026 I/O大會(huì)完整回顧:模型依然重要,但智能體正在接管一切
- 6 全球資本,重倉(cāng)中國(guó)機(jī)器人
- 7 Figure AI 交付突破350臺(tái),陪跑特斯拉會(huì)迎來(lái)iPhone 時(shí)刻嗎?
- 8 Anthropic發(fā)布2028年全球AI領(lǐng)導(dǎo)力的兩種情景報(bào)告
- 9 “國(guó)產(chǎn)GPU第一股”摩爾線程首季扭虧,但造血能力仍待考驗(yàn)
- 10 特斯拉宣布監(jiān)督版FSD登陸中國(guó)?
- 高級(jí)軟件工程師 廣東省/深圳市
- 自動(dòng)化高級(jí)工程師 廣東省/深圳市
- 光器件研發(fā)工程師 福建省/福州市
- 銷售總監(jiān)(光器件) 北京市/海淀區(qū)
- 激光器高級(jí)銷售經(jīng)理 上海市/虹口區(qū)
- 光器件物理工程師 北京市/海淀區(qū)
- 激光研發(fā)工程師 北京市/昌平區(qū)
- 技術(shù)專家 廣東省/江門(mén)市
- 封裝工程師 北京市/海淀區(qū)
- 結(jié)構(gòu)工程師 廣東省/深圳市


分享





