百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

神经网络算法实现《呐喊》风格的埃菲尔铁塔

suiw9 2024-11-13 14:43 24 浏览 0 评论

“艺术风格神经算法”的实现

这是 Leon Gatys、Alexander Ecker 和 Matthias Bethge 的论文“艺术风格的神经算法”中描述的方法的 Torch7 实现 ( http://arxiv.org/abs/1508.06576 )。

(较长的动画)

依赖关系

  • torch7
  • Imagine-nn(用于 Inception 网络)
  • CUDA 6.5+(除非在 CPU 上运行 - 见下文)

Imagine-nn(以及您缺少的任何其他 Torch 软件包)可以通过 Luarocks 安装:

luarocks install inn

用法

首先,通过运行下载脚本来下载模型:

bash download_models.sh

这将下载 VGG 和 Inception 网络的模型权重。

基本用法:

qlua main.lua --style <style.jpg> --content <content.jpg> --style_factor <factor>

其中style.jpg是提供最终生成图像样式的图像,content.jpg是提供内容的图像。style_factor是一个常数,控制生成的图像强调风格而非内容的程度。默认情况下,它设置为 2E9。

这会使用 Karen Simonyan 和 Andrew Zisserman 的 VGG-19 网络生成图像 ( http://www.robots.ox.ac.uk/~vgg/research/very_deep/ )。

其他选项:

  • model:{起始,vgg}。要使用的 Convnet 模型。Inception是指Google的Inception架构。默认为 VGG。
  • num_iters:优化步骤数。默认值为 500。
  • size:生成图像的长边尺寸。设置为 0 以使用内容图像的大小。默认值为 500。
  • display_interval:图像显示之间的迭代次数。设置为 0 可抑制图像显示。默认值为 20。
  • smoothness:控制生成图像的平滑度的常数(全变差范数正则化强度)。使用 Inception 模型时很有用(设置为 ~5E-3)。默认值为 0。
  • init:{图像,随机}。优化图像的初始化模式。image使用内容图像进行初始化;random用随机高斯噪声初始化。默认为image.
  • backend:{cunn,cudnn}。神经网络 CUDA 后端。cudnn需要CuDNN R3 的Torch 绑定。
  • optimizer:{SGD,LBFGS}。优化算法。lbfgs每次迭代速度较慢并消耗更多内存,但可能会产生更好的结果。默认为lbfgs.
  • cpu:针对 CPU 而不是 GPU 进行优化(仅支持 VGG 模型)。

内存不足?

具有默认 L-BFGS 优化器的 VGG 网络给出了最佳结果。不过,此设置也需要大量 GPU 内存。如果遇到 CUDA 内存不足错误,请尝试使用 Inception 架构或 SGD 优化器运行:

qlua main.lua --style <style.jpg> --content <content.jpg> --model inception --optimizer sgd

您还可以尝试减小生成图像的大小:

qlua main.lua --style <style.jpg> --content <content.jpg> --size 300

如果所有其他方法都失败了(或者如果您没有兼容 CUDA 的 GPU),您可以在 CPU 上进行优化:

qlua main.lua --style <style.jpg> --content <content.jpg> --cpu

例子

爱德华·蒙克《呐喊》风格的埃菲尔铁塔:

(较长的动画)

毕加索化的奥巴马:

(较长的动画)

实施细节

使用 Inception 网络时,以下层的输出用于优化样式:conv1/7x7_s2, conv2/3x3, inception_3a, inception_3b, inception_4a, inception_4b, inception_4c, inception_4d, inception_4e。

以下层的输出用于优化内容:inception_3a, inception_4a.

默认情况下,优化图像使用内容图像进行初始化;该实现还适用于白噪声初始化,如论文中所述。

为了减少生成图像中的高频“屏蔽门”噪声(特别是在使用 Inception 网络时),应用了全变分正则化(来自cnn-vis by jcjohnson的想法)。

项目地址:https://github.com/kaishengtai/neuralart

相关推荐

设置文件的默认打开方式(如何设定文件的默认打开方式)

在操作系统中,设置文件的默认打开方式可以让特定类型的文件始终使用你选择的程序打开。以下是Windows和macOS系统中设置默认打开方式的详细步骤:Windows系统方法1:通过文件属性设置右键点...

电脑怎么设置默认浏览器(电脑怎么设置默认浏览器?)

在电脑上设置默认浏览器的步骤因操作系统不同而有所差异。以下是Windows和Mac系统的设置方法:Windows系统方法1:通过系统设置打开“设置”:...

Java接口默认方法:灵活与约束并存

Java接口默认方法:灵活与约束并存在Java编程的世界里,接口作为定义行为规范的重要工具,一直扮演着举足轻重的角色。然而,在Java8引入了默认方法之后,接口的设计和使用方式发生了微妙的变化。今天...

Java8新特性之默认方法:为接口注入灵魂

Java8新特性之默认方法:为接口注入灵魂Java8发布时,它带来的最大创新之一就是接口的默认方法。这就像给一个传统的木偶注入了生命,让它不仅能动还能说话了。今天我们就来聊聊这个让Java开发者欢呼雀...

CentOS系统在不重启的情况下为虚拟机添加新硬盘

一、概述用过虚拟机的都知道,如果在系统运行的时候去给虚拟机添加一块新设备,比如说硬盘,系统是读取不到这个新硬盘的,因为系统在启动的时候会去检测硬件设备。但是我们也可能会遇到这样的情况,比如正在运行比较...

[常用工具] 基于psutil和GPUtil获取系统状态信息

本文主要介绍在Python3中利用psutil库获取系统状态,利用GPUtil获取gpu状态。psutil(processandsystemutilities)(进程和系统实用程序)是一个跨平...

Docker容器内执行宿主机指令(docker执行宿主机shell)

一背景最近项目有个需求,需要程序配置服务器IP并且可以重启服务器。如果程序直接部署在服务器,相信大家都会操作。但是程序是用docker运行的,在docker中执行指令就很麻烦了。...

容器网络调试怎么办?一条命令就搞定!

nsenter命令是一个可以在指定进程的命令空间下运行指定程序的命令。它位于util-linux包中。用途...

linux自动化巡检脚本集(linux服务器巡检内容以及标准)

以下是一个自动化巡检脚本集的制作方案,包含常见系统检查项和可扩展框架,使用Python和Shell脚本实现:...

麒麟KOS|统信UOS系统添加新数据盘
麒麟KOS|统信UOS系统添加新数据盘

原文链接:麒麟KOS|统信UOS系统添加新数据盘...

2025-03-26 16:57 suiw9

Linux CentOS 7 根目录扩容(linux扩展根目录磁盘空间)

一、现状描述现有一台CentOS7的虚拟机,硬盘容量为30GB通过lsblk命令查看分区容量,当前根目录容量为27.5GB左右二、扩容需求...

从Linux底层分析Docker原理(linux docker-compose)

写在前面如果你觉得本人对你有帮助,请你记得评论,点赞,关注;如果你觉得文章还不错请记得收藏,点赞。如果你觉得文章非常的好可以私信我,我会在第一时间回复你。...

CentOS新增硬盘的使用步骤(centos扩展硬盘)

一、查看机器所挂硬盘个数及分区情况,新增硬盘为/dev/sdb...

Python之psutil库简介(python3 pil库)

psutil(pythonsystemandprocessutilities)是一个跨平台的第三方库,能够轻松实现获取系统运行的进程和系统利用率(包扩CPU、内存、磁盘、网络等)信息。它主...

运维,你还不会查看Linux系统cpu信息?

CPU也称为微处理器或简称为处理器。就像大脑如何控制人体一样,CPU控制着计算机的所有部分。因此CPU被认为是计算机的大脑。那我们怎么在Linux系统中查看如IntelCorei3、i5、AM...

取消回复欢迎 发表评论: