File size: 1,692 Bytes
1fc8b87
 
 
f8beb9a
 
1fc8b87
 
f8beb9a
cfd825f
1fc8b87
e4c7064
f8beb9a
 
cfd825f
f8beb9a
 
cfd825f
f8beb9a
 
cfd825f
f8beb9a
 
 
 
 
 
 
 
 
 
5e2ff12
 
 
f8beb9a
 
 
 
 
 
 
 
cfd825f
f8beb9a
 
 
 
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
from transformers import BlenderbotTokenizer, BlenderbotForConditionalGeneration


import torch

chat_tkn = BlenderbotTokenizer.from_pretrained("facebook/blenderbot-400M-distill")
mdl = BlenderbotForConditionalGeneration.from_pretrained("facebook/blenderbot-400M-distill")

def converse(user_input, chat_history=[]):
    #tkn_ids = chat_tkn(input(">> User:") + chat_tkn.eos_token, return_tensors='pt')
    user_input_ids = chat_tkn(user_input + chat_tkn.eos_token, return_tensors='pt')

    # append the new user input tokens to the chat history
    bot_input_ids = torch.cat([torch.LongTensor(history), user_input_ids], dim=-1)

    # generate a response 
    history = mdl.generate(bot_input_ids, max_length=1000, pad_token_id=chat_tkn.eos_token_id).tolist()

    # convert the tokens to text, and then split the responses into lines
    response = chat_tkn.decode(chat_history[0]).split("<|endoftext|>")
    response.remove("")
    
    # write some HTML
    html = "<div class='chatbot'>"
    for m, msg in enumerate(response):
        cls = "user" if m%2 == 0 else "bot"
        html += "<div class='msg {}'> {}</div>".format(cls, msg)
    html += "</div>"
    
    return html, history

import gradio as gr

css = """
.chatbox {display:flex;flex-direction:column}
.msg {padding:4px;margin-bottom:4px;border-radius:4px;width:80%}
.msg.user {background-color:cornflowerblue;color:white}
.msg.bot {background-color:lightgray;align-self:self-end}
.footer {display:none !important}
"""

gr.Interface(fn=converse,
             theme="default",
             inputs=[gr.inputs.Textbox(placeholder="How are you?"), "state"],
             outputs=["html", "state"],
             css=css).launch()