Project Icon

SVGDreamer

文本驱动的SVG图形生成工具

SVGDreamer是一款基于扩散模型的矢量图形生成工具。它能根据文本描述生成高质量、可编辑的SVG图像。该工具支持多种风格,如图标、油画、像素艺术、低多边形和素描等。SVGDreamer在保证图像质量的同时,也注重矢量图形的可编辑性,为图形设计和创作提供了新的可能性。

SVGDreamer:基于扩散模型的文本引导SVG生成

cvpr24 arXiv 网站 博客 博客

本仓库包含我们CVPR 2024论文《SVGDreamer:基于扩散模型的文本引导SVG生成》的官方实现。它可以根据文本提示生成高质量的SVG。

标题 标题

:new: 更新

  • [2024年3月] 🔥 我们已发布SVGDreamer代码
  • [2024年2月] 🎉 SVGDreamer被CVPR2024接收。 🎉
  • [2023年12月] 🔥 我们已发布**SVGDreamer论文**。SVGDreamer是一种新颖的文本引导矢量图形合成方法。该方法同时考虑了矢量图形的编辑和合成的质量。

安装

1. 安装环境

您可以按照以下步骤快速上手并运行SVGDreamer。 这些步骤将让您在本地运行快速推理。

在顶层目录运行:

sh script/install.sh

或使用docker:

docker run --name svgdreamer --gpus all -it --ipc=host ximingxing/svgrender:v1 /bin/bash

2. 下载预训练的Stable Diffusion模型

下载预训练SD模型,首次运行时在/conf/config.yaml中设置diffuser.download=True。 (或者,您可以在脚本末尾附加diffuser.download=True。)

您也可以手动下载:

🔥 快速开始

SIVE + VPSD

**提示:**蝙蝠侠的图像。全身动作姿势,完整详细的身体,白色背景,高质量,4K,超级真实
预览:

粒子1粒子2粒子3粒子4粒子5粒子6
初始p1初始p2初始p3初始p4初始p5初始p6
最终p1最终p2最终p3最终p4最终p5最终p6

脚本:

python svgdreamer.py x=iconography skip_sive=False "prompt='an image of Batman. full body action pose, complete detailed body. white background. empty background, high quality, 4K, ultra realistic'" token_ind=4 x.vpsd.t_schedule='randint' result_path='./logs/batman' multirun=True
  • x=iconography(str):样式配置
  • skip_sive(bool):启用SIVE阶段
  • token_ind(int):文本提示的索引,从1开始
  • result_path(str):保存结果的路径
  • multirun(bool):使用不同的随机种子多次运行脚本
  • mv(bool):保存运行的中间结果并记录视频(这会增加运行时间)

更多参数在./conf/x/style.yaml中,您可以从命令行修改这些参数。例如, 在脚本末尾附加x.vpsd.n_particle=4

SIVE

**提示:**一名宇航员在沙漠中行走,背景是火星,漂浮在行星旁边,太空艺术
预览:

注意力图背景初始前景初始背景最终前景最终最终

脚本:

python svgdreamer.py x=iconography-s1 skip_sive=False "prompt='an astronaut walking across a desert, planet mars in the background, floating beside planets, space art'" token_ind=5 result_path='./logs/astronaut_sive' seed=116740

VPSD

✍️ 图标风格

**提示:**悉尼歌剧院。油画。梵高作品
预览:

粒子 1粒子 2粒子 3粒子 4粒子 5粒子 6
初始 p1初始 p2初始 p3初始 p4初始 p5初始 p6
最终 p1最终 p2最终 p3最终 p4最终 p5最终 p6

脚本:

python svgdreamer.py x=iconography "prompt='悉尼歌剧院。油画。梵高风格'" result_path='./logs/SydneyOperaHouse-OilPainting' state.mprec='fp16'

✍️ 绘画风格

提示: 抽象文森特·梵高油画大象,以绿色和棕色的大地色调为特色
预览:

粒子 1粒子 2粒子 3粒子 4粒子 5粒子 6
初始 p1初始 p2初始 p3初始 p4初始 p5初始 p6
最终 p1最终 p2最终 p3最终 p4最终 p5最终 p6

脚本:

python svgdreamer.py x=painting "prompt='抽象文森特·梵高油画大象,以绿色和棕色的大地色调为特色。'" x.num_paths=256 result_path='./logs/Elephant-OilPainting'

✍️ 像素艺术风格

提示: 拿着光剑的达斯·维达
预览:

粒子 1粒子 2粒子 3粒子 4粒子 5粒子 6
初始 p1初始 p2初始 p3初始 p4初始 p5初始 p6
最终 p1最终 p2最终 p3最终 p4最终 p5最终 p6

脚本:

python svgdreamer.py x=pixelart "prompt='拿着光剑的达斯·维达。'" result_path='./logs/DarthVader'

✍️低多边形风格

提示: 一幅白头鹰的图片。低多边形。多边形。极简平面2D矢量

粒子1粒子2粒子3粒子4粒子5粒子6
初始 p1初始 p2初始 p3初始 p4初始 p5初始 p6
最终 p1最终 p2最终 p3最终 p4最终 p5最终 p6

脚本:

python svgdreamer.py x=lowpoly "prompt='A picture of a bald eagle. low-ploy. polygon. minimal flat 2d vector'" neg_prompt='' result_path='./logs/BaldEagle'

✍️ 素描风格

提示词: 一幅兰博基尼高速行驶的手绘画。黑白绘画。
预览:

粒子1粒子2粒子3粒子4粒子5粒子6
初始 p1初始 p2初始 p3初始 p4初始 p5初始 p6
最终 p1最终 p2最终 p3最终 p4最终 p5最终 p6

脚本:

python svgdreamer.py x=sketch "prompt='A free-hand drawing of A speeding Lamborghini. black and white drawing.'" neg_prompt='' result_path='./logs/Lamborghini'

✍️ 水墨画风格

提示词: 大雁塔。水墨风格。极简抽象艺术灰度水彩。空白背景
预览:

粒子1粒子2粒子3粒子4粒子5粒子6
初始 p1初始 p2初始 p3初始 p4初始 p5初始 p6
最终 p1最终 p2最终 p3最终 p4最终 p5最终 p6

脚本:

python svgdreamer.py x=ink "prompt='Big Wild Goose Pagoda. ink style. Minimalist abstract art grayscale watercolor. empty background'" neg_prompt='' result_path='./logs/BigWildGoosePagoda'

更多案例

更多案例请参见 Examples.md

🔑 提示

  • 强烈建议开启 xformer enable_xformers=True 以加速优化。
  • x.vpsd.t_schedule 对结果风格影响很大。请多尝试。
  • neg_prompt 负面提示词会影响结果质量。
  • 通过设置 state.mprec='fp16',可以显著减少 GPU 内存使用。

📋 待办事项

  • 发布代码。
  • 添加 docker 镜像。
  • 支持 fp16 优化。

:books: 致谢

本项目基于以下仓库构建:

我们衷心感谢这些作者的杰出工作。

:paperclip: 引用

如果您在研究中使用了此代码,请引用以下论文:

@InProceedings{svgdreamer_xing_2023,
    author    = {Xing, Ximing and Zhou, Haitao and Wang, Chuang and Zhang, Jing and Xu, Dong and Yu, Qian},
    title     = {SVGDreamer: Text Guided SVG Generation with Diffusion Model},
    booktitle = {Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR)},
    month     = {June},
    year      = {2024},
    pages     = {4546-4555}
}

:copyright: 许可证

本作品采用MIT许可证授权。

项目侧边栏1项目侧边栏2
推荐项目
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号