OpenCV-Python实现人脸美白算法的实例


Posted in Python onJune 11, 2021

人脸美白原理

人脸美白原理说透了,就是一种图像的颜色空间处理,所以我们需要通过颜色空间进行设计。

不过,我们先来参考以下PS对于图像美白的处理步骤:

  • 首先,新建一个图层,将这个图层设置为白色
  • 接着,将白色图层与原本图像进行alpha通道的颜色混合,这样就可以使图像整体变白。

通过PS的操作,我们大致可以知道需要创建一个与原图同等大小维度的图像,然后全部赋值为白色,然后通过图像图像加权和将两个图像叠加即可。

不过,这里明显存在很多问题,在PS中,我们虽然创建了全白色的图层,但是我们可以剪裁或者使用画笔工具只让白色叠加倒人物身上。而程序中,我们这么做会导致整个图像偏白,效果非常不理想。

那么,我们就需要考虑一个新的思路来实现人脸美白效果。

根据论文“A Two-Stage Contrast Enhancement Algorithm for Digital Images”,采用映射表,使原图在色阶上有所增强,并在图像两端亮度相对减弱,中间增强,则会产生不错的美白效果,又能使图像白的更自然。

这里,我们提供一个美白映射表Color_list:

Color_list = [
	1, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 31, 33, 35, 37, 39,
	41, 43, 44, 46, 48, 50, 52, 53, 55, 57, 59, 60, 62, 64, 66, 67, 69, 71, 73, 74,
	76, 78, 79, 81, 83, 84, 86, 87, 89, 91, 92, 94, 95, 97, 99, 100, 102, 103, 105,
	106, 108, 109, 111, 112, 114, 115, 117, 118, 120, 121, 123, 124, 126, 127, 128,
	130, 131, 133, 134, 135, 137, 138, 139, 141, 142, 143, 145, 146, 147, 149, 150,
	151, 153, 154, 155, 156, 158, 159, 160, 161, 162, 164, 165, 166, 167, 168, 170,
	171, 172, 173, 174, 175, 176, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187,
	188, 189, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203,
	204, 205, 205, 206, 207, 208, 209, 210, 211, 211, 212, 213, 214, 215, 215, 216,
	217, 218, 219, 219, 220, 221, 222, 222, 223, 224, 224, 225, 226, 226, 227, 228,
	228, 229, 230, 230, 231, 232, 232, 233, 233, 234, 235, 235, 236, 236, 237, 237,
	238, 238, 239, 239, 240, 240, 241, 241, 242, 242, 243, 243, 244, 244, 244, 245,
	245, 246, 246, 246, 247, 247, 248, 248, 248, 249, 249, 249, 250, 250, 250, 250,
	251, 251, 251, 251, 252, 252, 252, 252, 253, 253, 253, 253, 253, 254, 254, 254,
	254, 254, 254, 254, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
	255, 255, 255, 256]

实现人脸美白

既然人脸美白的原理,以及美白的颜色映射表都给到了你。下面,我们就可以实现人脸美白效果,具体代码如下所示:

def face_whitening(fileName):
    img = cv2.imread(fileName)
    img = cv2.bilateralFilter(img, 19, 75, 75)
    height, width, n = img.shape
    img2 = img.copy()
    for i in range(height):
        for j in range(width):
            b = img2[i, j, 0]
            g = img2[i, j, 1]
            r = img2[i, j, 2]
            img2[i, j, 0] = Color_list[b]
            img2[i, j, 1] = Color_list[g]
            img2[i, j, 2] = Color_list[r]
    cv2.imwrite("59_1.jpg",img2)

    image = Image.open("59_1.jpg")
    # 锐度调节
    enh_img = ImageEnhance.Sharpness(image)
    image_sharped = enh_img.enhance(1.2)
    # 颜色均衡调节
    con_img = ImageEnhance.Contrast(image_sharped)
    image_con = con_img.enhance(1.2)
    image_con.save("59_2.jpg")

    img1 = cv2.imread("58.jpg")
    img2 = cv2.imread("59_2.jpg")
    cv2.imshow("1", img1)
    cv2.imshow("2", img2)
    cv2.waitKey()
    cv2.destroyAllWindows()


