-
Notifications
You must be signed in to change notification settings - Fork 1
/
web_demo.py
284 lines (223 loc) · 10.4 KB
/
web_demo.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
import json
import os
import time
import warnings
import appbuilder
import gradio as gr
import modelscope_studio as mgr
from rag_full.rag_langchain import FaissSearch, tokenize_chinese # tokenize_chinese需要在这里import,否则pickle会报错
warnings.filterwarnings('ignore')
# 配置密钥与应用ID
# 设置环境变量APPBUILDER_TOKEN,目前填的这个是官方的受限试用TOKEN
os.environ["APPBUILDER_TOKEN"] = "bce-v3/ALTAK-DyYuSA9DVtgt3uLCJvj09/66566c4c39901e34c20829d07bbe993654c03452"
app_id = "b2c236c9-e544-4d16-8e74-016c602ef342"
# 创建一个FaissSearch实例,用于检索向量数据库,每次检索返回top_k个相关文档
search_engine = FaissSearch(path='./faiss_index_llama_full_ernie', top_k=5, threshold=10)
# 使用appbuilder创建LLM对话接口
llm = appbuilder.AppBuilderClient(app_id)
prompt = """
检索结果:
第1个段落:
{doc}
检索语句: 你的名字是启迪绘,擅长把科学事实编成有趣易懂的故事,以激发儿童对相关领域的好奇心,同时这个故事应当作为成为亲子共读的桥梁,助力孩子们在轻松愉快的氛围中学习成长。
你需要根据我的问题和你所知道的知识为我创作符合以上要求的故事。
我的问题是:
{query}
请根据以上检索结果回答检索语句的问题
"""
docs = []
def resolve_assets(relative_path):
return os.path.join(os.path.dirname(__file__), "resources",
relative_path)
conversation = [
[None, {
"text": "你好,欢迎来到😶🌫️智慧启迪绘!",
"flushing": False
}],
]
def get_last_bot_message(chatbot):
return chatbot[-1][1]
def create_video_bot_message(text: str):
return {
"text": text,
}
def create_image_bot_message(text: str):
return {
"text": text,
}
async def chat_bot_with_llm(_input: mgr.MultimodalInput, _chatbot):
global prompt, docs, search_engine, llm
_chatbot.append([_input, [""]])
yield gr.update(interactive=False, value=None), _chatbot
docs = search_engine.search(_input.text)
if len(docs) > 0:
# 取出检索到的相关性最高的文档
doc = docs[0]['content']
else:
# 如果没有检索到相关文档,则将doc置为空字符串
doc = ""
final_prompt = prompt.replace('{query}', _input.text).replace('{doc}', doc)
conversation_id = llm.create_conversation()
messages = llm.run(conversation_id, final_prompt, stream=True)
for content in messages.content:
if content.answer is not None:
_chatbot[-1][1][0] += content.answer
yield {
chat_bot_1: _chatbot,
}
async def chat_bot_with_llm_image(_input: mgr.MultimodalInput, _chatbot):
global prompt, docs, search_engine, llm
_chatbot.append([_input, [""]])
yield gr.update(interactive=False, value=None), _chatbot
docs = search_engine.search(_input.text)
if len(docs) > 0:
# 取出检索到的相关性最高的文档
doc = docs[0]['content']
# 取出图片信息
image_paths = docs[0]['image']
else:
# 如果没有检索到相关文档,则将doc置为空字符串
doc = ""
# 如果没有检索到相关文档,则将image_paths置为空列表
image_paths = []
final_prompt = prompt.replace('{query}', _input.text).replace('{doc}', doc)
conversation_id = llm.create_conversation()
messages = llm.run(conversation_id, final_prompt, stream=True)
for content in messages.content:
if content.answer is not None:
_chatbot[-1][1][0] += content.answer
yield {
chat_bot_2: _chatbot,
}
_chatbot[-1][1][0] += '''\n
Demo 版本因十万图书版权限制,本项目代码只展示基础对话功能,不展示tts和视频生成,请关注我们的**Github** [chg0901/Public_QiDiHui](https://github.com/chg0901/Public_QiDiHui.git) , 后续更新, 敬请期待'''
yield {
chat_bot_2: _chatbot,
}
def chat_video(_input, _chatbot):
_chatbot.append([_input, None])
yield gr.update(interactive=False, value=None), _chatbot
_chatbot[-1][1] = [
create_video_bot_message("")
]
time.sleep(1)
get_last_bot_message(_chatbot)[0][
"text"] = f"""你好,欢迎来到😶🌫️智慧启迪绘 \n
<video src="{resolve_assets("dog.mp4")}"></video> \n
<accordion title="生成图片">
<img src="https://oss.lingkongstudy.com.cn/blog/202405261707489.jpg" style="float: left;">
<img src="https://oss.lingkongstudy.com.cn/blog/202405261707489.jpg" style="float: left;">
</accordion>
\n
Demo 版本因十万图书版权限制,本项目代码只展示基础对话功能,不展示tts和视频生成,请关注我们的**Github** [chg0901/Public_QiDiHui](https://github.com/chg0901/Public_QiDiHui.git) , 后续更新, 敬请期待"""
yield {
chat_bot_3: _chatbot,
}
def flushed():
return gr.update(interactive=True)
def read_grouped_queries(file_path):
# 读取 JSON 文件
with open(file_path, 'r', encoding='utf-8') as f:
data = json.load(f)
# 提取并返回 "grouped_queries" 列表
grouped_queries = data.get('grouped_queries', [])
# 返回第一个子列表,如果没有则返回空列表
if grouped_queries:
return grouped_queries
else:
return []
css = """
h1 {
text-align: center;
display: block;
}
"""
json_path = "resources/list.json"
avatar_images = [
# resolve_assets('user.jpeg'),
# default bot avatar and name
[{
"name": "Curious baby",
"avatar": "https://oss.lingkongstudy.com.cn/blog/202405271251981.png"
}],
[{
"name": "QiDiHui",
"avatar": "https://oss.lingkongstudy.com.cn/blog/202405261707489.jpg"
}],
]
# 创建Gradio界面
with gr.Blocks(gr.themes.Soft(), css=css) as demo:
html_code = """
<h1 style="text-align: center;">😶🌫️ 智慧启迪绘</h1>
<p align="center">
<img src="https://oss.lingkongstudy.com.cn/blog/202405261707489.jpg" alt="Logo" width="10%" style="border-radius: 5px;">
</p>
<div class="hint" style="text-align: center; background-color: rgba(255, 255, 0, 0.15); padding: 5px; margin: 5px; border-radius: 5px; border: 1px solid #ffcc00;">
<h3 align="center">我们致力于创造一个既能娱乐也能教育的视频生成应用,将《十万个为什么》系列丛书的丰富知识转化为易于消化和吸收理解的内容,使之成为亲子共读的桥梁,助力孩子们在轻松愉快的氛围中学习成长。在这里,学习将不再是枯燥的任务,而是充满乐趣和惊喜的旅程。让我们携手,为孩子们构建一个充满想象力和知识启迪的成长空间,一起见证《十万个为什么》系列丛书丰富有趣的知识魔力!</h3>
<p> 为了方便在AIStudio中部署,在AIStudio中的部署中,开发团队对整体功能进行了解耦拆分,增加更多的点击触发互动功能</p>
<p>
【AIStudio 主体验地址】:
<a href="https://aistudio.baidu.com/application/detail/40487" target="_blank">https://aistudio.baidu.com/application/detail/40487</a>
</p>
<p>
【AIStudio 备用体验地址】:
<a href="https://aistudio.baidu.com/application/detail/42990" target="_blank">https://aistudio.baidu.com/application/detail/42990</a>
</p>
<p>
【全功能版本请查看OpenXLab部署版本】:
<a href="https://openxlab.org.cn/apps/detail/chg0901/QiDiHui_appbuilder_V2" target="_blank">https://openxlab.org.cn/apps/detail/chg0901/QiDiHui_appbuilder_V2</a>
</p>
<p>
【B站介绍视频】:
<a href="https://www.bilibili.com/video/BV1yT8SejEQ8/" target="_blank">B站 LIC2024 RAG赛道智慧启迪绘 "十万个所以"团队 有关介绍视频</a>
</p>
</div>
"""
gr.Markdown(html_code)
with gr.Tabs():
with gr.TabItem("对话"):
chat_bot_1 = mgr.Chatbot(
value=conversation,
avatar_image_width=60,
avatar_images=avatar_images,
height=500,
flushing_speed=6,
)
state = gr.State([])
input = mgr.MultimodalInput()
input.submit(fn=chat_bot_with_llm, inputs=[input, chat_bot_1], outputs=[input, chat_bot_1])
chat_bot_1.flushed(fn=flushed, outputs=[input])
with gr.Column():
with gr.Accordion(open=True, label="😀输入示例:"): # 使用 Accordion 组件创建可以折叠的区域
gr.Examples(examples=read_grouped_queries(json_path), inputs=input, outputs=chat_bot_1)
with gr.TabItem("文生图"):
chat_bot_2 = mgr.Chatbot(
value=conversation,
avatar_image_width=40,
avatar_images=avatar_images,
height=500,
flushing_speed=6,
)
input = mgr.MultimodalInput()
input.submit(fn=chat_bot_with_llm_image, inputs=[input, chat_bot_2], outputs=[input, chat_bot_2])
chat_bot_2.flushed(fn=flushed, outputs=[input])
with gr.Column():
with gr.Accordion(open=True, label="😀输入示例:"): # 使用 Accordion 组件创建可以折叠的区域
gr.Examples(examples=read_grouped_queries(json_path), inputs=input, outputs=chat_bot_2)
with gr.TabItem("文生视频"):
chat_bot_3 = mgr.Chatbot(
value=conversation,
avatar_image_width=40,
avatar_images=avatar_images,
height=500,
flushing_speed=6,
)
input = mgr.MultimodalInput()
input.submit(fn=chat_video, inputs=[input, chat_bot_3], outputs=[input, chat_bot_3])
chat_bot_3.flushed(fn=flushed, outputs=[input])
with gr.Column():
with gr.Accordion(open=True, label="😀输入示例:"): # 使用 Accordion 组件创建可以折叠的区域
gr.Examples(examples=read_grouped_queries(json_path), inputs=input, outputs=chat_bot_3)
# 启动Gradio应用
if __name__ == "__main__":
demo.queue().launch()