@ -1,52 +1,60 @@
#!/usr/bin/env python3
# Copyright (c) Alibaba Cloud.
#
# This source code is licensed under the license found in the
# LICENSE file in the root directory of this source tree.
""" A simple web interactive chat demo based on gradio. """
from argparse import ArgumentParser
from transformers import AutoTokenizer
import gradio as gr
import gradio as gr
import mdtex2html
import mdtex2html
from transformers import AutoModelForCausalLM , AutoTokenizer
from transformers import AutoModelForCausalLM , AutoTokenizer
from transformers . generation import GenerationConfig
from transformers . generation import GenerationConfig
from argparse import ArgumentParser
import sys
DEFAULT_CKPT_PATH = ' QWen/QWen-7B-Chat '
print ( " Call args: " + str ( sys . argv ) )
parser = ArgumentParser ( )
def _get_args ( ) :
parser . add_argument ( " --share " , action = " store_true " , default = False )
parser = ArgumentParser ( )
parser . add_argument ( " --inbrowser " , action = " store_true " , default = False )
parser . add_argument ( " -c " , " --checkpoint-path " , type = str , default = DEFAULT_CKPT_PATH ,
parser . add_argument ( " --server_port " , type = int , default = 80 )
help = " Checkpoint name or path, default to %(default)r " )
parser . add_argument ( " --server_name " , type = str , default = " 0.0.0.0 " )
parser . add_argument ( " --cpu-only " , action = " store_true " , help = " Run demo with CPU only " )
parser . add_argument ( " --exit " , action = " store_true " , default = False )
parser . add_argument ( " --model_revision " , type = str , default = " " )
parser . add_argument ( " --share " , action = " store_true " , default = False ,
args = parser . parse_args ( sys . argv [ 1 : ] )
help = " Create a publicly shareable link for the interface. " )
print ( " Args: " + str ( args ) )
parser . add_argument ( " --inbrowser " , action = " store_true " , default = False ,
help = " Automatically launch the interface in a new tab on the default browser. " )
tokenizer = AutoTokenizer . from_pretrained (
parser . add_argument ( " --server-port " , type = int , default = 8000 ,
" Qwen/Qwen-7B-Chat " , trust_remote_code = True , resume_download = True
help = " Demo server port. " )
)
parser . add_argument ( " --server-name " , type = str , default = " 127.0.0.1 " ,
help = " Demo server name. " )
model = AutoModelForCausalLM . from_pretrained (
" Qwen/Qwen-7B-Chat " ,
args = parser . parse_args ( )
device_map = " auto " ,
return args
trust_remote_code = True ,
resume_download = True ,
* * { " revision " : args . model_revision }
def _load_model_tokenizer ( args ) :
if args . model_revision is not None
tokenizer = AutoTokenizer . from_pretrained (
and args . model_revision != " "
args . checkpoint_path , trust_remote_code = True , resume_download = True ,
and args . model_revision != " None "
)
else { } ,
) . eval ( )
if args . cpu_only :
device_map = " cpu "
model . generation_config = GenerationConfig . from_pretrained (
" Qwen/Qwen-7B-Chat " , trust_remote_code = True , resume_download = True
)
if " exit " in args :
if args . exit :
sys . exit ( 0 )
else :
else :
del args . exit
device_map = " auto "
model = AutoModelForCausalLM . from_pretrained (
args . checkpoint_path ,
device_map = device_map ,
trust_remote_code = True ,
resume_download = True ,
) . eval ( )
model . generation_config = GenerationConfig . from_pretrained (
args . checkpoint_path , trust_remote_code = True , resume_download = True ,
)
if " model_revision " in args :
return model , tokenizer
del args . model_revision
def postprocess ( self , y ) :
def postprocess ( self , y ) :
@ -54,7 +62,7 @@ def postprocess(self, y):
return [ ]
return [ ]
for i , ( message , response ) in enumerate ( y ) :
for i , ( message , response ) in enumerate ( y ) :
y [ i ] = (
y [ i ] = (
None if message is None else mdtex2html . convert ( ( message ) ) ,
None if message is None else mdtex2html . convert ( message ) ,
None if response is None else mdtex2html . convert ( response ) ,
None if response is None else mdtex2html . convert ( response ) ,
)
)
return y
return y
@ -63,7 +71,7 @@ def postprocess(self, y):
gr . Chatbot . postprocess = postprocess
gr . Chatbot . postprocess = postprocess
def parse_text( text ) :
def _ parse_text( text ) :
lines = text . split ( " \n " )
lines = text . split ( " \n " )
lines = [ line for line in lines if line != " " ]
lines = [ line for line in lines if line != " " ]
count = 0
count = 0
@ -78,7 +86,7 @@ def parse_text(text):
else :
else :
if i > 0 :
if i > 0 :
if count % 2 == 1 :
if count % 2 == 1 :
line = line . replace ( " ` " , " \ ` " )
line = line . replace ( " ` " , r " \ ` " )
line = line . replace ( " < " , " < " )
line = line . replace ( " < " , " < " )
line = line . replace ( " > " , " > " )
line = line . replace ( " > " , " > " )
line = line . replace ( " " , " " )
line = line . replace ( " " , " " )
@ -95,70 +103,89 @@ def parse_text(text):
return text
return text
task_history = [ ]
def _launch_demo ( args , model , tokenizer ) :
task_history = [ ]
def predict ( query , chatbot ) :
print ( " User: " + parse_text ( query ) )
chatbot . append ( ( parse_text ( query ) , " " ) )
fullResponse = " "
for response in model . chat_stream ( tokenizer , query , history = task_history ) :
chatbot [ - 1 ] = ( parse_text ( query ) , parse_text ( response ) )
yield chatbot
fullResponse = parse_text ( response )
task_history . append ( ( query , fullResponse ) )
def predict ( _query , _chatbot ) :
print ( " Qwen-7B-Chat: " + parse_text ( fullResponse ) )
print ( " User: " + _parse_text ( _query ) )
_chatbot . append ( ( _parse_text ( _query ) , " " ) )
full_response = " "
for response in model . chat_stream ( tokenizer , _query , history = task_history ) :
_chatbot [ - 1 ] = ( _parse_text ( _query ) , _parse_text ( response ) )
def regenerate ( chatbot ) :
yield _chatbot
if not task_history :
full_response = _parse_text ( response )
yield chatbot
return
item = task_history . pop ( - 1 )
chatbot . pop ( - 1 )
yield from predict ( item [ 0 ] , chatbot )
task_history . append ( ( _query , full_response ) )
print ( " Qwen-7B-Chat: " + _parse_text ( full_response ) )
def reset_user_input ( ) :
def regenerate ( _chatbot ) :
return gr . update ( value = " " )
if not task_history :
yield _chatbot
return
item = task_history . pop ( - 1 )
_chatbot . pop ( - 1 )
yield from predict ( item [ 0 ] , _chatbot )
def reset_user_input ( ) :
return gr . update ( value = " " )
def reset_state ( ) :
def reset_state ( ) :
task_history . clear ( )
task_history . clear ( )
return [ ]
return [ ]
with gr . Blocks ( ) as demo :
with gr . Blocks ( ) as demo :
gr . Markdown ( """ <p align= " center " ><img src= " https://modelscope.cn/api/v1/models/qwen/Qwen-7B-Chat/repo?Revision=master&FilePath=assets/logo.jpeg&View=true " style= " height: 80px " /><p> """ )
gr . Markdown ( """ \
gr . Markdown ( """ <center><font size=8>Qwen-7B-Chat Bot</center> """ )
< p align = " center " > < img src = " https://modelscope.cn/api/v1/models/qwen/Qwen-7B-Chat/repo?
gr . Markdown (
Revision = master & FilePath = assets / logo . jpeg & View = true " style= " height : 80 px " /><p> " " " )
""" <center><font size=3>This WebUI is based on Qwen-7B-Chat, developed by Alibaba Cloud. (本WebUI基于Qwen-7B-Chat打造, 实现聊天机器人功能。)</center> """
gr . Markdown ( """ <center><font size=8>Qwen-7B-Chat Bot</center> """ )
)
gr . Markdown (
gr . Markdown (
""" \
""" <center><font size=4>Qwen-7B <a href= " https://modelscope.cn/models/qwen/Qwen-7B/summary " >🤖 <a> | <a href= " https://huggingface.co/Qwen/Qwen-7B " >🤗</a>  | Qwen-7B-Chat <a href= " https://modelscope.cn/models/qwen/Qwen-7B-Chat/summary " >🤖 <a>| <a href= " https://huggingface.co/Qwen/Qwen-7B-Chat " >🤗</a>  |  <a href= " https://github.com/QwenLM/Qwen-7B " >Github</a></center> """
< center > < font size = 3 > This WebUI is based on Qwen - 7 B - Chat , developed by Alibaba Cloud . \
( 本WebUI基于Qwen - 7 B - Chat打造 , 实现聊天机器人功能 。 ) < / center > """ )
gr . Markdown ( """ \
< center > < font size = 4 > Qwen - 7 B < a href = " https://modelscope.cn/models/qwen/Qwen-7B/summary " > 🤖 < / a >
| < a href = " https://huggingface.co/Qwen/Qwen-7B " > 🤗 < / a > & nbsp |
Qwen - 7 B - Chat < a href = " https://modelscope.cn/models/qwen/Qwen-7B-Chat/summary " > 🤖 < / a > |
< a href = " https://huggingface.co/Qwen/Qwen-7B-Chat " > 🤗 < / a > & nbsp |
& nbsp < a href = " https://github.com/QwenLM/Qwen-7B " > Github < / a > < / center > """ )
chatbot = gr . Chatbot ( label = ' Qwen-7B-Chat ' , elem_classes = " control-height " )
query = gr . Textbox ( lines = 2 , label = ' Input ' )
with gr . Row ( ) :
empty_btn = gr . Button ( " 🧹 Clear History (清除历史) " )
submit_btn = gr . Button ( " 🚀 Submit (发送) " )
regen_btn = gr . Button ( " 🤔️ Regenerate (重试) " )
submit_btn . click ( predict , [ query , chatbot ] , [ chatbot ] , show_progress = True )
submit_btn . click ( reset_user_input , [ ] , [ query ] )
empty_btn . click ( reset_state , outputs = [ chatbot ] , show_progress = True )
regen_btn . click ( regenerate , [ chatbot ] , [ chatbot ] , show_progress = True )
gr . Markdown ( """ \
< font size = 2 > Note : This demo is governed by the original license of Qwen - 7 B . \
We strongly advise users not to knowingly generate or allow others to knowingly generate harmful content , \
including hate speech , violence , pornography , deception , etc . \
( 注 : 本演示受Qwen - 7 B的许可协议限制 。 我们强烈建议 , 用户不应传播及不应允许他人传播以下内容 , \
包括但不限于仇恨言论 、 暴力 、 色情 、 欺诈相关的有害信息 。 ) """ )
demo . queue ( ) . launch (
share = args . share ,
inbrowser = args . inbrowser ,
server_port = args . server_port ,
server_name = args . server_name ,
)
)
chatbot = gr . Chatbot ( lines = 10 , label = ' Qwen-7B-Chat ' , elem_classes = " control-height " )
query = gr . Textbox ( lines = 2 , label = ' Input ' )
with gr . Row ( ) :
def main ( ) :
emptyBtn = gr . Button ( " 🧹 Clear History (清除历史) " )
args = _get_args ( )
submitBtn = gr . Button ( " 🚀 Submit (发送) " )
regenBtn = gr . Button ( " 🤔️ Regenerate (重试) " )
submitBtn . click ( predict , [ query , chatbot ] , [ chatbot ] , show_progress = True )
model , tokenizer = _load_model_tokenizer ( args )
submitBtn . click ( reset_user_input , [ ] , [ query ] )
emptyBtn . click ( reset_state , outputs = [ chatbot ] , show_progress = True )
_launch_demo ( args , model , tokenizer )
regenBtn . click ( regenerate , [ chatbot ] , [ chatbot ] , show_progress = True )
gr . Markdown (
""" <font size=2>Note: This demo is governed by the original license of Qwen-7B. We strongly advise users not to knowingly generate or allow others to knowingly generate harmful content, including hate speech, violence, pornography, deception, etc. (注: 本演示受Qwen-7B的许可协议限制。我们强烈建议, 用户不应传播及不应允许他人传播以下内容, 包括但不限于仇恨言论、暴力、色情、欺诈相关的有害信息。) """
)
if len ( sys . argv ) > 1 :
if __name__ == ' __main__ ' :
demo . queue ( ) . launch ( * * vars ( args ) )
main ( )
else :
demo . queue ( ) . launch ( )