ADI-Stable-Diffusion: 基于ONNXRuntime的高性能Stable Diffusion推理框架

Ray

ADI-Stable-Diffusion:加速您的Stable Diffusion推理

Stable Diffusion作为一种强大的AI图像生成技术,已经在各种应用场景中展现出巨大潜力。然而,如何高效地部署和运行Stable Diffusion模型一直是一个挑战。为了解决这个问题,ADI-Stable-Diffusion应运而生,为开发者和研究人员提供了一个高性能、跨平台的Stable Diffusion推理解决方案。

什么是ADI-Stable-Diffusion?

ADI-Stable-Diffusion是一个基于C++的库和命令行工具,旨在加速Stable Diffusion的推理过程。它利用ONNXRuntime的强大功能和.onnx模型格式的广泛兼容性,为Stable Diffusion的工程部署提供了一个便捷的解决方案。该项目的主要目标是在保持较小包大小的同时,实现高性能的Stable Diffusion推理。

ADI-Stable-Diffusion架构图

为什么选择ONNXRuntime作为推理引擎?

ADI-Stable-Diffusion选择ONNXRuntime作为其推理引擎,这一决定基于以下几个关键因素:

  1. 开源性: ONNXRuntime是一个开源项目,允许用户自由使用和修改,以适应不同的应用场景。

  2. 可扩展性: 它支持自定义算子和优化,允许根据特定需求进行扩展和优化。

  3. 高性能: ONNXRuntime经过高度优化,提供快速的推理速度,适用于实时应用。

  4. 强兼容性: 支持从多个深度学习框架(如PyTorch、TensorFlow)转换模型,使集成和部署变得更加便捷。

  5. 跨平台支持: ONNXRuntime支持多种硬件平台,包括CPU、GPU、TPU等,能够在各种设备上高效执行。

  6. 社区和企业支持: 由微软开发和维护,拥有活跃的社区和企业支持,提供持续的更新和维护。

ADI-Stable-Diffusion的安装与使用

ADI-Stable-Diffusion提供了多种安装方式,以适应不同用户的需求:

  1. 使用包管理器安装命令行工具:

    • macOS (Homebrew):
      brew tap windsander/adi-stable-diffusion
      brew install adi
      
    • Windows (git-Bash + Chocolatey):
      curl -L -o adi.1.0.1.nupkg "https://raw.githubusercontent.com/Windsander/ADI-Stable-Diffusion/deploy/adi.1.0.1.nupkg"
      choco install adi.1.0.1.nupkg -y
      
  2. 从已发布版本下载: 用户可以从GitHub的Release Assets页面下载最新可用版本。

  3. 本地构建: 项目提供了一个自动化脚本auto_build.sh,可以更容易地在本地设备上编译ADI。

使用示例

ADI-Stable-Diffusion的使用非常直观。以下是一个使用命令行工具进行1步Euler_A img2img推理的示例:

adi \
 -p "A cat in the water at sunset" \
 -m img2img \
 -i ../../sd/io-test/input-test.png \
 -o ../../sd/io-test/output.png \
 -w 512 -h 512 -c 3 \
 --seed 15.0 \
 --dims 1024 \
 --clip ../../sd/sd-base-model/onnx-sd-turbo/text_encoder/model.onnx \
 --unet ../../sd/sd-base-model/onnx-sd-turbo/unet/model.onnx \
 --vae-encoder ../../sd/sd-base-model/onnx-sd-turbo/vae_encoder/model.onnx \
 --vae-decoder ../../sd/sd-base-model/onnx-sd-turbo/vae_decoder/model.onnx \
 --dict ../../sd/sd-dictionary/vocab.txt \
 --beta-start 0.00085 \
 --beta-end 0.012 \
 --beta scaled_linear \
 --alpha cos \
 --scheduler euler_a \
 --predictor epsilon \
 --tokenizer bpe \
 --train-steps 1000 \
 --token-idx-num 49408 \
 --token-length 77 \
 --token-border 1.0 \
 --gain 1.1 \
 --decoding 0.18215 \
 --guidance 1.0 \
 --steps 1 \
 -v

这个命令演示了如何使用ADI-Stable-Diffusion进行图像到图像的转换,同时指定了各种参数,如模型路径、调度器类型、采样步数等。

开发进展

ADI-Stable-Diffusion正在不断发展,目前已经支持多个Stable Diffusion版本和功能:

  • 基础管道功能:

    • SD_v1 (v1.0 ~ v1.5, turbo)
    • SD_v2 (v2.0, v2.1)
    • SD_v3 (v3.0)
    • SDXL 和 SDXL-turbo
    • SVD (Stable Video Diffusion)
  • 调度器能力:

    • 多种采样方法,如Euler、Euler Ancestral、LMS等
    • 不同的采样策略
  • 分词器类型:

    • 支持BPE、Word Piece等编码方式

