用Python生成会跳舞的美女


Posted in Python onJanuary 18, 2022

导语

表妹心疼我,为了逗我开心,教我用Python制作会跳舞的美女。作为新时代的活雷锋,在这里分享给大家。

开发工具

Python版本:3.6.4

相关模块:

torch0.4.1模块;
torchvision0.2.2模块;
opencv-python模块;
argparse模块;
numpy模块;
以及一些Python自带的模块。

环境搭建

安装Python并添加到环境变量,pip安装需要的相关模块即可。

(PS:CUDA环境配置请自行Google教程。)

原理简介

这里我们利用VAE的原理来生成会跳舞的小姐姐呗。先简单介绍一下理论知识,要说VAE,就得先谈谈自动编码器,自动编码器最开始用于数据压缩,其原理图十分简单直观:

用Python生成会跳舞的美女

在模型训练时,输入图片首先通过一个编码器(现在当然是神经网络啦)将输入数据降维到一个code,接着将code输入到解码器(当然还是神经网络啦)生成一个与输入相同大小的图片,网络的优化目标就是使得输入编码器的图片与解码器输出的图片尽可能相似。 当模型训练完之后,我们就可以拿出这个解码器,随机传入一些code作为它的输入,来生成一些差不多的图片。但是这种做法存在一个问题,就是编码器生成的code包含了原图信息,因此,我们就无法自己构造一些随机的code来作为解码器输入从而生成任意图片(必须是现有图片过了编码器之后生成的code作为输入)。为了解决这个问题,VAE就诞生啦~VAE的全称是:

Variational Autoencoder 即变分自编码器
说起来,它的原理图也十分简单:

用Python生成会跳舞的美女

与自编码器唯一不同就是在训练过程中对code也进行了约束,使得code满足某种分布(譬如正态分布)。这样的话,模型训练完之后,我们只需要随机生成一个满足该分布的code,就可以拿来作为解码器的输入,从而生成任意图片啦~ 一般地,我们用均方损失函数保证原图和生成图相似,用KL损失函数来保证code满足我们所要求的分布。均方损失大家肯定知道,KL散度的定义这里我也不想过多地去介绍,贴下维基百科上定义的公式吧:

用Python生成会跳舞的美女

P和Q是在同一个概率空间上定义的离散概率分布。 同时,为了方便计算KL散度,VAE引入了一个trick,叫:

reparameterization

以正态分布为例子,就是现在不直接预测code了,而是预测code的均值和方差,有了均值向量和方差向量,恢复code是很方便的(用标准正态分布乘以方差再加个均值就行了)。

再回过头来,我们现在要用VAE来生成会跳舞的小姐姐,无非就是先找到一个训练数据集,这里我找了个Youtube上的视频作为数据集:

https://www.youtube.com/watch?v=NdSqAAT28v0

然后根据VAE的原理构造一个编码和解码网络,用两个损失函数作为约束训练网络就行啦。代码就不一个个贴了,写起来很简单的,贴上来倒感觉有点麻烦,有需要的直接在公众号后台回复“dancenet”即可获取。简单说下代码使用方式吧,模型训练运行train.py文件即可,命令格式为:

python train.py --videopath xxx.mp4
模型测试运行demo.py文件即可,命令格式为:
python demo.py --mode random/fromtrain --checkpointspath xxx.pth --outputpath xxx.avi
这里模式的含义是code随机生成/从训练集中提取一些图片的code作为输入。

效果展示

随机生成code模式作为输入:

用Python生成会跳舞的美女

数据集中挑选图片过编码器获得code作为输入:

用Python生成会跳舞的美女


好了,我的分享到此结束了。

总结

