亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

python 實現(xiàn)圖像快速替換某種顏色

瀏覽:14日期:2022-07-22 18:47:09

最近的對圖像數(shù)據(jù)進(jìn)行處理的時候需要將圖像中的某個顏色替換為另一個顏色,但是網(wǎng)絡(luò)上找到的方法都是通過對圖像的遍歷進(jìn)行替換,實在是太費(fèi)時了!剛開始使用時覺得CPU很快了,一張圖片應(yīng)該用不了多久,但是實際使用中耗時確實難以接受的!于是自己寫了一個替換程序加快速度,比遍歷快很多,但我覺得不是最快的,應(yīng)該有通過矩陣索引更快的處理方式,只是我自己暫時并不知道該如何實現(xiàn),如果以后能夠?qū)崿F(xiàn)會進(jìn)行更新,暫時先寫下自己暫時覺得可用的代碼。

一、通過遍歷替換

將圖像中某個顏色替換為另一個顏色一般的做法是遍歷整個圖像,逐一替換,如下:

def replace_color_tran(img, src_clr, dst_clr):’’’ 通過遍歷顏色替換程序@paramimg:圖像矩陣@paramsrc_clr:需要替換的顏色(r,g,b)@paramdst_clr:目標(biāo)顏色(r,g,b)@return替換后的圖像矩陣’’’img_arr = np.asarray(img, dtype=np.double)dst_arr = img_arr.copy()for i in range(img_arr.shape[1]):for j in range(img_arr.shape[0]):if (img_arr[j][i] == src_clr)[0] == True:dst_arr[j][i] = dst_clrreturn np.asarray(dst_arr, dtype=np.uint8)

二、通過矩陣操作加快替換

但是這樣做,處理速度是很慢的即便是現(xiàn)在CPU很快的情況下。我自己通過numpy矩陣操作將速度提升了一點,具體做法如下:

將圖像的三個通道拆分開來為R,G,B三個通道

將三個通道的數(shù)據(jù)值進(jìn)行簡單的編碼,合并為單通道矩陣;

將需要替換的顏色進(jìn)行同2的編碼,利用改編碼在2中得到的矩陣中得到對應(yīng)顏色的索引;

利用3中得到的索引將R,G,B三個通道中的對應(yīng)顏色值替換為目標(biāo)值;

將得到的三個通道合并為一個圖像數(shù)據(jù)。

具體實現(xiàn)如下:

def replace_color(img, src_clr, dst_clr):’’’ 通過矩陣操作顏色替換程序@paramimg:圖像矩陣@paramsrc_clr:需要替換的顏色(r,g,b)@paramdst_clr:目標(biāo)顏色(r,g,b)@return替換后的圖像矩陣’’’ img_arr = np.asarray(img, dtype=np.double) r_img = img_arr[:,:,0].copy() g_img = img_arr[:,:,1].copy() b_img = img_arr[:,:,2].copy() img = r_img * 256 * 256 + g_img * 256 + b_img src_color = src_clr[0] * 256 * 256 + src_clr[1] * 256 + src_clr[2] #編碼 r_img[img == src_color] = dst_clr[0] g_img[img == src_color] = dst_clr[1] b_img[img == src_color] = dst_clr[2] dst_img = np.array([r_img, g_img, b_img], dtype=np.uint8) dst_img = dst_img.transpose(1,2,0) return dst_img

三、結(jié)果對比

先看下具體的實現(xiàn)結(jié)果,全部測試程序文末給出,(上面的圖片是原圖,下面是替換后的圖片)。

python 實現(xiàn)圖像快速替換某種顏色

python 實現(xiàn)圖像快速替換某種顏色

python 實現(xiàn)圖像快速替換某種顏色

四、程序解釋

通過如下方式編碼的原因是r,g,b三原色的數(shù)值本身是順序相關(guān)的,為了保證最后索引的一致與準(zhǔn)確性,采用將不同數(shù)值錯位開。這里的magic number采用256是因為三原色的數(shù)值的范圍是[0,255],這樣相乘可以保證數(shù)據(jù)在二進(jìn)制上的完全相互交錯而保證該編碼是絕對正確的,當(dāng)然也可以采用其他形式的編碼或者數(shù)值選擇其他數(shù)值,我這樣選擇是為了保險起見而已。

