Python3,2分钟掌握Doscoart库,你也能成为艺术家。

举报
Carl_奕然 发表于 2023/03/06 14:45:07 2023/03/06
【摘要】 学会Doscoart库, 我也可以当艺术家。

1、引言

小云:鱼哥,最近在忙啥?

小鱼:咱俩陌生了?

小云:何出此言?

小鱼:你说的话又嘛意思呢?

小云:我的意思, 最近看你这整理各种资料,貌似很忙的样子?

小鱼:我平时不也这么忙嘛

小云:鱼哥, 还能正常唠嗑嘛?

小鱼:我又没说不能唠嗑。

小云:鱼哥,行… 非常行…

小鱼:男人,怎么能不行!

小云:…

小鱼:~ ~

小云:discoart模块知道吗?

小鱼:貌似, 大概,可能,或许,知道。

小云:太好了, 那能不能给我讲一讲呢?

小鱼:然后呢?

小云:老地方~

小鱼:又是老地方,整的我都不好意思了。

小云:这都是小事,我主要就想让你多放松放松…

小鱼:停,停, 打住~ 别说多了, 我们来聊discoart。

小云:别着急啊,

小鱼:能不着急吗,你看,这都几点了, 再晚一会,就…

小云:昂…

2、 代码实战

2.1 模块介绍

说起 discoart 可能大部分都不太了解。 但是,说到艺术库,可能你就有些印象了。 这里,我也引用官网对discoart的解析,让你对它有个初步的了解,如下:

>>DiscoArt is an elegant way of creating compelling Disco Diffusion[*] artworks for generative artists, AI enthusiasts and hard-core developers. DiscoArt has a modern & professional API with a beautiful codebase, ensuring high usability and maintainability. It introduces handy features such as result recovery and persistence, gRPC/HTTP serving w/o TLS, post-analysis, easing the integration to larger cross-modal or multi-modal applications.

这里,我也简答的用汉语描述一下,即:

>>DiscoArt是一种优雅的方式,可以为生成艺术家,AI爱好者和铁杆开发人员创建引人注目的Disco Diffusion艺术品。 DiscoArt拥有现代和专业的API,具有漂亮的代码库,确保了高可用性和可维护性。它引入了方便的功能,例如结果恢复和持久性,没有TLS的gRPC / HTTP服务,后期分析,简化与更大的跨模态或多模态应用程序的集成。

简答一句话概括:DiscoArt就是为了艺术而生的。

2.2 模块安装

涉及到第三方库,肯定就需要安装 老规矩,pip 安装

pip install discoart

然后就是等待着安装。

其它安装方式,直接看这两篇:


安装的样子,如下:

这里提示一下:

  •  按照官网的要求, discoart的使用,必须依托于:Python 3.7+ 和 CUDA 的 PyTorch 。


2.3 代码示例

2.3.1 创建默认图片

这里直接使用discoart的 create方法即可

代码示例

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
使用默认参数创建图片
'''
from discoart  import create
ca = create()

效果展示

在这里插入图片描述

2.3.2 设置参数创建图片

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
设置参数创建图片
'''
from discoart  import create
#设置参数
ca = create(
text_prompts='A painting of sea cliffs in a tumultuous storm, Trending on ArtStation.',
init_image='​​https://d2vyhzeko0lke5.cloudfront.net/xxxx7e77b72f0.png​​',
skip_steps=100,
)

效果展示

在这里插入图片描述


2.3.3 查看设置参数

如果你忘记参数,也没关系,直接用cheatsheet 查询即可

代码展示

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
查看设置参数
'''
from discoart  import cheatsheet
#设置参数
sha = cheatsheet()


2.3.4 查看配置

如果要查看文档配置, 可以使用show_config:

代码展示

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
查看文档配置
'''
from discorat import  show_config
展示第一个项目运行的配置
show_config(da)
参考第四个项目的运行配置
show_config(da[3])
#查看discoartID
show_config('discoart-xxxxfbf288')

2.3.5 保存配置

如果要保存文档配置, 可以使用save_config:

代码展示

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
保存文档配置
'''
from discoart import save_config
#保存第一次运行的配置
save_config(da, 'my.yml')
#保存第四次运行的配置
save_config(da[3], 'my.yml')

2.3.6 加载配置

有了查看和保存,当然也可以直接加载配置文件了, 这里,使用load_config即可

代码示例

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
加载文档配置
'''
from discoart import create, load_config
#加载配置文件
config = load_config('my.yml')
create(**config)

2.3.7 导出配置文件

为了便于后期的管理使用,同样可以直接导出配置文件为SVG映像,使用 save_config_svg方法:

代码示例

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
导出配置文件为SVG映像
'''
from discoart.config import save_config_svg
#直接保存为svg映像
save_config_svg(da)

这里也展示一下, 保存的svg映像

2.3.7 生成Python代码

更神奇的功能,就是可以直接从配置中生成可运行的Python代码,使用export_python方法:

代码示例

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
生成可运行的Python代码
'''
from discoart.config import export_python
export_python(da)

2.3.8 调用文档

  • 如果你觉得自己配置太繁琐, 那可以直接使用DocumentArray作为初始状态运行。

代码示例

-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
调用DocumentArray作为初始状态,运行
'''
from discoart import create
from docarray import DocumentArray
da = DocumentArray.pull('discoart-32xxx')
create(
init_document=da[0],
cut_ic_pow=0.5,
tv_scale=600,
cut_overview='[12]*1000',
cut_innercut='[12]*1000',
use_secondary_model=False,
)
  • 当然, 如果你只想从已有的 DocArray ID 初始化, 那也不是不可能,
-- coding:utf-8 --
@Time   : 2023-02-12
@Author : Carl_DJ
'''
实现功能:
从已有的 DocArray ID 初始化
'''
from discoart import create
create(init_document='discoart-320xxxx')

3、总结

看到这里, Doscart库的介绍就完成了。

按照流程, 我们来回顾一下今天都分享了啥内容:

  • 创建默认图片;
  • 设置参数创建图片;
  • 查看设置参数;
  • 查看文档配置;
  • 报错文档配置;
  • 加载文档配置;
  • 导出配置文件
  • 生成Python代码;
  • 调用文档;

你看, Doscoart也没有想想的那么难嘛, 常用的功能,也就差不多这么多。 所以, 只要我们把一个库从头到尾的捋一遍, 其实是很容易掌握的。

最后,唠叨一句:

我是​​奕然​​:

  • CSDN 博客专家;
  • 阿里云 专家博主;
  • 51CTO 博客专家;
  • 51认证讲师;
  • 金牌面试官&面试培训师;

关注我,带你学习更多更有趣的Python知识。 ​

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。