Project Icon

diffae

基于扩散模型的自编码器框架实现图像生成与编辑

diffae项目实现了基于扩散模型的自编码器框架,用于高质量图像的生成和编辑。该项目提供多个预训练模型,支持FFHQ、LSUN等数据集,实现了无条件生成、图像操作和插值等功能。项目包含使用说明、模型检查点和针对不同数据集的训练脚本,为图像生成和编辑研究提供了完整的工具链。

扩散自编码器的官方实现

CVPR 2022 (口头报告)论文(论文链接项目网站5分钟视频):

@inproceedings{preechakul2021diffusion,
      title={扩散自编码器:迈向有意义且可解码的表示}, 
      author={Preechakul, Konpat and Chatthee, Nattanat and Wizadwongsa, Suttisak and Suwajanakorn, Supasorn},
      booktitle={IEEE计算机视觉与模式识别会议(CVPR)}, 
      year={2022},
}

使用方法

⚙️ 尝试Colab演示:在Colab中打开

🤗 尝试网页演示:Replicate

注意:由于代码库可能会有很多变更,请在使用前先fork该仓库。

前提条件

参见requirements.txt

pip install -r requirements.txt

快速开始

Jupyter notebook示例:

无条件生成:sample.ipynb

图像操作:manipulate.ipynb

图像插值:interpolate.ipynb

自编码:autoencoding.ipynb

对齐自己的图像:

  1. 将图像放入imgs目录
  2. 运行align.py(需要pip install dlib requests
  3. 对齐后的图像将保存在imgs_align目录中
imgs目录中的原始图像
使用align.py对齐后
使用manipulate.ipynb的效果

模型检查点

我们提供以下模型的检查点:

  1. DDIM:FFHQ12872M130M),Bedroom128Horse128

  2. DiffAE(仅自编码):FFHQ256FFHQ12872M130M),Bedroom128Horse128

  3. DiffAE(带潜在DPM,可采样):FFHQ256FFHQ128Bedroom128Horse128

  4. DiffAE的分类器(用于操作):FFHQ256的CelebAHQ潜在空间FFHQ128的CelebAHQ潜在空间

检查点应放置在单独的checkpoints目录中。 下载检查点并将它们放入checkpoints目录。目录结构应如下所示:

checkpoints/
- bedroom128_autoenc
    - last.ckpt # diffae检查点
    - latent.ckpt # 数据集上预测的z_sem
- bedroom128_autoenc_latent
    - last.ckpt # diffae + 潜在DPM检查点
- bedroom128_ddpm
- ...

LMDB数据集

我们不拥有以下任何数据集的所有权。为了方便起见,我们提供了可直接使用的LMDB数据集。

失效链接

注意:我正在尝试恢复以下链接。

目录结构应如下所示:

datasets/
- bedroom256.lmdb
- celebahq256.lmdb
- celeba.lmdb
- ffhq256.lmdb
- horse256.lmdb

您也可以从原始来源下载,并使用我们提供的代码将它们打包为LMDB文件。 各数据集的原始来源如下:

提供的转换代码如下:

data_resize_bedroom.py
data_resize_celebhq.py
data_resize_celeba.py
data_resize_ffhq.py
data_resize_horse.py

Google云端硬盘:https://drive.google.com/drive/folders/1abNP4QKGbNnymjn8607BF0cwxX2L23jh?usp=sharing

训练

我们提供了在以下数据集上训练和评估DDIM和DiffAE(包括潜在DPM)的脚本:FFHQ128、FFHQ256、Bedroom128、Horse128、Celeba64(D2C的裁剪)。 通常,评估结果(FID)将在eval目录中可用。

注意:大多数实验在训练DPM模型时至少需要4个V100 GPU,而在训练配套的潜在DPM时只需要1个2080Ti GPU。

FFHQ128

# diffae
python run_ffhq128.py
# ddim
python run_ffhq128_ddim.py

可以使用以下命令训练分类器(用于操作):

python run_ffhq128_cls.py

FFHQ256

由于计算成本较高,我们只训练了DiffAE。 这需要8个V100 GPU。

sbatch run_ffhq256.py

任务完成后,您需要训练潜在DPM(只需要1个2080Ti GPU)

python run_ffhq256_latent.py

可以使用以下命令训练分类器(用于操作):

python run_ffhq256_cls.py

Bedroom128

# diffae
python run_bedroom128.py
# ddim
python run_bedroom128_ddim.py

Horse128

# diffae
python run_horse128.py
# ddim
python run_horse128_ddim.py

Celeba64

这个实验可以在2080Ti GPU上运行。

# diffae
python run_celeba64.py
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号