File size: 2,812 Bytes
5d67a3b 8d201a1 2a98158 8d201a1 5d67a3b 8d201a1 |
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 |
"""Streamlit app for demoing SambaCoder-nsql-llama-2-70b."""
import json
import os
import pandas as pd
import requests
import streamlit as st
from manifest import Manifest, Response
from manifest.connections.client_pool import ClientConnection
STOP_TOKENS = ["###", ";", "--", "```"]
def generate_prompt(question, schema):
return f"""{schema}\n\n\n-- Using valid SQLite, answer the following questions for the tables provided above.\n\n-- {question}\n"""
def generate_sql(question, schema):
prompt = generate_prompt(question, schema)
url = st.secrets["backend_url"]
headers = {
"Content-Type": "application/json",
"key": st.secrets["key"],
}
data = {
"inputs": [prompt],
"params": {
"do_sample": {"type": "bool", "value": "false"},
"max_tokens_to_generate": {"type": "int", "value": "1000"},
"repetition_penalty": {"type": "float", "value": "1"},
"temperature": {"type": "float", "value": "1"},
"top_k": {"type": "int", "value": "50"},
"top_p": {"type": "float", "value": "1"},
"process_prompt":{"type":"bool","value":"false"},
"select_expert":{"type":"str","value":"SambaCoder-nsql-llama-2-70b"}
},
}
r = requests.post(url, headers=headers, data=json.dumps(data), stream=True)
if r.encoding is None:
r.encoding = "utf-8"
for line in r.iter_lines(decode_unicode=True):
if line and line.startswith("data: "):
output = json.loads(line[len("data: ") :])
token = output.get("stream_token", "")
if len(token) > 0:
yield token
st.title("SambaCoder-nsql-llama-2-70b Demo")
expander = st.expander("Database Schema")
# Input field for text prompt
# TODO(Bo Li): update this with the new example
default_schema = """CREATE TABLE stadium (
stadium_id number,
location text,
name text,
capacity number,
highest number,
lowest number,
average number
)
CREATE TABLE singer (
singer_id number,
name text,
country text,
song_name text,
song_release_year text,
age number,
is_male others
)
CREATE TABLE concert (
concert_id number,
concert_name text,
theme text,
stadium_id text,
year text
)
CREATE TABLE singer_in_concert (
concert_id number,
singer_id text
)"""
schema = expander.text_area("Current schema:", value=default_schema, height=500)
# Input field for text prompt
text_prompt = st.text_input(
"Please let me know what question do you want to ask?",
value="What is the maximum, the average, and the minimum capacity of stadiums ?",
)
# if text_prompt or
if st.button("Generate SQL"):
sql_query = generate_sql(text_prompt, schema)
st.write_stream(sql_query)
|