ADI-Stable-Diffusion性能对比

结语

ADI-Stable-Diffusion为Stable Diffusion的推理提供了一个高效、灵活的解决方案。通过利用ONNXRuntime的优势,它不仅提高了推理速度,还简化了部署过程。无论您是开发者、研究人员还是AI爱好者,ADI-Stable-Diffusion都为您提供了一个强大的工具,以探索和应用Stable Diffusion的潜力。

随着项目的不断发展,我们期待看到更多创新功能和性能优化。欢迎社区成员参与贡献,共同推动ADI-Stable-Diffusion的发展,为AI图像生成领域带来更多可能性。

🔗 GitHub仓库
📚 详细文档
💡 问题反馈

让我们一起探索ADI-Stable-Diffusion的无限潜力,开创AI图像生成的新纪元!

avatar
0
0
0
相关项目
Project Cover

dream-textures

Dream Textures是一款Blender插件,通过文本提示生成纹理、概念艺术和背景资产。支持无缝拼接、场景投影和动画再设计等功能,用户可本地运行模型,避免在线服务延迟。兼容CUDA和Apple Silicon GPU,适用于4GB以上显存设备。若硬件不支持,可使用DreamStudio进行云端处理。插件提供详细的安装指南和使用教程,并有活跃的社区支持,适合高效生成和处理图像资源的创意工作者。

Project Cover

photoshot

Photoshot是一款开源AI头像生成应用,利用Stable Diffusion模型生成独特虚拟形象。应用由Next.js、Chakra UI、Prisma和Replicate等技术构建,支持AWS S3图片存储和Stripe支付。用户通过简单安装和配置环境变量快速启动,并使用Docker管理本地数据库和邮件服务器,轻松运行开发服务器生成和定制头像。

Project Cover

StabilityMatrix

Stability Matrix提供一键安装和更新Stable Diffusion Web UI包,支持多种包和扩展插件管理。内置推理界面具有自动完成功能和语法高亮,多标签工作区支持项目文件的保存和加载。跨平台支持Windows、Linux和macOS,便于管理Python依赖,导入本地或在线模型,并提供便携使用体验。

Project Cover

cloudflare-ai-web

Cloudflare Workers AI支持快速搭建轻量化多模态AI平台,提供Serverless部署,无需服务器。支持ChatGPT、Gemini Pro、Stable Diffusion、llama-3和通义千问等模型,具备访问密码和本地存储聊天记录功能。详细的部署说明和环境变量设置指南,支持Docker、Deno Deploy和Vercel等多种部署方式。

Project Cover

opendream

Opendream 是一个简化 Stable Diffusion 工作流的 Web 界面,支持分层操作和非破坏性编辑,帮助用户在保留原始图像数据的同时进行灵活调整。扩展功能使得用户可以轻松编写和安装扩展,集成 ControlNet 等新功能,提升创意探索的可能性。通过保存和分享工作流,用户可以轻松协作,保持创作的连续性。Opendream 为图像生成和编辑带来了更多便捷和控制力。

Project Cover

easydiffusion

Easy Diffusion 3.0提供一键安装,无需技术知识和预装软件,快速入门AI图像创作。全面支持Stable Diffusion模型,新增多种功能如ControlNet、多LoRA文件支持、嵌入式等,适用于Windows、Linux和Mac系统。适合新手和需求高级功能的用户,配备强大的社区支援。

Project Cover

krita-ai-diffusion

krita-ai-diffusion是一款集成于Krita中的AI生成插件,专为图像编辑和绘画工作流程设计。它支持精准控制生成内容,如通过选择区域、使用参考图像和素描来引导图像生成。此插件与Krita的编辑工作流程完美整合,支持本地运行和开放源代码,无需依赖高性能云服务。特性包括实时绘画、图像放大、稳定扩散技术、区域文本描述、以及强大的默认及自定义预设。

Project Cover

StableSwarmUI

StableSwarmUI是一个高性能模块化的网页用户界面,专注于易用性、扩展性以及工具的强大功能性。适合初学者和专业用户,支持图像生成和复杂工作流管理。随着项目独立发展,用户可通过新的仓库获取更新。加入官方Discord或参与GitHub讨论,了解功能更新和详细的迁移指南。

Project Cover

PaddleHub

PaddleHub提供超过400种高质量AI模型,覆盖计算机视觉、自然语言处理和语音识别等领域。用户仅需3行代码即可进行模型预测,同时支持模型即服务,通过简单命令即可部署。最新版本v2.3.0引入了ERNIE-ViLG、Disco Diffusion和Stable Diffusion等模型,并支持在HuggingFace平台上发布。PaddleHub兼容Linux、Windows和MacOS,适合多平台开发。

最新项目
Project Cover

豆包MarsCode

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

Project Cover

AI写歌

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

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

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

Project Cover

Kimi

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

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

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

Project Cover

AIWritePaper论文写作

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

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