一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python傳統圖像處理之皮膚區域檢測詳解

Python傳統圖像處理之皮膚區域檢測詳解

2022-03-11 00:30watersink Python

這篇文章主要介紹了在不同情景下對傳統圖像進行皮膚區域檢測,文章中的代碼具有一定的參考價值,感興趣的小伙伴可以跟隨小編一起來學習學習

1.RGB空間

膚色在RGB模型下的范圍基本滿足以下約束:

在均勻光照下應滿足以下判別式:

R>95 AND G>40 B>20 AND MAX(R,G,B)-MIN(R,G,B)>15 AND ABS(R-G)>15 AND R>G AND R>B

在側光拍攝環境下:

R>220 AND G>210 AND B>170 AND ABS(R-G)<=15 AND R>B AND G>B

代碼:

def skinMask_rgb(image):
  b, g, r = cv2.split(image)
  mask_uniformity = (r>95)*(g>40)*(b>20)* (np.max(image, axis=2) -np.min(image,axis=2)>15)* (abs(r-g)>15)*(r>g)*(r>b)
  mask_side = (r>220)*(g>210)*(b>170)*(abs(r-g)<=15)*(r>b)*(g>b)
  mask = mask_uniformity|mask_side
  skin = np.array(mask, np.uint8)*255
  ratio = np.sum(skin/255)/(image.shape[0]*image.shape[1])

  return skin, ratio

效果:

Python傳統圖像處理之皮膚區域檢測詳解Python傳統圖像處理之皮膚區域檢測詳解

 

2.Ycrcb空間

在RGB空間里人臉的膚色受亮度影響相當大,所以膚色點很難從非膚色點中分離出來,也就是說在此空間經過處理后,膚色點是離散的點,中間嵌有很多非膚色。如果把RGB轉為YCrCb空間的話,可以忽略Y(亮度)的影響,因為該空間受亮度影響很小,膚色會產生很好的類聚。這樣就把三維的空間降為二維的CrCb,膚色點會形成一定得形狀。

133≤Cr≤173

77≤Cb≤127

代碼:

def skinMask_YCrCb(image):
  YCrCb = cv2.cvtColor(image, cv2.COLOR_BGR2YCR_CB) #轉換至YCrCb空間
  (y,cr,cb) = cv2.split(YCrCb) #拆分出Y,Cr,Cb值
  skin = np.zeros(cr.shape, dtype = np.uint8)
  (x,y) = cr.shape
  
  cr_mask1 = cr >= 133
  cr_mask2 = cr <= 173
  cr_mask = cr_mask1 * cr_mask2

  cb_mask1 = cb >= 77
  cb_mask2 = cb <= 127
  cb_mask = cb_mask1 * cb_mask2
  mask = cr_mask * cb_mask
  skin[mask] = 255

  ratio = np.sum(skin/255)/(x*y)
  return skin, ratio

效果:

Python傳統圖像處理之皮膚區域檢測詳解Python傳統圖像處理之皮膚區域檢測詳解

 

3.Ycrcb空間+otsu

Y表示明亮度(Luminance或Luma),也就是灰階值。Cr反映了RGB輸入信號紅色部分與RGB信號亮度值之間的差異。而Cb反映的是RGB輸入信號藍色部分與RGB信號亮度值之間的差異。

將RGB圖像轉換到YCrCb顏色空間,提取Cr分量圖像。對Cr做自二值化閾值分割處理(Otsu法)。

代碼:

def skinMask_YCrCb_otsu(image):
  YCrCb = cv2.cvtColor(image, cv2.COLOR_BGR2YCR_CB) #轉換至YCrCb空間
  (y,cr,cb) = cv2.split(YCrCb) #拆分出Y,Cr,Cb值
  
  ret, skin = cv2.threshold(cr, 0, 255, cv2.THRESH_BINARY | cv2.THRESH_OTSU)

  ratio = np.sum(skin/255)/(image.shape[0]*image.shape[1])
  return skin, ratio

效果:

Python傳統圖像處理之皮膚區域檢測詳解Python傳統圖像處理之皮膚區域檢測詳解

 

4.HSV空間

7<H<20

28<S<256

50<V<256

代碼:

def skinMask_hsv(image):
  hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)
  h, s, v = cv2.split(hsv)

  mask = (h>7)*(h<20)*(s>28)*(v>50)
  skin = np.array(mask, np.uint8)*255
  ratio = np.sum(skin/255)/(image.shape[0]*image.shape[1])
  return skin, ratio

效果:

Python傳統圖像處理之皮膚區域檢測詳解Python傳統圖像處理之皮膚區域檢測詳解

 

5.opencv自帶膚色檢測類AdaptiveSkinDetector

已經從opencv 3以上版本中移除,opencv 2中函數。

 

6.基于橢圓模型

將皮膚信息映射到YCrCb空間,則在CrCb二維空間中這些皮膚像素點近似成一個橢圓分布。因此如果我們得到了一個CrCb的橢圓,下次來一個坐標(Cr, Cb)我們只需判斷它是否在橢圓內(包括邊界),如果是,則可以判斷其為皮膚,否則就是非皮膚像素點。