if __name__ == "__main__":
    face_whitening("58.jpg")

运行之后,效果如下:

OpenCV-Python实现人脸美白算法的实例

到此这篇关于OpenCV-Python实现人脸美白算法的实例的文章就介绍到这了,更多相关OpenCV人脸美白 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
使用Python中的cookielib模拟登录网站
Apr 09 Python
Linux下通过python访问MySQL、Oracle、SQL Server数据库的方法
Apr 23 Python
python实现斐波那契数列的方法示例
Jan 12 Python
使用Python通过win32 COM实现Word文档的写入与保存方法
May 08 Python
python pandas 对series和dataframe的重置索引reindex方法
Jun 07 Python
python 反向输出字符串的方法
Jul 16 Python
python发送告警邮件脚本
Sep 17 Python
Python生成MD5值的两种方法实例分析
Apr 26 Python
Python实现Linux监控的方法
May 16 Python
详解python 利用echarts画地图(热力图)(世界地图,省市地图,区县地图)
Aug 06 Python
python3图片文件批量重命名处理
Oct 31 Python
python标识符命名规范原理解析
Jan 10 Python
Matplotlib可视化之添加让统计图变得简单易懂的注释
教你用Python matplotlib库制作简单的动画
PyQt5实现多张图片显示并滚动
pyqt5蒙版遮罩mask,setmask的使用
详解Python描述符的工作原理
用Python爬取各大高校并可视化帮弟弟选大学,弟弟直呼牛X
用python修改excel表某一列内容的操作方法
You might like
全国FM电台频率大全 - 7 吉林省
2020/03/11 无线电
PHILIPS L4X25T电路分析和打理
2021/03/02 无线电
php无限分类且支持输出树状图的详细介绍
2013/06/19 PHP
php上传图片客户端和服务器端实现方法
2015/03/30 PHP
PHP支付宝当面付2.0代码
2018/12/21 PHP
laravel-admin 实现在指定的相册下添加照片
2019/10/21 PHP
js中将多个语句写成一个语句的两种方法小结
2007/12/08 Javascript
js Form.elements[i]的使用实例
2011/11/13 Javascript
把字符串按照特定的字母顺序进行排序的js代码
2014/01/28 Javascript
javascript实现动态导入js与css等静态资源文件的方法
2015/07/25 Javascript
纯javascript实现自动发送邮件
2015/10/21 Javascript
谈一谈JS消息机制和事件机制的理解
2016/04/14 Javascript
jQuery动态加载css文件实现方法
2016/06/15 Javascript
浅谈js函数三种定义方式 & 四种调用方式 & 调用顺序
2017/02/19 Javascript
JS实现AES加密并与PHP互通的方法分析
2017/04/19 Javascript
基于javaScript的this指向总结
2017/07/22 Javascript
简单谈谈js的数据类型
2017/09/25 Javascript
解决vue多个路由共用一个页面的问题
2018/03/12 Javascript
vue发送ajax请求详解
2018/10/09 Javascript
vue中是怎样监听数组变化的
2020/10/24 Javascript
[42:24]完美世界DOTA2联赛PWL S2 LBZS vs FTD.C 第三场 11.27
2020/12/01 DOTA
Django修改app名称和数据表迁移方案实现
2020/09/17 Python
详解pandas apply 并行处理的几种方法
2021/02/24 Python
Origins加拿大官网:雅诗兰黛集团高端植物护肤品牌
2017/11/19 全球购物
销售类个人求职信范文
2013/09/25 职场文书
物业门卫岗位职责
2013/12/28 职场文书
给水工程专业毕业生自荐信
2014/01/28 职场文书
保安岗位职责
2014/02/21 职场文书
酒店员工职业生涯规划
2014/02/25 职场文书
教师教学评估方案
2014/05/09 职场文书
纪念九一八事变演讲稿:牢记九一八,屈辱怎能忘
2014/09/14 职场文书
领导四风问题整改措施思想汇报
2014/10/13 职场文书
2015年保险业务员工作总结
2015/05/27 职场文书
严以律己专题学习研讨会发言材料
2015/11/09 职场文书
承诺书应该怎么写?
2019/09/10 职场文书
Redis 持久化 RDB 与 AOF的执行过程
2021/11/07 Redis