Stable Diffusion C++ 项目下载及安装教程
2024-12-09 22:51:36作者:郁楠烈Hubert
1. 项目介绍
Stable Diffusion C++ 是一个基于纯 C/C++ 实现的 Stable Diffusion 和 Flux 推理项目。该项目具有以下特点:
- 基于 ggml 的纯 C/C++ 实现,类似于 llama.cpp。
- 超轻量级,无外部依赖。
- 支持 SD1.x、SD2.x、SDXL 和 SD3/SD3.5。
- 支持 SD-Turbo 和 SDXL-Turbo。
- 支持 PhotoMaker。
- 支持 16-bit 和 32-bit 浮点数。
- 支持 2-bit、3-bit、4-bit、5-bit 和 8-bit 整数量化。
- 支持加速内存高效的 CPU 推理。
- 支持 AVX、AVX2 和 AVX512。
- 支持 CUDA、Metal、Vulkan 和 SYCL 后端。
- 支持加载 ckpt、safetensors 和 diffusers 模型/检查点。
- 支持 Flash Attention 以优化内存使用。
2. 项目下载位置
项目源代码托管在 GitHub 上,可以通过以下命令进行下载:
git clone --recursive https://github.com/leejet/stable-diffusion.cpp.git
3. 项目安装环境配置
3.1 环境要求
- 操作系统:Linux、Mac OS、Windows、Android(通过 Termux)
- 编译器:支持 C++11 的编译器(如 GCC、Clang)
- 依赖库:OpenBLAS、CUBLAS、HipBLAS、Metal、Vulkan、SYCL(根据需要选择)
3.2 环境配置示例
3.2.1 Linux 环境配置
3.2.2 Windows 环境配置
4. 项目安装方式
4.1 从源码编译
4.1.1 下载源码
git clone --recursive https://github.com/leejet/stable-diffusion.cpp.git
cd stable-diffusion.cpp
4.1.2 更新子模块
如果已经克隆了仓库,可以使用以下命令更新子模块:
git pull origin master
git submodule init
git submodule update
4.1.3 下载模型权重
下载原始权重(ckpt 或 safetensors),例如:
curl -L -O https://huggingface.co/CompVis/stable-diffusion-v-1-4-original/resolve/main/sd-v1-4.ckpt
4.1.4 编译
mkdir build
cd build
cmake ..
cmake --build . --config Release
4.2 使用预编译的可执行文件
对于大多数用户,可以直接从项目的最新发布版本中下载预编译的可执行文件。
5. 项目处理脚本
5.1 文本生成图像
使用 SYCL 后端生成图像的示例:
./bin/sd -m /models/sd3_medium_incl_clips_t5xxlfp16.safetensors --cfg-scale 5 --steps 30 --sampling-method euler -H 1024 -W 1024 --seed 42 -p "fantasy medieval village world inside a glass sphere high detail fantasy realistic light effect hyper detail volumetric lighting cinematic macro depth of field blur red light and clouds from the back highly detailed epic cinematic concept art cg render made in maya blender and photoshop octane render excellent composition dynamic dramatic cinematic lighting aesthetic very inspirational world inside a glass sphere by james gurney by artgerm with james jean joe fenton and tristan eaton by ross tran fine details 4k resolution"
5.2 启用 Flash Attention
启用 Flash Attention 可以减少内存使用,例如:
./bin/sd --flash-attention
通过以上步骤,您可以成功下载并安装 Stable Diffusion C++ 项目,并使用其提供的功能进行图像生成和处理。
热门项目推荐
相关项目推荐
- DDeepSeek-R1-0528DeepSeek-R1-0528 是 DeepSeek R1 系列的小版本升级,通过增加计算资源和后训练算法优化,显著提升推理深度与推理能力,整体性能接近行业领先模型(如 O3、Gemini 2.5 Pro)Python00
cherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端TSX028unibest
unibest - 最好用的 uniapp 开发框架。unibest 是由 uniapp + Vue3 + Ts + Vite5 + UnoCss + WotUI 驱动的跨端快速启动模板,使用 VS Code 开发,具有代码提示、自动格式化、统一配置、代码片段等功能,同时内置了大量平时开发常用的基本组件,开箱即用,让你编写 uniapp 拥有 best 体验。TypeScript00
热门内容推荐
1 freeCodeCamp 前端开发实验室:排列生成器代码规范优化2 freeCodeCamp全栈开发课程中Navbar组件构建的优化建议3 freeCodeCamp课程中关于学习习惯讲座的标点规范修正4 freeCodeCamp课程中CSS模态框描述优化分析5 freeCodeCamp JavaScript课程中十进制转二进制转换器的潜在问题分析6 freeCodeCamp 实验室项目:Event Hub 图片元素顺序优化指南7 freeCodeCamp课程中sr-only类与position: absolute的正确使用8 freeCodeCamp课程中ARIA-hidden属性的技术解析9 freeCodeCamp正则表达式教程中捕获组示例的修正说明10 freeCodeCamp全栈开发课程中业务卡片设计实验的优化建议
最新内容推荐
Cap项目v0.3.35版本发布:跨平台录制优化与全新定价界面设计 eslint-config-prettier 兼容性问题分析与解决方案 Vimtex项目中的语法高亮自定义技巧 处理Dotnet WebAPI Starter Kit中的JWT令牌失效问题 LSPosed模块中WebUI组件的可选择性安装方案解析 VSCode C/C++扩展IntelliSense失效问题排查与解决指南 Kotlinx.serialization中WrappedSerialDescriptor.equals方法的缺陷分析 Kotlinx.serialization版本冲突导致的AbstractMethodError问题解析 Home Assistant操作系统对UGREEN NASync设备网卡驱动的支持分析 Actions Runner Images 项目中的 macOS 15 镜像更新解析
项目优选
收起

🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
416
317

React Native鸿蒙化仓库
C++
90
157

openGauss kernel ~ openGauss is an open source relational database management system
C++
45
113

本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
268
401

🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
50
13

🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TSX
309
28

本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
341
211

🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
84
60

前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。
官网地址:https://matechat.gitcode.com
625
73

轻量级、语义化、对开发者友好的 golang 时间处理库
Go
7
2