代碼:

def skinMask_ellipse(image):
  YCrCb = cv2.cvtColor(image, cv2.COLOR_BGR2YCR_CB) #轉換至YCrCb空間
  (y,cr,cb) = cv2.split(YCrCb) #拆分出Y,Cr,Cb值

  skinCrCbHist = np.zeros((256,256),np.uint8)
  skinCrCbHist = cv2.ellipse(skinCrCbHist, (113, 155), (23, 15), 43.0, 0.0, 360.0, (255, 255, 255), -1)
  cv2.imwrite("ww.jpg", skinCrCbHist)

  skin = cv2.remap(skinCrCbHist, cb.astype(np.float32), cr.astype(np.float32), interpolation=cv2.INTER_LINEAR)
  ratio = np.sum(skin/255)/(image.shape[0]*image.shape[1])
  return skin, ratio

效果:

橢圓模型

Python傳統圖像處理之皮膚區域檢測詳解

效果

Python傳統圖像處理之皮膚區域檢測詳解Python傳統圖像處理之皮膚區域檢測詳解

 

7.直方圖反向投影

反向投影可以用來做圖像分割,尋找感興趣區間??梢詫ふ胰魏蔚膔oi,這里將其用作尋找人體膚色。它會輸出與輸入圖像大小相同的圖像,每一個像素值代表了輸入圖像上對應點屬于目標對象的概率,簡言之,輸出圖像中像素值越高的點越可能代表想要查找的目標。直方圖投影經常與camshift(追蹤算法)算法一起使用。

操作步驟:

(1)截取若干張不同膚色的圖片,最好覆蓋常見的所有膚色(如下圖)

Python傳統圖像處理之皮膚區域檢測詳解

(2)對所有膚色的圖片一起做色彩直方圖(利用OpenCV中的calcHist函數)

(3)新建一個與待檢測圖片同尺寸的灰度圖片,找到待檢測圖片中每顆像素點的顏色在色彩直方圖中對應柵格的數值(即統計中出現的次數),并將該數值賦值予新建灰度圖片中與該檢測像素同位置的像素(利用OpenCV中的calcBackProject函數)。圖像中像素亮度越高,待檢測圖像該位置處是膚色的概率越大。

代碼:

def skinMask_hist_backproject(target, roi_image):
  #roi圖片,就想要找的的圖片
  hsv = cv2.cvtColor(roi_image,cv2.COLOR_BGR2HSV)

  #目標搜索圖片
  hsvt = cv2.cvtColor(target,cv2.COLOR_BGR2HSV)

  #計算目標直方圖
  roihist = cv2.calcHist([hsv],[0,1],None,[180,256],[0,180,0,256])
  #歸一化,參數為原圖像和輸出圖像,歸一化后值全部在2到255范圍
  cv2.normalize(roihist,roihist,0,255,cv2.NORM_MINMAX)
  dst = cv2.calcBackProject([hsvt],[0,1],roihist,[0,180,0,256],1)


  #卷積連接分散的點
  disc = cv2.getStructuringElement(cv2.MORPH_ELLIPSE,(5,5))
  dst = cv2.filter2D(dst,-1,disc)

  ret,skin = cv2.threshold(dst,50,255,0)

  ratio = np.sum(skin/255)/(target.shape[0]*target.shape[1])
return skin, ratio

效果: 

 Python傳統圖像處理之皮膚區域檢測詳解

以上就是Python傳統圖像處理之皮膚區域檢測詳解的詳細內容,更多關于Python 皮膚區域檢測的資料請關注服務器之家其它相關文章!

原文鏈接:https://blog.csdn.net/qq_14845119/article/details/121655002

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 我和寂寞孕妇的性事 | 亚洲精品乱码久久久久久蜜桃图片 | 动漫肉在线观看 | 久久久久久久久女黄9999 | 国产精品欧美在线观看 | 国精品午夜dy8888狼人 | 双性受合不垅腿攻np | 91色香sxmv最网页版新地址 | 白鹿扒开内裤露出尿孔 | 二次元美女挤奶漫画 | 羞羞私人影院可以直接免费观影吗 | 欧美日韩国产在线人成dvd | 欧美日韩高清一区 | 精品一区二区三区视频日产 | 水野朝阳厨房系列在线观看 | 91在线亚洲综合在线 | 99精品偷自拍 | 久久精品一区二区免费看 | 亚洲精品成人456在线播放 | 国产日韩欧美精品在线 | 99久久成人 | 好姑娘在线完整版视频 | 亚洲精品无码不卡 | 91gmail国产 | 思久久| 免费观看小视频 | 午夜理论电影在线观看亚洲 | 亚洲精品第二页 | 激情小视频网站 | 亚洲国产综合久久精品 | 免费一级日本c片完整版 | 久久88综合| 欧美日本一区视频免费 | 亚洲精品资源在线 | 秘书小说阿蛮 | 免费网站看v片在线香蕉 | www久久com| 精品亚洲一区二区三区在线播放 | 午夜一区二区福利视频在线 | 99精品热线在线观看免费视频 | 日韩一区二区三区四区区区 |