locorene1000 commited on
Commit
1710428
1 Parent(s): 6ec646e
Files changed (2) hide show
  1. app.py +82 -62
  2. requirements.txt +4 -1
app.py CHANGED
@@ -1,63 +1,83 @@
1
  import gradio as gr
2
- from huggingface_hub import InferenceClient
3
-
4
- """
5
- For more information on `huggingface_hub` Inference API support, please check the docs: https://huggingface.co/docs/huggingface_hub/v0.22.2/en/guides/inference
6
- """
7
- client = InferenceClient("HuggingFaceH4/zephyr-7b-beta")
8
-
9
-
10
- def respond(
11
- message,
12
- history: list[tuple[str, str]],
13
- system_message,
14
- max_tokens,
15
- temperature,
16
- top_p,
17
- ):
18
- messages = [{"role": "system", "content": system_message}]
19
-
20
- for val in history:
21
- if val[0]:
22
- messages.append({"role": "user", "content": val[0]})
23
- if val[1]:
24
- messages.append({"role": "assistant", "content": val[1]})
25
-
26
- messages.append({"role": "user", "content": message})
27
-
28
- response = ""
29
-
30
- for message in client.chat_completion(
31
- messages,
32
- max_tokens=max_tokens,
33
- stream=True,
34
- temperature=temperature,
35
- top_p=top_p,
36
- ):
37
- token = message.choices[0].delta.content
38
-
39
- response += token
40
- yield response
41
-
42
- """
43
- For information on how to customize the ChatInterface, peruse the gradio docs: https://www.gradio.app/docs/chatinterface
44
- """
45
- demo = gr.ChatInterface(
46
- respond,
47
- additional_inputs=[
48
- gr.Textbox(value="You are a friendly Chatbot.", label="System message"),
49
- gr.Slider(minimum=1, maximum=2048, value=512, step=1, label="Max new tokens"),
50
- gr.Slider(minimum=0.1, maximum=4.0, value=0.7, step=0.1, label="Temperature"),
51
- gr.Slider(
52
- minimum=0.1,
53
- maximum=1.0,
54
- value=0.95,
55
- step=0.05,
56
- label="Top-p (nucleus sampling)",
57
- ),
58
- ],
59
- )
60
-
61
-
62
- if __name__ == "__main__":
63
- demo.launch()
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
  import gradio as gr
2
+ import requests
3
+ import logging
4
+ import os
5
+
6
+ # Leer el token de Hugging Face desde las variables de entorno
7
+ HUGGING_FACE_TOKEN = os.getenv("HUGGING_FACE_TOKEN")
8
+ API_URL = "https://api-inference.huggingface.co/models/meta-llama/Meta-Llama-3-70B-Instruct"
9
+
10
+ headers = {"Authorization": f"Bearer {HUGGING_FACE_TOKEN}"}
11
+
12
+ # Configurar el logger
13
+ logging.basicConfig(filename='interactions.log', level=logging.INFO,
14
+ format='%(asctime)s - %(levelname)s - %(message)s')
15
+
16
+ def query(api_url, headers, payload):
17
+ try:
18
+ response = requests.post(api_url, headers=headers, json=payload)
19
+ response.raise_for_status()
20
+ return response.json()
21
+ except requests.exceptions.RequestException as e:
22
+ error_message = f"Error durante la solicitud: {e}"
23
+ if e.response:
24
+ error_message += f" C贸digo de estado: {e.response.status_code} Respuesta del servidor: {e.response.text}"
25
+ logging.error(error_message)
26
+ return {"error": error_message}
27
+
28
+ def preparar_texto(contexto, borrador):
29
+ return f"{contexto}\n\n{borrador}"
30
+
31
+ def mejorar_resolucion(context, borrador, api_url, headers, max_length=1000):
32
+ prompt = preparar_texto(context, borrador)
33
+ payload = {
34
+ "inputs": prompt,
35
+ "parameters": {
36
+ "max_new_tokens": max_length,
37
+ "temperature": 0.7,
38
+ "top_p": 0.9,
39
+ "top_k": 50,
40
+ "repetition_penalty": 1.2,
41
+ "return_full_text": False,
42
+ "do_sample": True,
43
+ }
44
+ }
45
+
46
+ result = query(api_url, headers, payload)
47
+
48
+ if result and isinstance(result, list) and 'generated_text' in result[0]:
49
+ texto_generado = result[0]['generated_text']
50
+ context += f"\n\n{texto_generado}"
51
+ logging.info(f"Prompt: {prompt}\nGenerated: {texto_generado.strip()}")
52
+ return texto_generado.strip(), context
53
+ else:
54
+ error_message = result.get("error", "No se pudo obtener la respuesta del modelo.")
55
+ logging.error(f"Prompt: {prompt}\nError: {error_message}")
56
+ return None, context
57
+
58
+ # Funci贸n de predicci贸n para la interfaz de Gradio
59
+ def predict(message, history):
60
+ context = (
61
+ "Asume el papel de asistente legal especializado en derecho chileno. Tu meta es optimizar resoluciones judiciales utilizando procesamiento de lenguaje natural (PLN). "
62
+ "Mant茅n un tono formal, preciso y autoritativo en todo momento. Como requierase, autoricese, apercibase, entre otros. "
63
+ "Sigue estrictamente las gu铆as de estilo proporcionadas. Simplifica oraciones complejas y elimina redundancias. Adapta la terminolog铆a al contexto legal chileno. "
64
+ "Aseg煤rate de que las resoluciones optimizadas sean claras, concisas y libres de ambig眉edades. Utiliza par谩frasis, analog铆as y ejemplos para mejorar la claridad. "
65
+ "Revisa documentos de referencia. Identifica inconsistencias, ambig眉edades y redundancias. Simplifica oraciones complejas y elimina redundancias. "
66
+ "Realiza una revisi贸n gramatical y estil铆stica para asegurar precisi贸n y formalidad. Justifica las modificaciones necesarias. Explica c贸mo cada mejora contribuye a la formalidad, precisi贸n y claridad. "
67
+ "Proporciona la Resoluci贸n Optimizada. Verifica que la resoluci贸n optimizada cumpla con los criterios de claridad, precisi贸n y formalidad. Asegura que todas las modificaciones est茅n justificadas y sean comprensibles."
68
+ )
69
+
70
+ history_transformer_format = history + [[message, ""]]
71
+ for item in history_transformer_format:
72
+ context += f"\n\n{item[0]}"
73
+
74
+ resolucion_mejorada, context = mejorar_resolucion(context, message, API_URL, headers, max_length=1000)
75
+ if resolucion_mejorada:
76
+ history.append([message, resolucion_mejorada])
77
+ return resolucion_mejorada
78
+ else:
79
+ return "No se pudo mejorar la resoluci贸n."
80
+
81
+ # Crear y lanzar la interfaz de Gradio
82
+ iface = gr.ChatInterface(predict)
83
+ iface.launch()
requirements.txt CHANGED
@@ -1 +1,4 @@
1
- huggingface_hub==0.22.2
 
 
 
 
1
+ huggingface_hub==0.22.2
2
+ numpy<2.0.0
3
+ gradio
4
+ requests