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 相关文章推荐
python3.3教程之模拟百度登陆代码分享
Jan 16 Python
python处理cookie详解
Feb 07 Python
Python中使用HTMLParser解析html实例
Feb 08 Python
Windows安装Python、pip、easy_install的方法
Mar 05 Python
python利用urllib和urllib2访问http的GET/POST详解
Sep 27 Python
Python动刷新抢12306火车票的代码(附源码)
Jan 24 Python
python email smtplib模块发送邮件代码实例
Apr 26 Python
python隐藏终端执行cmd命令的方法
Jun 24 Python
关于pytorch处理类别不平衡的问题
Dec 31 Python
将pycharm配置为matlab或者spyder的用法说明
Jun 08 Python
python爬虫智能翻页批量下载文件的实例详解
Feb 02 Python
pycharm最新激活码有效期至2100年(亲测可用)
Feb 05 Python
Matplotlib可视化之添加让统计图变得简单易懂的注释
教你用Python matplotlib库制作简单的动画
PyQt5实现多张图片显示并滚动
pyqt5蒙版遮罩mask,setmask的使用
详解Python描述符的工作原理
用Python爬取各大高校并可视化帮弟弟选大学,弟弟直呼牛X
用python修改excel表某一列内容的操作方法
You might like
php上传图片存入数据库示例分享
2014/03/11 PHP
PHP中spl_autoload_register()和__autoload()区别分析
2014/05/10 PHP
PHP+Mysql+jQuery查询和列表框选择操作实例讲解
2015/10/22 PHP
swoole锁的机制代码实例讲解
2021/03/04 PHP
javascript知识点收藏
2007/02/22 Javascript
javascript 函数使用说明
2010/04/07 Javascript
JavaScript取得鼠标绝对位置程序代码介绍
2012/09/16 Javascript
一个js控制的导航菜单实例代码
2013/12/03 Javascript
table对象中的insertRow与deleteRow使用示例
2014/01/26 Javascript
jquery实现通用的内容渐显Tab选项卡效果
2015/09/07 Javascript
ES6新特性之解构、参数、模块和记号用法示例
2017/04/01 Javascript
小程序实现投票进度条
2019/11/20 Javascript
javascript前端实现多视频上传
2020/12/13 Javascript
Python实现的科学计算器功能示例
2017/08/04 Python
Python利用ElementTree模块处理XML的方法详解
2017/08/31 Python
Django中redis的使用方法(包括安装、配置、启动)
2018/02/21 Python
解决Python plt.savefig 保存图片时一片空白的问题
2019/01/10 Python
pandas数据筛选和csv操作的实现方法
2019/07/02 Python
在Django的View中使用asyncio的方法
2019/07/12 Python
利用Python检测URL状态
2019/07/31 Python
pandas针对excel处理的实现
2021/01/15 Python
俄罗斯最大的消费电子连锁零售商:Mvideo
2017/06/25 全球购物
墨尔本最受欢迎的复古风格品牌:Princess Highway
2018/12/21 全球购物
关键字throw与throws的用法差异
2016/11/22 面试题
法学专业个人求职信
2013/09/26 职场文书
应届生的求职推荐信范文
2013/11/30 职场文书
大家检讨书5000字
2014/02/03 职场文书
2014年两会学习心得体会
2014/03/17 职场文书
教师民族团结演讲稿
2014/08/27 职场文书
2014高中生入党思想汇报范文
2014/09/13 职场文书
2015年个人现实表现材料
2014/12/10 职场文书
民事答辩状范本
2015/05/21 职场文书
导游词之蓬莱长岛
2019/12/17 职场文书
欧元符号 €
2022/02/17 杂记
vue使用refs获取嵌套组件中的值过程
2022/03/31 Vue.js
详解Mysq MVCC多版本的并发控制
2022/04/29 MySQL