深度学习论文代码复现——CycleGAN和pix2pix

article/2025/9/29 8:50:27

一:前期代码准备

从GitCode(服务器在国内,访问比较快)中将开源代码copy下来

地址:mirrors / junyanz / pytorch-cyclegan-and-pix2pix · GitCode

也可从github源项目地址中获取:GitHub - junyanz/pytorch-CycleGAN-and-pix2pix: Image-to-Image Translation in PyTorch

二:数据集准备

2.1.使用官网提供的数据集

2.1.1.在Ubuntu中通过shell命令下载

以下载maps数据集为例,在终端输入以下命令:

bash ./datasets/download_cyclegan_dataset.sh maps

2.1.2.直接从源地址中下载

打开开源代码中datasets文件夹中的download_cyclegan_dataset.sh文件,复制URL中的前半段网址打开http://efrosgans.eecs.berkeley.edu/cyclegan/datasets/

打开后就可以下载你想下的任何数据集了

2.2.使用自己制作的数据集

选出训练集(A、B)和测试集(A、B),然后按照下图文件夹进行命名,最后将制作的数据集放入datasets文件夹中即可

三:初始化环境

以conda用户为例,在项目目录中使用如下命令进行环境配置(以后的操作都是基于这个虚拟环境)

conda env create -f environment.yml

这里我修改了environment.yml文件,将创建出的虚拟环境重命名为cycleGAN

注意:一定要根据自己cuda的版本号选择合适的pytorch版本,不然后续更改会很麻烦!!!

创建成功后,使用如下命令即可进入conda创建出的虚拟环境:

conda activate cycleGAN

此外,通过pip等方式也可进行初始化,具体详见原网站说明

PS:如果环境配置有问题想删了重新安装,使用如下命令:

1.首先退出当前环境

conda deactivate

2.删除自己刚创建的虚拟环境

conda remove -n xxx --all

四:训练数据

4.1.前期准备

首先,打开options文件夹,在base_options.py文件中可以进行基础配置的更改。

例如gpu_ids,默认为0,即使用第一个GPU进行训练;‘-1’是使用CPU进行训练。也可以设置batch_size(默认为1)等等

train_options.py文件中可以设置epochs的大小以及保存模型的频率等等

4.2.安装visdom(可视化)

visdom 是Facebook 为PyTorch 打造的一款可视化工具,可以实时的对数据进行可视化显示,比如模型loss值的变化、生成的图像等等

下面在conda环境中对其进行安装

conda install visdom

安装完成后,通过如下命令即可开启visdom服务

python -m visdom.server

启动成功后,终端会显示以下网址:http://localhost:8097,打开网址即可看到训练数据的实时展示

 同时,如果想看到更加详细的生成图像结果,就在主文件夹下打开以下路径./checkpoints/maps_cyclegan/web/index.html,效果展示如下图所示

 

注意:如果visdom端口被占用时,除了在配置文件中更改端口外,还可以通过以下命令:

查看当前正在进行进程的端口号以及PID:

netstat -tunlp

kill跟visdom相关的那个进程(默认端口号8097):

kill -9 xxxx(PID)

4.3.开始训练

打开终端,进入cycleGAN虚拟环境,然后输入如下命令

python train.py --dataroot ./datasets/sar2optical --name sar2optical_cyclegan --model cycle_gan

如果训练pix2pix模型,则输入以下命令:

python train.py --dataroot ./datasets/sar2optical --name sar2optical_pix2pix --model pix2pix --direction AtoB

AtoB表示由A数据集训练生成B数据集

其中,sar2optical换成自己设置的数据集名称

注意:刚开始可能会报错PyTorch与CUDA版本不匹配,这时需要去官网https://pytorch.org/get-started/previous-versions/下载合适的pytorch版本

此外,要恢复之前的训练,可以使用--continue_train标志。程序将根据epoch加载模型。默认情况下,该程序将把epoch计数初始化为1,同时设置--epoch_count <int>可以来指定不同的起始epoch

五:测试数据

结束训练之后,使用如下命令对数据集进行测试

python test.py --dataroot ./datasets/sar2optical --name sar2optical_cyclegan --model cycle_gan

