2023-04-06 01:22:15 -03:00
|
|
|
import json
|
|
|
|
|
|
|
|
import gradio as gr
|
|
|
|
|
|
|
|
from modules import shared
|
|
|
|
from modules.text_generation import generate_reply
|
|
|
|
|
2023-04-14 12:11:47 -03:00
|
|
|
# set this to True to rediscover the fn_index using the browser DevTools
|
|
|
|
VISIBLE = False
|
|
|
|
|
2023-04-06 01:22:15 -03:00
|
|
|
|
|
|
|
def generate_reply_wrapper(string):
|
2023-04-16 17:33:28 -03:00
|
|
|
|
|
|
|
# Provide defaults so as to not break the API on the client side when new parameters are added
|
2023-04-06 01:22:15 -03:00
|
|
|
generate_params = {
|
2023-04-16 17:33:28 -03:00
|
|
|
'max_new_tokens': 200,
|
2023-04-06 01:22:15 -03:00
|
|
|
'do_sample': True,
|
2023-04-16 17:33:28 -03:00
|
|
|
'temperature': 0.5,
|
2023-04-06 01:22:15 -03:00
|
|
|
'top_p': 1,
|
|
|
|
'typical_p': 1,
|
2023-04-16 17:33:28 -03:00
|
|
|
'repetition_penalty': 1.1,
|
2023-04-06 01:22:15 -03:00
|
|
|
'encoder_repetition_penalty': 1,
|
2023-04-16 17:33:28 -03:00
|
|
|
'top_k': 0,
|
|
|
|
'min_length': 0,
|
|
|
|
'no_repeat_ngram_size': 0,
|
2023-04-06 01:22:15 -03:00
|
|
|
'num_beams': 1,
|
|
|
|
'penalty_alpha': 0,
|
|
|
|
'length_penalty': 1,
|
|
|
|
'early_stopping': False,
|
2023-04-16 17:33:28 -03:00
|
|
|
'seed': -1,
|
|
|
|
'add_bos_token': True,
|
|
|
|
'custom_stopping_strings': [],
|
|
|
|
'truncation_length': 2048,
|
|
|
|
'ban_eos_token': False,
|
|
|
|
'skip_special_tokens': True,
|
2023-04-06 01:22:15 -03:00
|
|
|
}
|
|
|
|
params = json.loads(string)
|
2023-04-16 17:33:28 -03:00
|
|
|
generate_params.update(params[1])
|
2023-04-06 01:22:15 -03:00
|
|
|
for i in generate_reply(params[0], generate_params):
|
|
|
|
yield i
|
|
|
|
|
2023-04-07 00:15:45 -03:00
|
|
|
|
2023-04-06 01:22:15 -03:00
|
|
|
def create_apis():
|
2023-04-14 12:11:47 -03:00
|
|
|
t1 = gr.Textbox(visible=VISIBLE)
|
|
|
|
t2 = gr.Textbox(visible=VISIBLE)
|
|
|
|
dummy = gr.Button(visible=VISIBLE)
|
2023-04-06 01:22:15 -03:00
|
|
|
|
|
|
|
input_params = [t1]
|
|
|
|
output_params = [t2] + [shared.gradio[k] for k in ['markdown', 'html']]
|
|
|
|
dummy.click(generate_reply_wrapper, input_params, output_params, api_name='textgen')
|