【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_人工智能


应用名称:一键变身毛茸茸小兔子

体验地址:点击跳转体验 模型名称:Kolors,点击跳转

背景

Gitee AI最近发起了一个社群挑战赛。
如果最近你也没什么好点子,想练习又无从下手,怎么办呢?
没关系,Gitee AI发起第一期挑战赛题目《基于 Kolors 等文生图模型,创作一个能生成「毛茸茸作品」的应用》

生成作品参考示例

【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_Server_02


【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_v8_03

效果

下面是博主基于Kolors模型的风格转换生成的毛茸茸小兔子图片。

【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_v8_04

AI应用

基本信息

应用名称:一键变身毛茸茸小兔子
体验地址:点击跳转体验 模型名称:Kolors,点击跳转

Kolors模型

Kolors 是由快手 Kolors 团队开发的文生图模型。由数十亿的参数训练,在视觉质量、中文语义理解和文本渲染方面有显著优势。

【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_GiteeAi_05

开发过程

博主这里使用的是C#后端语言来调用模型的api。

对于又后端开发基础以及有自己服务器的小伙伴来说,直接调用对应模型的api是非常不错的。

当然,也可以直接在Gitee AI 平台上创建应用来调用对应模型。

【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_Server_06


下面是Python代码调用api的例子,平台上面也有,如下,需要自己创建令牌进行调用

import requests

API_URL = "https://ai.gitee.com/api/serverless/Kolors/image-to-image"
headers = {
    "Authorization": "Bearer XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
    "Content-Type": "application/json"
}

def query(payload):
    response = requests.post(API_URL, headers=headers, json=payload)
    return response.content

output = query({
    "parameters": {
        "prompt": "变成一幅油画",
        "width": 1024,
        "height": 1024,
        "steps": 25,
        "guidance_scale": 6,
        "strength": 0.6,
        "scale": 0.5
    },
    "image": "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",
    "inputs": "iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsIAAA7CARUoSoAAAALpSURBVHhe7d1rbtpAFEDhS5fDeDk1WQ72cuphOTbboePEojWhhKgP1XPOJ6GEEOWPj+dFouwuRQjry/JRUAYAZwBwBgBnAHAGAGcAcAYAZwBwBgBnAHAGAGcAcAYAZwBwBgBnAHAGAGcAcAYAZwBwBgBnAHAGAGcAcAYAZwBwBgBnAHAGAGcAcAYAZwBwBgBnAHAGAGcAcAYAZwBwBgBnAHAGAGcAcAYAhw1gWj7SMQKYpsj9IQ5NE81uF7vyaA55eZENMgKcou9y5BLC9c4/nx0Fio3/v4ByQZ+8iqeXJrrV96Zoh29x3C9PH0qR0vJpZTYdQD7s4p+M5KmLcTyWDOrjLgDOAOCqmgJSNzw5p3/gnF8XjdclQ8VTQMwBbNXQxhzv9dEOywu/a+wu5WL/+Nmpu4zLS7WpagQoAcTQPr8zuKss99PUR9N0jgD/u3sjwNil1dc++0hdudcdAbZifbencvdOfRPNesP/KSWAGI/l56yGEc8BNuNPBUBRXQAx5cjn5fMHzrmPLt+GkqIbxji2y1OCOQCW8dK179cJqa13nn8EFcA4tOvF3esjlcUj8dK/AZ0ETnHqfzrcmc3bu8tYto6cOf/WdtcAt3v1v+ztjGF5UhHfC4AzALhNTwGHlxxP7Piu1oc7s+cPePbHea2wPKlIfecAvzRF36x/K6jWef0znALgDACuyilgyrlM2uvfDDn3L3G4Ofp1Cqg1gKfeEErRjWOA3ve5q8opIN3c/fftYw+/+LM61wBtG49H9vlvAoYPvoeh0m3g/Kdgfbx7t7dIqY2vx7YkoBnoHED3uA2EMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDgDMAOAOAMwA4A4AzADgDQIv4DjFGOoqLWc/oAAAAAElFTkSuQmCC"
})

with open("output.png", "wb") as file:
    file.write(output)

开发难点

后端语言开发和对接api这个不算难,非常简单。
比较有难度的点,我觉得是prompt提示词这里,需要很好的表达清晰,
让Kolors模型理解你的意图。
还有一个难点就是参考图,这个也很重要。
通过参考图+提示词,必须要合理准确,否则生成出来的效果就没那么好。

解决思路

基于上面的难点,我的解决方案就是,找一张合理的参考图,以及简洁明了的prompt提示词。、
比如:
提示词:保持原图不变,如果是人物头像,尽量能够小兔子头像神似原图人物头像,根据参考图转为毛茸茸小兔子的风格。
参考图:## 开发难点
后端语言开发和对接api这个不算难,非常简单。
比较有难度的点,我觉得是prompt提示词这里,需要很好的表达清晰,
让Kolors模型理解你的意图。
还有一个难点就是参考图,这个也很重要。
通过参考图+提示词,必须要合理准确,否则生成出来的效果就没那么好。

解决思路

基于上面的难点,我的解决方案就是,找一张合理的参考图,以及简洁明了的prompt提示词。、

比如:

提示词:保持原图不变,如果是人物头像,尽量能够小兔子头像神似原图人物头像,根据参考图转为毛茸茸小兔子的风格。

参考图:

【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_API_07

Serverless API

Gitee AI 的 Serverless API 为您提供开箱即用的企业级的大模型 API 服务。

我们已为您接入了多种国内外领先算力资源,并提供极具竞争力的价格。您只需购买全模型资源包,即可尽享众多主流模型。

平台上提供在线测试预览,以及API调用代码参考,非常方便。

【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_Server_08


【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_人工智能_09


Serverless API 为开发者提供一个便捷的方式来调用不同种类的模型,无需关心底层的硬件或管理服务器。此 API 支持通过简单的 HTTP 请求在 Gitee AI 的共享基础设施上进行快速推理。

Gitee AI

在开发前,我们先来了解下Gitee AI平台。
Gitee AI 汇聚最新最热 AI 模型,提供模型体验、推理、训练、部署和应用的一站式服务,提供充沛算力,做中国最好的 AI 社区。

国产开源模型

Gitee AI 平台为大家呈现更深入理解和处理中国文化和语境、在中文处理中更准确且符合本土需求的国产开源模型,社区的开发者能在这些模型基础上进行更多尝试和创新,小伙伴都可以为更多国产大模型贡献自己一点小小的力量。

【AI】最近有款毛茸茸AI生成图片圈粉了,博主也尝试使用风格转换生成可爱的小兔子,一起来探索下是如何实现的_人工智能_10