distrifuser

distrifuser

高效分布式并行推理助力高分辨率图像生成

DistriFusion是一种用于高分辨率扩散模型的分布式并行推理算法。该方法无需额外训练,通过多GPU协同工作加速推理过程,同时保持图像质量。其创新的补丁交互技术解决了传统方法的碎片化问题,在高分辨率图像生成任务中显著提升了性能。该项目已在CVPR 2024被评为亮点工作,并开源了相关代码。

DistriFusiondiffusion模型并行推理高分辨率GPU加速Github开源项目

DistriFusion:高分辨率扩散模型的分布式并行推理

论文 | 项目 | 博客 | 幻灯片 | YouTube | 海报

[2024年7月29日] DistriFusion 已在 ColossalAI 中得到支持!

[2024年4月4日] DistriFusion 被选为 CVPR 2024 亮点海报展示!

[2024年2月29日] DistriFusion 被 CVPR 2024 接收!我们的代码已公开发布!

概览图 我们提出了 DistriFusion,这是一种免训练的算法,可利用多个 GPU 加速扩散模型推理,同时不牺牲图像质量。简单的图像块处理(概览(b))由于缺乏图像块之间的交互而存在分割问题。展示的示例是使用 SDXL 在 1280×1920 分辨率下生成的,采用 50 步 Euler 采样器,延迟在 A100 GPU 上测量。

DistriFusion:高分辨率扩散模型的分布式并行推理</br> 李牧洋*,蔡天乐*,曹嘉欣张钦胜蔡涵白俊杰贾扬清刘明宇李凯,以及 宋涵</br> 麻省理工学院、普林斯顿大学、Lepton AI 和 NVIDIA</br> 发表于 CVPR 2024。

概述

思路 (a) 在单个设备上运行的原始扩散模型。(b) 简单地将图像分割成 2 个块并分布在 2 个 GPU 上,由于块之间缺乏交互,边界处会出现明显的接缝。(c) 我们的 DistriFusion 在第一步使用同步通信进行块交互。之后,我们通过异步通信重用前一步的激活。通过这种方式,通信开销可以隐藏在计算流水线中。

性能

加速效果

<p align="center"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/43cdba14-514d-4107-a9dc-2007345a78fc.jpg" width="80%"/> </p>在 NVIDIA A100 GPU 上使用 SDXL 和 50 步 DDIM 采样器生成单张图像时,DistriFusion 的总延迟测量结果。随着分辨率的提高,GPU 设备得到更好的利用。值得注意的是,在生成 3840×3840 图像时,DistriFusion 分别在 2、4 和 8 个 A100 上实现了 1.8 倍、3.4 倍和 6.1 倍的加速。

质量

质量 SDXL 的定性结果。FID 是与真实图像相比计算得出的。我们的 DistriFusion 可以根据使用的设备数量减少延迟,同时保持视觉保真度。

参考文献:

  • 去噪扩散隐式模型(DDIM),Song 等人,ICLR 2021
  • 阐明基于扩散的生成模型的设计空间,Karras 等人,NeurIPS 2022
  • 扩散模型的并行采样,Shih 等人,NeurIPS 2023
  • SDXL:改进高分辨率图像合成的潜在扩散模型,Podell 等人,ICLR 2024

先决条件

  • Python3
  • NVIDIA GPU + CUDA >= 12.0 及相应的 CuDNN
  • PyTorch = 2.2

入门指南

安装

安装 PyTorch 后,您应该能够通过 PyPI 安装 distrifuser

pip install distrifuser

或通过 GitHub:

pip install git+https://github.com/mit-han-lab/distrifuser.git

或在本地进行开发安装

git clone git@github.com:mit-han-lab/distrifuser.git cd distrifuser pip install -e .

使用示例

scripts/sdxl_example.py 中,我们提供了一个使用 DistriFusion 运行 SDXL 的最小脚本。

import torch from distrifuser.pipelines import DistriSDXLPipeline from distrifuser.utils import DistriConfig distri_config = DistriConfig(height=1024, width=1024, warmup_steps=4) pipeline = DistriSDXLPipeline.from_pretrained( distri_config=distri_config, pretrained_model_name_or_path="stabilityai/stable-diffusion-xl-base-1.0", variant="fp16", use_safetensors=True, ) pipeline.set_progress_bar_config(disable=distri_config.rank != 0) image = pipeline( prompt="宇航员在丛林中,冷色调,柔和的颜色,细节丰富,8k", generator=torch.Generator(device="cuda").manual_seed(233), ).images[0] if distri_config.rank == 0: image.save("astronaut.png")