测试结果保存在主目录下的一个html文件中./results/sar2optical_cyclegan/test_latest/index.html

部分测试结果:

 此外,我还测试了下monet2photo:

以及horse2zebra:

 

 整体效果还是不错的~


http://chatgpt.dhexx.cn/article/hUk2w9at.shtml

相关文章

深度学习论文复习

文章目录 一. 卷积神经网络二. 感受野三. 激活函数四. BN层1. BN层问题2. BN层思想3. BN层训练阶段4. BN层测试阶段 五. AlexNet六. VGG七. ResNet1. 网络加深的问题2. ResNet三个优点&#xff1a; 八. YOLO系列1. YOLO &#xff08;Darknet&#xff09;2. YOLOv2&#xff08;D…

深度学习领域引用量最多的前20篇论文简介

本文来源&#xff1a;全球人工智能 作者&#xff1a;Pedro Lopez&#xff0c;数据科学家&#xff0c;从事金融与商业智能 深度学习是机器学习和统计学交叉领域的一个子集&#xff0c;在过去的几年里得到快速的发展。强大的开源工具以及大数据爆发使其取得令人惊讶的突破进展。本…

2019年最新十篇「深度学习领域综述」论文

1、A guide to deep learning in healthcare&#xff08;医疗深度学习技术指南&#xff09; Google 斯坦福 Nature Medicine 作者&#xff1a;Andre Esteva, Alexandre Robicquet, Bharath Ramsundar, Volodymyr Kuleshov, Mark DePristo, Katherine Chou, Claire Cui, Greg …

【深度学习】2022年最值得关注的十篇论文,你都看了吗?来卷来学习

选自Ahead of AI 作者&#xff1a;Sebastian Raschka 机器之心编译 编辑&#xff1a;王强、蛋酱 年关将至&#xff0c;威斯康星大学助理教授 Sebastian Raschka 盘点了 2022 年他最看好的十大论文。 2022 年 1 月&#xff0c;扩散模型第一次吸引了我的眼球。当时我判断到将会有…

10篇论文带你入门深度学习图像分类(附下载)

来源&#xff1a;计算机视觉联盟 本文约7600字&#xff0c;建议阅读10分钟。 本文将介绍10篇最佳论文供初学者阅读。 前言 计算机视觉是将图像和视频转换成机器可理解的信号的主题。利用这些信号&#xff0c;程序员可以基于这种高级理解来进一步控制机器的行为。在许多计算机视…

机器学习和深度学习引用量最高的20篇论文(2014-2017)

机器学习和深度学习的研究进展正深刻变革着人类的技术&#xff0c;本文列出了自 2014 年以来这两个领域发表的最重要&#xff08;被引用次数最多&#xff09;的 20 篇科学论文&#xff0c;以飨读者。 机器学习&#xff0c;尤其是其子领域深度学习&#xff0c;在近些年来取得了许…

综述 | 近年来深度学习的重要研究成果(附PDF)

来源&#xff1a;机器之心 本文约1万字&#xff0c;建议阅读15分钟。 本文列举出了近年来深度学习的重要研究成果&#xff0c;从方法、架构&#xff0c;以及正则化、优化技术方面进行概述。 这篇综述论文列举出了近年来深度学习的重要研究成果&#xff0c;从方法、架构&#xf…

2023年2月的十篇深度学习论文推荐

本月的论文包括语言模型、扩散模型、音乐生成、多模态等主题。 1、MusicLM: Generating Music From TextPage https://arxiv.org/abs/2301.11325 By Andrea Agostinelli, Timeo I. Denk, et al. 扩散模型和自回归离散模型都在生成音乐/音频显示出令人印象深刻的性能。 与最…

深度学习研究综述

本文分为四章。 第一章 神经网络的发展 深度学习&#xff08;deep learning&#xff09;作为机器学习算法中的一个新兴技术&#xff0c;其动机在于建立&#xff0c;模拟人脑进行分析学习的神经网络。 深度学习的本质是对观察数据进行分层特征表示&#xff0c;实现将低级特征进…

如何快速入门深度学习写论文?