到此这篇关于用Python生成会跳舞的美女的文章就介绍到这了,更多相关Python美女内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python程序设计入门(3)数组的使用
Jun 16 Python
python常用知识梳理(必看篇)
Mar 23 Python
python实现最长公共子序列
May 22 Python
Python读取英文文件并记录每个单词出现次数后降序输出示例
Jun 28 Python
Python框架Flask的基本数据库操作方法分析
Jul 13 Python
Flask Web开发入门之文件上传(八)
Aug 17 Python
python利用跳板机ssh远程连接redis的方法
Feb 19 Python
pyinstaller打包多个py文件和去除cmd黑框的方法
Jun 21 Python
Django接收post前端返回的json格式数据代码实现
Jul 31 Python
python加载自定义词典实例
Dec 06 Python
Pandas实现DataFrame按行求百分数(比例数)
Dec 27 Python
如何定义TensorFlow输入节点
Jan 23 Python
基于Pygame实现简单的贪吃蛇游戏
Dec 06 #Python
Python可变集合和不可变集合的构造方法大全
Dec 06 #Python
Python实现视频中添加音频工具详解
Dec 06 #Python
Python实现GIF动图以及视频卡通化详解
Python实现照片卡通化
用Python爬取英雄联盟的皮肤详细示例
Python+腾讯云服务器实现每日自动健康打卡
Dec 06 #Python
You might like
php学习之 认清变量的作用范围
2010/01/26 PHP
php的curl封装类用法实例
2014/11/07 PHP
PHP实现QQ登录实例代码
2016/01/14 PHP
PHP strip_tags保留多个HTML标签的方法
2016/05/22 PHP
php对象工厂类完整示例
2018/08/09 PHP
动手学习无线电
2021/03/10 无线电
自适应高度框架 ----属个人收藏内容
2007/01/22 Javascript
javascript 处理事件绑定的一些兼容写法
2009/12/24 Javascript
javascript动态加载实现方法一
2012/08/22 Javascript
javascript采用数组实现tab菜单切换效果
2012/12/12 Javascript
js中eval()函数和trim()去掉字符串左右空格应用
2013/02/02 Javascript
js实现在字符串中提取数字
2013/11/05 Javascript
javascript判断chrome浏览器的方法
2014/03/26 Javascript
基于javascript如何传递特殊字符
2015/11/30 Javascript
javascript如何写热点图
2015/12/08 Javascript
js模仿java的Map集合详解
2016/01/06 Javascript
Jquery UI实现一次拖拽多个选中的元素操作
2020/12/01 Javascript
jQuery Autocomplete简介_动力节点Java学院整理
2017/07/17 jQuery
基于vue-router 多级路由redirect 重定向的问题
2018/09/03 Javascript
记一次react前端项目打包优化的方法
2020/03/30 Javascript
vue内置组件component--通过is属性动态渲染组件操作
2020/07/28 Javascript
如何使用pyinstaller打包32位的exe程序
2019/05/26 Python
Ubuntu18.04安装 PyCharm并使用 Anaconda 管理的Python环境
2020/04/08 Python
纯CSS3实现移动端展开和收起效果的示例代码
2020/04/26 HTML / CSS
卡西欧G-SHOCK英国官网: 防水防震手表
2018/01/08 全球购物
阿迪达斯荷兰官方网站:adidas荷兰
2018/03/16 全球购物
Tiqets英国:智能手机上的文化和娱乐门票
2019/07/10 全球购物
既然说Ruby中一切都是对象,那么Ruby中类也是对象吗
2013/01/26 面试题
户外宣传策划方案
2014/05/25 职场文书
小班下学期个人总结
2015/02/12 职场文书
总经理司机岗位职责
2015/04/10 职场文书
2016年教师学习教师法心得体会
2016/01/20 职场文书
机械生产实习心得体会
2016/01/22 职场文书
JavaScript 事件捕获冒泡与捕获详情
2021/11/11 Javascript
mysql5.6主从搭建以及不同步问题详解
2021/12/04 MySQL
Mybatis 一级缓存和二级缓存原理区别
2022/09/23 Java/Android