java opencv磨皮算法

编程入门 行业动态 更新时间:2024-10-16 22:14:57

java opencv磨皮<a href=https://www.elefans.com/category/jswz/34/1770096.html style=算法"/>

java opencv磨皮算法

参考一个大神的美肤公式:

Dest =(Src * (100 - Opacity) + (Src + 2 * GuassBlur(EPFFilter(Src) - Src + 128) - 256) * Opacity) /100

OpenCV3实现算法如下:

```python

# -*- coding: utf-8 -*-

'''

美肤-磨皮算法

Dest =(Src * (100 - Opacity) + (Src + 2 * GuassBlur(EPFFilter(Src) - Src + 128) - 256) * Opacity) /100 ;

'''

import cv2

import numpy as np

def beauty_face(img):

dst = np.zeros_like(img)

#int value1 = 3, value2 = 1; 磨皮程度与细节程度的确定

v1 = 3

v2 = 1

dx = v1 * 5 # 双边滤波参数之一

fc = v1 * 12.5 # 双边滤波参数之一

p = 0.1

temp4 = np.zeros_like(img)

temp1 = cv2.bilateralFilter(img,dx,fc,fc)

temp2 = cv2.subtract(temp1,img);

temp2 = cv2.add(temp2,(10,10,10,128))

temp3 = cv2.GaussianBlur(temp2,(2*v2 - 1,2*v2-1),0)

temp4 = cv2.add(img,temp3)

dst = cv2.addWeighted(img,p,temp4,1-p,0.0)

dst = cv2.add(dst,(10, 10, 10,255))

return dst

img = cv2.imread('../datas/s3.png')

dst = beauty_face(img)

cv2.imshow("SRC",img)

cv2.imshow("DST",dst)

cv2.waitKey()

cv2.destroyAllWindows()

运行结果:

更多推荐

java opencv磨皮算法

本文发布于:2023-06-20 04:11:11,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/795896.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:算法   java   opencv

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!