img = r_img * 256 * 256 + g_img * 256 + b_img src_color = src_clr[0] * 256 * 256 + src_clr[1] * 256 + src_clr[2] #編碼

五、完整的測試程序

完整的程序:

from PIL import Imageimport osimport numpy as npimport timedef replace_color(img, src_clr, dst_clr):’’’ 通過矩陣操作顏色替換程序@paramimg:圖像矩陣@paramsrc_clr:需要替換的顏色(r,g,b)@paramdst_clr:目標(biāo)顏色(r,g,b)@return替換后的圖像矩陣’’’ img_arr = np.asarray(img, dtype=np.double) #分離通道 r_img = img_arr[:,:,0].copy() g_img = img_arr[:,:,1].copy() b_img = img_arr[:,:,2].copy()#編碼 img = r_img * 256 * 256 + g_img * 256 + b_img src_color = src_clr[0] * 256 * 256 + src_clr[1] * 256 + src_clr[2] #索引并替換顏色 r_img[img == src_color] = dst_clr[0] g_img[img == src_color] = dst_clr[1] b_img[img == src_color] = dst_clr[2] #合并通道 dst_img = np.array([r_img, g_img, b_img], dtype=np.uint8) #將數(shù)據(jù)轉(zhuǎn)換為圖像數(shù)據(jù)(h,w,c) dst_img = dst_img.transpose(1,2,0) return dst_imgdef replace_color_tran(img, src_clr, dst_clr):’’’ 通過遍歷顏色替換程序@paramimg:圖像矩陣@paramsrc_clr:需要替換的顏色(r,g,b)@paramdst_clr:目標(biāo)顏色(r,g,b)@return替換后的圖像矩陣’’’img_arr = np.asarray(img, dtype=np.double)dst_arr = img_arr.copy()for i in range(img_arr.shape[1]):for j in range(img_arr.shape[0]):if (img_arr[j][i] == src_clr)[0] == True:dst_arr[j][i] = dst_clrreturn np.asarray(dst_arr, dtype=np.uint8)img = ’1.jpg’img = Image.open(img).convert(’RGB’)res_img = img.copy()count = 20matrix_time = 0trans_time = 0for i in range(count):print(i)start = time.time()dst_img = replace_color(img, (8,10,51), (255,0,0))end = time.time()matrix_time += (end - start)start = time.time()dst_img = replace_color_tran(img, (8,10,51), (255,0,0))end = time.time()trans_time += (end - start)res_img = dst_imgres_img = Image.fromarray(res_img)res_img.save(’2.jpg’)print(’矩陣操作花費(fèi)時間:’, matrix_time / count )print(’遍歷操作花費(fèi)時間:’, trans_time / count )

以上這篇python 實現(xiàn)圖像快速替換某種顏色就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 久久午夜激情 | 久久se精品一区精品二区 | 久久国产主播 | 久操视频网站 | 91丝瓜视频最新版 | 中文字幕第98页小明免费 | 老司机观看精品一区二区 | 国产激情视频在线 | 欧美a级黄 | 精品一精品国产一级毛片 | 国产成在线观看免费视频成本人 | 中文激情 | 九九免费精品视频 | 亚洲精品国产第一区二区图片 | 精品五夜婷香蕉国产线看观看 | 成人黄页网站免费观看大全 | 午夜精品成人毛片 | 超级碰碰碰碰97久久久久 | 一级成人生活片免费看 | 欧美日韩中文亚洲v在线综合 | 日本精品一区二区三本中文 | a级免费观看| 国产精品v一区二区三区 | 中文字幕久久乱码一区二区 | 精品欧美一区二区在线观看欧美熟 | 永久黄色免费网站 | 国产拍拍视频一二三四区 | 国产女人综合久久精品视 | 亚洲精品综合 | 国产福利在线观看永久免费 | 国产午夜精品一区二区三区不卡 | 嫩草在线视频www免费观看 | 欧美亚洲综合另类在线观看 | 久久人| 亚洲狠狠成人综合网 | 日本国产免费一区不卡在线 | 亚洲自偷自偷精品 | 综合久久久久综合体桃花网 | 国产高清视频在线免费观看 | 国产精品日本一区二区不卡视频 | 国产精品合集一区二区三区 |