Spaces:
Running
Running
import gradio as gr | |
from gradio_client import Client | |
from huggingface_hub import get_token, InferenceClient | |
from llama_cpp import Llama | |
llm = Llama.from_pretrained( | |
repo_id="HuggingFaceTB/SmolLM2-360M-Instruct-GGUF", | |
filename="smollm2-360m-instruct-q8_0.gguf", | |
verbose=False, | |
) | |
def generate( | |
user_prompt: str, | |
system_prompt: str = "You are a helpful assistant.", | |
max_tokens: int = 4000, | |
temperature: float = 0.2, | |
top_p: float = 0.95, | |
top_k: int = 40, | |
presence_penalty: float = 0.0, | |
frequency_penalty: float = 0.0, | |
): | |
messages = [ | |
{"role": "system", "content": system_prompt}, | |
{"role": "user", "content": user_prompt}, | |
] | |
return llm.create_chat_completion( | |
messages, | |
max_tokens=max_tokens, | |
temperature=temperature, | |
top_p=top_p, | |
top_k=top_k, | |
presence_penalty=presence_penalty, | |
frequency_penalty=frequency_penalty, | |
) | |
with gr.Blocks() as demo: | |
gr.Markdown("""# RAG - generate | |
Generate a response to a query using a [HuggingFaceTB/SmolLM2-360M-Instruct and llama-cpp-python](https://huggingface.co./HuggingFaceTB/SmolLM2-360M-Instruct-GGUF?library=llama-cpp-python). | |
Part of [ai-blueprint](https://github.com/davidberenstein1957/ai-blueprint) - a blueprint for AI development, focusing on applied examples of RAG, information extraction, analysis and fine-tuning in the age of LLMs and agents.""") | |
with gr.Row(): | |
system_prompt = gr.Textbox(label="System prompt", lines=3) | |
user_prompt = gr.Textbox(label="Query", lines=3) | |
with gr.Accordion("kwargs"): | |
with gr.Row(variant="panel"): | |
max_tokens = gr.Number(label="Max tokens", value=512) | |
temperature = gr.Number(label="Temperature", value=0.2) | |
top_p = gr.Number(label="Top p", value=0.95) | |
top_k = gr.Number(label="Top k", value=40) | |
submit_btn = gr.Button("Submit") | |
response_output = gr.Textbox(label="Response", lines=10) | |
documents_output = gr.Dataframe( | |
label="Documents", headers=["chunk", "url", "distance", "rank"], wrap=True | |
) | |
submit_btn.click( | |
fn=generate, | |
inputs=[ | |
user_prompt, | |
system_prompt, | |
max_tokens, | |
temperature, | |
top_p, | |
top_k, | |
], | |
outputs=[response_output], | |
) | |
demo.launch() | |