/jittor-jieke-semantic_images_synthesis

第三届计图人工智能挑战赛赛道一代码开源

Primary LanguagePython

第三届计图人工智能挑战赛 - 风景图像生成赛道 - IIDM

简介

本项目包含了第三届计图挑战赛 - 风景图像生成赛道的代码实现。

安装

由于在Jittor上Gradient-checkpoint机制难以实现,本项目需要在6张3090上训练,训练时间为8天左右。我们后期会继续尝试实现,该机制可显著降低显存使用。

运行环境

  • ubuntu 22.04 LTS

  • python 3.8.5

  • sudo apt install libomp-dev

  • 安装mpi sudo apt install mpich

  • 安装python库: pip install -r requirements.txt

  • 根据cuda版本安装cupy:

    v11.1 (x86_64) pip install cupy-cuda111

    v11.2 ~ 11.8 (x86_64 / aarch64) pip install cupy-cuda11x

    v12.x (x86_64 / aarch64) pip install cupy-cuda12x

数据集下载

清华大学计算机系图形学实验室从Flickr官网收集了12000张高清(宽512、高384)的风景图片,并制作了它们的语义分割图。其中,10000对图片被用来训练。其中 label 是值在 0~28 的灰度图

签包括29类物体,分别是

"mountain", "sky", "water", "sea", "rock", "tree", "earth", "hill", "river", "sand", "land", "building", "grass", "plant", "person", "boat", "waterfall", "wall", "pier", "path", "lake", "bridge", "field", "road", "railing", "fence", "ship", "house", "other" 
  • 训练数据集可以从这里下载。

  • A榜测试数据集可以从这里下载。

  • B榜测试数据集可以从这里下载。

预训练模型

使用在ImageNet上训练的VQ-GAN作为AutoEncoder。

下载checkpoint

使用比赛数据集训练的AutoEncoder效果可能会更佳。

如何预训练AutoEncoder?

数据预处理

在训练开始时会自动对数据进行预处理。

推理

python test.py --input_path 测试数据路径 --img_path 参考图像路径 --output_path ./results

训练

python train.py --input_path 训练集路径

数据路径目录结构如下:

--input_path
	- val_B_labels_resized
	- label_to_img.json

--img_path
	- imgs
	- labels

训练结束之后,可以使用merge-model.py进行模型集成。

python merge_model --model_1 ./ckpts/model.pkl --weight_1 0.5 --model_2 ./ckpts/model2.pkl --weight_2 0.5

下载我们训练好的checkpoint

生成图片样例

从左到右分别为 参考图片语义分割图片生成图片

image-20230919171215839

image-20230919171248415

致谢

此项目基于论文Semantic Image Synthesis via Diffusion Models (SDM)实现,部分代码参考了Taming Transformers for High-Resolution Image Synthesis

Citation

If you find this code useful, please kindly cite the following paper:

@article{liu2024iidm,
  title={IIDM: Image-to-Image Diffusion Model for Semantic Image Synthesis},
  author={Liu, Feng and Chang, Xiaobin},
  booktitle = {Computational Visual Media Journal (CVMJ)},
  year={2024}
}