forked from shibing624/ChatPDF
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebui.py
93 lines (81 loc) · 3.35 KB
/
webui.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
# -*- coding: utf-8 -*-
"""
@author:XuMing([email protected])
@description:
"""
import argparse
import os
import gradio as gr
from loguru import logger
from chatpdf import ChatPDF
pwd_path = os.path.abspath(os.path.dirname(__file__))
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument("--gen_model_type", type=str, default="auto")
parser.add_argument("--gen_model_name", type=str, default="01-ai/Yi-6B-Chat")
parser.add_argument("--lora_model", type=str, default=None)
parser.add_argument("--rerank_model_name", type=str, default="maidalun1020/bce-reranker-base_v1")
parser.add_argument("--device", type=str, default=None)
parser.add_argument("--corpus_files", type=str, default="sample.pdf")
parser.add_argument("--int4", action='store_true', help="use int4 quantization")
parser.add_argument("--int8", action='store_true', help="use int8 quantization")
parser.add_argument("--chunk_size", type=int, default=220)
parser.add_argument("--chunk_overlap", type=int, default=0)
parser.add_argument("--num_expand_context_chunk", type=int, default=1)
parser.add_argument("--server_name", type=str, default="0.0.0.0")
parser.add_argument("--server_port", type=int, default=8082)
parser.add_argument("--share", action='store_true', help="share model")
args = parser.parse_args()
logger.info(args)
model = ChatPDF(
generate_model_type=args.gen_model_type,
generate_model_name_or_path=args.gen_model_name,
lora_model_name_or_path=args.lora_model,
corpus_files=args.corpus_files.split(','),
device=args.device,
int4=args.int4,
int8=args.int8,
chunk_size=args.chunk_size,
chunk_overlap=args.chunk_overlap,
num_expand_context_chunk=args.num_expand_context_chunk,
rerank_model_name_or_path=args.rerank_model_name,
)
logger.info(f"chatpdf model: {model}")
def predict_stream(message, history):
history_format = []
for human, assistant in history:
history_format.append([human, assistant])
model.history = history_format
for chunk in model.predict_stream(message):
yield chunk
def predict(message, history):
logger.debug(message)
response, reference_results = model.predict(message)
r = response + "\n\n" + '\n'.join(reference_results)
logger.debug(r)
return r
chatbot_stream = gr.Chatbot(
height=600,
avatar_images=(
os.path.join(pwd_path, "assets/user.png"),
os.path.join(pwd_path, "assets/llama.png"),
), bubble_full_width=False)
title = " 🎉ChatPDF WebUI🎉 "
description = "Link in Github: [shibing624/ChatPDF](https://github.com/shibing624/ChatPDF)"
css = """.toast-wrap { display: none !important } """
examples = ['Can you tell me about the NLP?', '介绍下NLP']
chat_interface_stream = gr.ChatInterface(
predict_stream,
textbox=gr.Textbox(lines=4, placeholder="Ask me question", scale=7),
title=title,
description=description,
chatbot=chatbot_stream,
css=css,
examples=examples,
theme='soft',
)
with gr.Blocks() as demo:
chat_interface_stream.render()
demo.queue().launch(
server_name=args.server_name, server_port=args.server_port, share=args.share
)