用Python做世界名画合成,下一个毕加索就是你了!

2023-12-29 05:32

本文主要是介绍用Python做世界名画合成,下一个毕加索就是你了!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如今,随着深度学习技术逐渐成为人工智能的研究热潮,python这门编程语言的热度也不断的提升,甚至一度超越Java,成为第一热门编程语言。

今天小编就带领大家,利用深度学习的技术来实现图像的合成,即风格迁移。小编力争用最通俗易懂的语言让大家理解何为风格迁移,以及风格迁移的基本原理,最后是教大家如何实现属于自己的风格迁移。

1.何为风格迁移

 

风格迁移的意义就在于既保持了原图的内容,又将原图赋予新的风格,至于组合起来的效果,看起来就像是画的一样,让计算机拥有了绘画大师的技能。

风格迁移的原理是什么呢?风格迁移其实本质也是利用了卷积神经网络特征提取的能力,而卷积神经网络就是深度学习中的一个最为基础的模型,模型的基本结构如下所示:

网络通过一层层的提取特征,并通过优化损失函数,达到图像分类,目标检测等目的。

2.风格迁移的关键

风格迁移的关键就在于损失函数的设计,风格迁移的损失函数包含了两个部分,一个是内容的损失,就是评价合成的图片和原图之间的相似程度,我们暂且称之为loss_A,另一个是风格损失,其评价的是合成的图和风格图之间的风格相似程度。我们暂且称之为loss_B。而总的损失函数可以描述为以下公式:

Total_loss = α* loss_A + β * loss_B,其中α和β是用来权衡loss_A和loss_B,也就是偏重于哪一个损失函数。

下面我们来分别简要的介绍loss_A和loss_B。在卷积神经网络中,较低层的网络层提取的特征一般为表述图像具体视觉特征,例如颜色特征、边缘信息等特征,而较高层提取的特征一般是较为抽象的特征信息,而这些抽象的特征信息更贴近于我们眼中理解的物体。如下图所示:

 

 

从上图我们可以看出,卷积神经网络的较低层,提取的只是边缘、颜色等信息,而在较高层中,提取的特征更加抽象,也更加符合我们所认知的图像。所以要比较两幅图的loss_A, 也即内容损失,需要比较两幅图(原图和合成图)的较高层特征信息的相似程度。而对于loss_B,则需要比较两张图(合成图和风格图)的较低层特征信息的相似程度。

03.

训练深度学习模型

以上就是风格迁移的基本原理,下面小编就带领大家设计属于自己的风格迁移模型。由于风格迁移模型训练数据集较大,而且对于电脑的硬件要求较高,小编的电脑是1080Ti的显卡,外加16GB的内存,即便是这样,训练三个模型的话也需要一天的时间,因此,小编直接拿来了他人训练好的模型来进行我们的风格迁移。

模型一共有三种风格图,如下图所示:

 

有了风格图,下面就是利用训练好的模型进行原图的风格转化了,首先在dos系统下找到stylize_image.py 的文件路径,然后利用python进行运行,输入我们的原图路径,风格画模型路径和合成图的保存路径后,点击enter便可以生成我们的合成图,程序的运行界面如下图所示:

 

需要注意的是,想要运行程序的话,大家的电脑里需要安装numpy,argparse,tensorflow等python库。

4.最后看一下合成的效果

 

这篇关于用Python做世界名画合成,下一个毕加索就是你了!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/548472

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

揭秘世界上那些同时横跨两大洲的国家

我们在《世界人口过亿的一级行政区分布》盘点全球是那些人口过亿的一级行政区。 现在我们介绍五个横跨两州的国家,并整理七大洲和这些国家的KML矢量数据分析分享给大家,如果你需要这些数据,请在文末查看领取方式。 世界上横跨两大洲的国家 地球被分为七个大洲分别是亚洲、欧洲、北美洲、南美洲、非洲、大洋洲和南极洲。 七大洲示意图 其中,南极洲是无人居住的大陆,而其他六个大洲则孕育了众多国家和

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Python QT实现A-star寻路算法

目录 1、界面使用方法 2、注意事项 3、补充说明 用Qt5搭建一个图形化测试寻路算法的测试环境。 1、界面使用方法 设定起点: 鼠标左键双击,设定红色的起点。左键双击设定起点,用红色标记。 设定终点: 鼠标右键双击,设定蓝色的终点。右键双击设定终点,用蓝色标记。 设置障碍点: 鼠标左键或者右键按着不放,拖动可以设置黑色的障碍点。按住左键或右键并拖动,设置一系列黑色障碍点

Python:豆瓣电影商业数据分析-爬取全数据【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】

**爬取豆瓣电影信息,分析近年电影行业的发展情况** 本文是完整的数据分析展现,代码有完整版,包含豆瓣电影爬取的具体方式【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】   最近MBA在学习《商业数据分析》,大实训作业给了数据要进行数据分析,所以先拿豆瓣电影练练手,网络上爬取豆瓣电影TOP250较多,但对于豆瓣电影全数据的爬取教程很少,所以我自己做一版。 目