Github项目推荐 | SC-FEGAN:基于GAN的人脸照片涂鸦编辑
时间:2022-06-20
本文章向大家介绍Github项目推荐 | SC-FEGAN:基于GAN的人脸照片涂鸦编辑,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Github项目推荐 | SC-FEGAN:基于GAN的人脸照片涂鸦编辑
(使用用户的草图和所选颜色进行面部编辑生成对抗网络,可添加/更改耳环,眼镜,发型,酒窝等)
by Youngjoo Jo, Jongyoul Park
《SC-FEGAN: Face Editing Generative Adversarial Network with User's Sketch and Color》Y Jo, J Park [South Korea] (2019)
论文链接
https://arxiv.org/abs/1902.06838
模型
https://drive.google.com/drive/folders/1VPsYuIK_DY3Gw07LEjUhg2LwbEDlFpq1
Github项目地址
https://github.com/JoYoungjoo/SC-FEGAN
概述
我们学习使用深度网络来编辑人像。我们的网络SC-FEGAN(即本项目)非常适合使用直观的用户输入与草图和颜色生成高质量的合成图像。我们使用SN-patchGAN鉴别器和Unet-like发生器和门控卷积层。
依赖项
- tensorflow
- numpy
- Python3
- PyQt5
- opencv-python
- pyyaml
使用
首先,从Google drive 下载模型
基本用法是:
mv /${HOME}/SC-FEGAN.ckpt.* /${HOME}/ckpt/
python3 demo.py
通过编辑 demo.yaml 文件选择GPU的数量(不支持多GPU)。
GPU_NUM: 1 (the number you want to use)
#GPU_NUM: (if you want to use only CPU, erase the number)
你可以使用我们的网络与简单的GUI。只填充已擦除的区域。
GUI中的按钮:
- Open Image :打开要编辑的图像并重置草图和颜色。
- Mask :单击此按钮并在左侧查看器上绘制蒙版。
- Sketches :单击此按钮并在左侧查看器上绘制素描线。
- Color :单击此按钮并绘制颜色线。 如果您第一次单击此按钮,则必须从调色板中选择颜色。
- Palette :单击此按钮可更改颜色。 如果选择颜色,则单击“颜色”按钮进行更改。
- Save Img :单击此按钮可保存更改后的图片。 将以'name.jpg'的方式保存。
- Arrange :安排编辑工作。
- Undo :撤消之前的编辑工作。
- Complete :完成图像生成并在右侧显示。
我们建议你按照以下的步骤使用:
1. 根据原图合理地画出草图。
2. 在草图区域绘制蒙版。
3. 单击“Arrange”按钮。
4. 在蒙版区域上绘制颜色。
5. 单击“Complete”。
示例
面部编辑
耳环编辑
面部修复
面部修复(只有草图和颜色)
License
CC 4.0署名 - 非商业国际
该软件仅用于教育和学术研究。
注意
- 本项目是在运行Ubuntu 18.04.1的Linux机器上开发的
- 所提供的模型和示例代码均遵循非商业的知识共享许可协议。
接下来要做的事
- 更新训练代码
- Jexus 负载均衡
- 用.NET Framework 2.0创建 Form设计器[翻译]
- jquery事件绑定
- Fontello:免费Web-font 图标大集合(font-face 图标集)
- 通过 wp-config.php 禁止安装、升级或编辑WordPress 主题与插件
- 利用VS2005中的Code Snippets提高开发效率
- 用schemaSpy制作数据库文档
- WordPress 投票插件Post Ratings,可在谷歌搜索显示星级投票(附中文包下载)
- Spark学习笔记——共享变量
- 如何升级Mono
- 使用信息架构视图访问数据库元数据
- Java 基础标识符
- 在Windows上玩转Mono/Linux
- Active Record和Domain Object + Dao
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Magicodes.IE 2.3重磅发布——.NET Core开源导入导出库
- pytest文档59-运行未提交git的用例(pytest-picked)
- pytest文档57-单元测试代码覆盖率(pytest-cov)
- pytest文档58-随机执行测试用例(pytest-random-order)
- Kubernetes探针踩坑记
- 大揭秘| 我司项目组Gitlab Flow && DevOps流程
- 离线安装Superset 0.37(截图详细版)
- 如何高速转储、索引和第7层网络流量过滤?
- 爬虫 | JS逆向某验滑动加密(二)
- 闲聊 Kotlin-Native (0) - 我们为什么应该关注一下 Kotlin Native?
- 哈佛大学单细胞课程|笔记汇总 (五)
- 通过源码理解IGMP v1的实现(基于linux1.2.13)
- 微服务下数据一致性的几种实现方式
- 关于mac electron设备权限申请的方法
- 两种实现方式 | 如何查看消费者组的消费情况