• 一句话生成图片,FlagAI使用(附页面操作代码) | 机器学习


    目录

    前言

    项目结构

    页面交互调整

    总结


    前言

    最近Text-To-Image是一个很火的话题,甚至更进一步的Text-To-Video话题度也在不断上升。最近看到一个开源项目FlagAI,是目前我觉着效果比较好的项目之一。安装操作简单,支持中英文,这就很nice。

    项目开源地址:github地址

    下面是我用项目demo跑出的效果,大家可以看一下。

    输入的文本:

    Anime portrait of natalie portman as an anime girl by stanley artgerm lau, wlop, rossdraws, james jean, andrei riabovitchev, marc simonetti, and sakimichan, trending on artstation

    翻译一下,乱七八糟的人名,动漫肖像女孩,大概是这样。

    项目结构

    在ReadMe中,作者不但提供了快速上手的可以使用的中英文预训练模型

    还有分词器、预测器的操作说明。

    我先打开作者给我们的样例代码。

    使用的方式很简单,生成图片的方法为:predictor.predict_generate_images,代码看上去十分简单移动。作者给出的安装说明如下:

    OK,我把样例代码改一下,改成可页面交互方式,方便使用。

    页面交互调整

    代码如下:

    1. import torch
    2. from flagai.auto_model.auto_loader import AutoLoader
    3. from flagai.model.predictor.predictor import Predictor
    4. from PIL import Image
    5. import gradio as gr
    6. import os
    7. import shutil
    8. # Initialize
    9. device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
    10. loader = AutoLoader(task_name="text2img", # contrastive learning
    11. model_name="AltDiffusion",
    12. model_dir="./checkpoints")
    13. model = loader.get_model()
    14. model.eval()
    15. model.to(device)
    16. predictor = Predictor(model)
    17. def handle(text: str):
    18. if not os.path.isdir("./AltDiffusionOutputs"):
    19. os.mkdir("./AltDiffusionOutputs")
    20. else:
    21. shutil.rmtree("./AltDiffusionOutputs")
    22. predictor.predict_generate_images(text)
    23. imgs = []
    24. for s in os.listdir("./AltDiffusionOutputs/samples"):
    25. imgs.append(Image.open(os.path.join("./AltDiffusionOutputs/samples", s)))
    26. return imgs
    27. if __name__ == '__main__':
    28. demo = gr.Interface(fn=handle, inputs=gr.Text(),
    29. outputs=[gr.Image(type="pil"), gr.Image(type="pil"),
    30. gr.Image(type="pil"), gr.Image(type="pil")])
    31. demo.launch(server_name="0.0.0.0", server_port=12003)

    除了项目要求的安装内容,需要额外安装gradio。

    安装命令如下:

    pip install gradio -i https://pypi.douban.com/simple

    第一次执行会在当前目录下创建checkpoints文件夹,下载预训练模型,耗时比较久。

    第二次执行后结果如下

    ******************** text2img altdiffusion
    LatentDiffusion: Running in eps-prediction mode
    DiffusionWrapper has 859.52 M params.
    making attention of type 'vanilla' with 512 in_channels
    Working with z of shape (1, 4, 64, 64) = 16384 dimensions.
    making attention of type 'vanilla' with 512 in_channels
    ******************** txt_img_matching altclip-xlmr-l
    model files:['config.json', 'pytorch_model.bin', 'tokenizer.json', 'tokenizer_config.json', 'preprocessor_config.json', 'special_tokens_map.json']
    ./checkpoints/AltCLIP-XLMR-L
    Global Step: 143310
    Running on local URL:  http://0.0.0.0:12003

    To create a public link, set `share=True` in `launch()`.

    通过浏览器打开页面:http://localhost:12003

    输入需要生成图片的文字,然后点击submit。

    我们用中文试试看这次输入的是:坐落在迷幻森林里的庙宇,周围有着满是红色枫叶的枫树。

    我们看一下执行的效果

    该demo方法会默认生成4张图,我们一起看一下。

    第一眼看我还以为是照片,下面我简化操作过程,看下生成的几个效果。

    文本:一个有天使翅膀的动漫女孩

    文本:国画风格

    总结

    项目整体效果个人感觉还是不错的,其中英文还是稍微比中文理解的更好一些。大家可以自己摸索尝试一下。

    最近太忙,很少写文章。有不少人微信联系我,问我这个文章那个文章的安装部署问题,我也没太多时间一一回复。我写这些文章不是为了给自己带来什么收入,主要是抛砖引玉给大家分享,还是希望大家多自己摸索,会收获更多。

    分享:

            曲则全,枉则直,洼则盈,敝则新,少则得,多则惑。是以圣人抱一,为天下式。不自见故明,不自是故彰,不自伐故有功,不自矜故长。夫唯不争,故天下莫能与之争。古之所谓曲则全者,岂虚言哉!诚全而归之。——《道德经》

  • 相关阅读:
    NineData云原生智能数据管理平台新功能发布|2024年2月版
    [Database] 关系型数据库中的MVCC是什么?怎么理解?原理是什么?MySQL是如何实现的?
    C++类模板再学习
    数仓建模—大数据建模
    Windows11安装Maven,配置环境变量
    前端飞机大战小游戏
    Vuex的使用
    【Java】常用的文件操作
    设计原则之【依赖反转原则】
    Jmeter性能 —— 事务控制器
  • 原文地址:https://blog.csdn.net/zhiweihongyan1/article/details/127908222