具体来说,我们的 distrifuserdiffusers 共享相同的 API,可以以类似的方式使用。您只需定义一个 DistriFusion 并使用我们封装的 DistriSDXLPipeline 来加载预训练的 SDXL 模型。然后,我们可以像 diffusers 中的 StableDiffusionXLPipeline 一样生成图像。运行命令是

torchrun --nproc_per_node=$N_GPUS scripts/sdxl_example.py

其中 $N_GPUS 是您想要使用的 GPU 数量。

我们还在 scripts/sd_example.py 中提供了一个使用 DistriFusion 运行 SD1.4/2 的最小脚本。使用方法相同。

基准测试

我们的基准测试结果使用 PyTorch 2.2 和 diffusers 0.24.0。首先,您可能需要安装一些额外的依赖项:

pip install git+https://github.com/zhijian-liu/torchprofile datasets torchmetrics dominate clean-fid

COCO 质量

您可以使用 scripts/generate_coco.py 生成带有 COCO 描述的图像。命令是

torchrun --nproc_per_node=$N_GPUS scripts/generate_coco.py --no_split_batch

其中$N_GPUS是您想使用的GPU数量。默认情况下,生成的结果将存储在results/coco中。您也可以使用--output_root自定义它。一些您可能想调整的额外参数:

  • --num_inference_steps:推理步骤数。我们默认使用50步。
  • --guidance_scale:无分类器引导尺度。我们默认使用5。
  • --scheduler:扩散采样器。我们默认使用DDIM采样器。您也可以使用euler表示Euler采样器dpm-solver表示DPM求解器
  • --warmup_steps:额外预热步骤数(默认为4)。
  • --sync_mode:不同的GroupNorm同步模式。默认使用我们修正的异步GroupNorm。
  • --parallelism:您使用的并行范式。默认为补丁并行。您可以使用tensor表示张量并行和naive_patch表示朴素补丁。

生成所有图像后,您可以使用我们的脚本scripts/compute_metrics.py来计算PSNR、LPIPS和FID。用法如下:

python scripts/compute_metrics.py --input_root0 $IMAGE_ROOT0 --input_root1 $IMAGE_ROOT1

其中$IMAGE_ROOT0$IMAGE_ROOT1是您想比较的图像文件夹路径。如果IMAGE_ROOT0是真实值文件夹,请添加--is_gt标志以进行调整大小。我们还提供了一个脚本scripts/dump_coco.py来导出真实值图像。

延迟

您可以使用scripts/run_sdxl.py来对我们不同方法的延迟进行基准测试。命令如下:

torchrun --nproc_per_node=$N_GPUS scripts/run_sdxl.py --mode benchmark --output_type latent

其中$N_GPUS是您想使用的GPU数量。与scripts/generate_coco.py类似,您也可以更改一些参数:

  • --num_inference_steps:推理步骤数。我们默认使用50步。
  • --image_size:生成的图像大小。默认为1024×1024。
  • --no_split_batch:禁用无分类器引导的批次分割。
  • --warmup_steps:额外预热步骤数(默认为4)。
  • --sync_mode:不同的GroupNorm同步模式。默认使用我们修正的异步GroupNorm。
  • --parallelism:您使用的并行范式。默认为补丁并行。您可以使用tensor表示张量并行和naive_patch表示朴素补丁。
  • --warmup_times/--test_times:预热/测试运行次数。默认分别为5和20次。

引用

如果您在研究中使用此代码,请引用我们的论文。

@inproceedings{li2023distrifusion, title={DistriFusion: Distributed Parallel Inference for High-Resolution Diffusion Models}, author={Li, Muyang and Cai, Tianle and Cao, Jiaxin and Zhang, Qinsheng and Cai, Han and Bai, Junjie and Jia, Yangqing and Liu, Ming-Yu and Li, Kai and Han, Song}, booktitle={Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR)}, year={2024} }

致谢

我们的代码基于huggingface/diffuserslmxyy/sige开发。我们感谢torchprofile用于MACs测量,clean-fid用于FID计算,以及Lightning-AI/torchmetrics用于PSNR和LPIPS。

我们感谢Jun-Yan Zhu和Ligeng Zhu的有益讨论和宝贵反馈。该项目得到了MIT-IBM Watson AI Lab、亚马逊、MIT Science Hub和美国国家科学基金会的支持。

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多