原文作者&#xff1a;月来客栈 https://www.zhihu.com/people/the_lastest 最快的方式&#xff1a; 第一&#xff0c;选择一篇有代码的论文&#xff0c;记住一定要有代码&#xff1b; 第二&#xff0c;大致弄清楚论文里所提出算法的思想原理&#xff1b; 第三&#xff…

2021年3月四篇深度学习论文推荐

这是Machine-Learning-Collage系列&#xff0c;每隔一周作者都会编写一个本周论文的幻灯片摘要。每月底所有的幻灯片画都会被集中到一个总结文章中。作者希望给读者一个直观和直观的一些最酷的趋势。以下是作者在2021年3月读到的四篇最喜欢的论文&#xff0c;以及为什么我相信它…

深度学习论文《Deep Learning》

论文《Deep Learning》 (深度学习) 作者&#xff1a;Yann Lecun, Yoshua Bengio, Geoffery Hinton 单位&#xff1a; FAIR&#xff0c; NYU&#xff0c; UMontreal&#xff0c; Utoronto&#xff0c; Google 发表会议及时间&#xff1a;《Nature》杂志 1、论文作者简介 2019…

2022 年 1 月推荐阅读的四篇深度学习论文

自举元学习到深度学习的时间序列预测&#xff0c;外推与泛化之间的关系与 Ridge Rider 探索多样化最优 ‘Bootstrapped Meta-Learning’ Flennerhag et al. (2021) | &#x1f4dd; https://arxiv.org/pdf/2109.04504.pdf 元学习算法旨在自动发现归纳偏差&#xff0c;这允许…

深度学习9篇论文

Introduction 卷积神经网络CNN&#xff0c;虽然它听起来就像是生物学、数学和计算机的奇怪混杂产物&#xff0c;但在近些年的机器视觉领域&#xff0c;它是最具影响力的创新结果。随着Alex Krizhevsky开始使用神经网络&#xff0c;将分类错误率由26%降到15%并赢得2012年度Image…

2020年最新Spark企业级面试题【上】

前言 现在距离2021年还有不到一个月的时间了&#xff0c;是不是有的小伙明年不知该怎么复习spark&#xff0c;以及不知道该备战企业中会问到那些问题。好今天他来了总结了20个企业中经常被问到的面题以及会附带一些笔试题哦&#xff0c;编写不易建议收藏。 一、 Spark 有几种…

spark相关面试题总结

&#xff08;根据博客总结并不断增加自己的内容&#xff09; 1.spark中的RDD是什么&#xff0c;有哪些特性&#xff1f; 答&#xff1a;RDD&#xff08;Resilient Distributed Dataset&#xff09;叫做分布式数据集&#xff0c;是spark中最基本的数据抽象&#xff0c;它代表一…

spark面试题

1.spark中的RDD是什么&#xff0c;有哪些特性&#xff1f; 答&#xff1a;RDD&#xff08;Resilient Distributed Dataset&#xff09;叫做分布式数据集&#xff0c;是spark中最基本的数据抽象&#xff0c;它代表一个不可变&#xff0c;可分区&#xff0c;里面的元素可以并行计…

Spark面试

场景描述&#xff1a;这是一个Spark的面试题合集。是我自己作为面试者和作为面试官都会被问到或者问到别人的问题&#xff0c;这个总结里面有大量参考了网上和书上各位老师、大佬的一些原文答案&#xff0c;只是希望可以给出更好的回答&#xff0c;一般上我都会把原文链接贴上&…

还有多少人搞不懂这 40 道 Spark 灵魂面试题?

大家好&#xff0c;我是峰哥~ 最近看到了各大厂裁员的消息&#xff0c;没办法&#xff0c;到了毕业季&#xff0c;大家总有一天会各奔东西&#xff0c;今天给分享一些面试题&#xff0c;希望大家能拿到更好的offer&#xff01; 来源&#xff1a;大数据真好玩 1、spark的有几种部…

关于Spark的面试题,你应该知道这些!

之前分享过一篇博客&#xff0c;&#x1f449;不会这20个Spark热门技术点&#xff0c;你敢出去面试大数据吗?&#xff0c;那一篇确实是非常精华&#xff0c;提炼出了非常重要同样非常高频的Spark技术点&#xff0c;也算是收到了一些朋友们的好评。本篇博客&#xff0c;博主打算…