Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -7,8 +7,8 @@ import os
|
|
7 |
# Configuraci贸n del modelo y par谩metros globales
|
8 |
generation_config = {
|
9 |
"max_output_tokens": 8192,
|
10 |
-
"temperature": 0,
|
11 |
-
"top_p": 0.
|
12 |
}
|
13 |
|
14 |
safety_settings = [
|
@@ -34,6 +34,20 @@ def configurar_credenciales(json_path):
|
|
34 |
"""Configura las credenciales de Google Cloud usando un archivo JSON."""
|
35 |
os.environ["GOOGLE_APPLICATION_CREDENTIALS"] = json_path
|
36 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
37 |
def revisar_examen(json_path, pdf_docente, pdf_alumno):
|
38 |
"""Funci贸n principal para comparar los PDFs del docente y del alumno."""
|
39 |
try:
|
@@ -50,48 +64,25 @@ def revisar_examen(json_path, pdf_docente, pdf_alumno):
|
|
50 |
with open(pdf_alumno.name, "rb") as alumno_file:
|
51 |
alumno_data = alumno_file.read()
|
52 |
|
53 |
-
#
|
54 |
-
|
55 |
-
|
56 |
-
|
57 |
-
|
58 |
-
|
59 |
-
|
60 |
-
|
61 |
-
|
62 |
-
|
63 |
-
|
64 |
-
|
65 |
-
|
66 |
-
|
67 |
-
|
68 |
-
|
69 |
-
|
70 |
-
|
71 |
-
|
72 |
-
PDF del alumno: alumno
|
73 |
-
Solicita la revisi贸n: \\\"Por favor, compara las respuestas del alumno en el PDF adjunto con las preguntas y respuestas del PDF del docente. Eval煤a cada respuesta como 'Correcta', 'Incorrecta', 'Incompleta' o 'Vac铆a'. Considera que el alumno solo respondi贸 a un subconjunto de las preguntas del examen. Para cada pregunta, indica si fue 'Asignada' o 'No asignada' al alumno. Proporciona retroalimentaci贸n detallada para cada respuesta de las preguntas asignadas, incluyendo la explicaci贸n de errores, la respuesta correcta (del PDF del docente) y sugerencias de temas para reforzar. Al final, ofrece una retroalimentaci贸n general sobre el desempe帽o del alumno y calcula el porcentaje de precisi贸n, bas谩ndote solo en las preguntas que le fueron asignadas.\\\""""
|
74 |
-
|
75 |
-
textsi_1 = """Rol: Act煤a como un asistente de docente experto en la materia del examen de Bioquimica.
|
76 |
-
Objetivo: Tu tarea principal es analizar las respuestas del alumno a las preguntas del examen, compar谩ndolas con la clave de respuestas y criterios de evaluaci贸n proporcionados en el PDF del docente. Debes identificar las respuestas correctas, incorrectas, incompletas y vac铆as, tomando en cuenta que el alumno pudo haber recibido un subconjunto aleatorio de las preguntas del examen. Proporciona retroalimentaci贸n detallada sobre los errores, 谩reas de mejora y temas que el alumno necesita reforzar. Adem谩s, debes calcular y mostrar el porcentaje de precisi贸n del alumno en el examen, considerando solo las preguntas que le fueron asignadas."""
|
77 |
-
|
78 |
-
# Configurar el modelo
|
79 |
-
model = GenerativeModel(
|
80 |
-
"gemini-1.5-pro-001", # Cambiar a Gemini-2
|
81 |
-
system_instruction=[textsi_1]
|
82 |
-
)
|
83 |
-
|
84 |
-
# Generar la revisi贸n
|
85 |
-
response = model.generate_content(
|
86 |
-
[document1, document2, text1],
|
87 |
-
generation_config=generation_config,
|
88 |
-
safety_settings=safety_settings,
|
89 |
-
stream=False,
|
90 |
-
)
|
91 |
-
|
92 |
-
# Acceder al texto de la respuesta
|
93 |
-
feedback = response.text
|
94 |
-
|
95 |
return feedback
|
96 |
|
97 |
except Exception as e:
|
|
|
7 |
# Configuraci贸n del modelo y par谩metros globales
|
8 |
generation_config = {
|
9 |
"max_output_tokens": 8192,
|
10 |
+
"temperature": 0.75,
|
11 |
+
"top_p": 0.95,
|
12 |
}
|
13 |
|
14 |
safety_settings = [
|
|
|
34 |
"""Configura las credenciales de Google Cloud usando un archivo JSON."""
|
35 |
os.environ["GOOGLE_APPLICATION_CREDENTIALS"] = json_path
|
36 |
|
37 |
+
def extraer_respuestas(pdf_data):
|
38 |
+
"""Simula la extracci贸n de preguntas y respuestas desde un PDF."""
|
39 |
+
# Aqu铆 puedes usar bibliotecas como PyPDF2 para procesar el contenido del PDF
|
40 |
+
# Por simplicidad, asumiremos texto plano (esto es un ejemplo)
|
41 |
+
texto_extraido = base64.b64decode(pdf_data).decode("utf-8", errors="ignore")
|
42 |
+
preguntas_respuestas = {}
|
43 |
+
for linea in texto_extraido.split("\n"):
|
44 |
+
if "Pregunta" in linea:
|
45 |
+
pregunta = linea
|
46 |
+
preguntas_respuestas[pregunta] = ""
|
47 |
+
elif "Respuesta" in linea:
|
48 |
+
preguntas_respuestas[pregunta] = linea.split(":")[-1].strip()
|
49 |
+
return preguntas_respuestas
|
50 |
+
|
51 |
def revisar_examen(json_path, pdf_docente, pdf_alumno):
|
52 |
"""Funci贸n principal para comparar los PDFs del docente y del alumno."""
|
53 |
try:
|
|
|
64 |
with open(pdf_alumno.name, "rb") as alumno_file:
|
65 |
alumno_data = alumno_file.read()
|
66 |
|
67 |
+
# Extraer preguntas y respuestas del docente y del alumno
|
68 |
+
preguntas_docente = extraer_respuestas(docente_data)
|
69 |
+
respuestas_alumno = extraer_respuestas(alumno_data)
|
70 |
+
|
71 |
+
# Construir la retroalimentaci贸n manualmente para evitar "alucinaciones"
|
72 |
+
retroalimentacion = []
|
73 |
+
for pregunta, respuesta_correcta in preguntas_docente.items():
|
74 |
+
respuesta_alumno = respuestas_alumno.get(pregunta, "No respondida")
|
75 |
+
if respuesta_alumno == "No respondida":
|
76 |
+
retroalimentacion.append(f"Pregunta: {pregunta}\nNo fue asignada al alumno.\n")
|
77 |
+
else:
|
78 |
+
retroalimentacion.append(
|
79 |
+
f"Pregunta: {pregunta}\n"
|
80 |
+
f"Respuesta del alumno: {respuesta_alumno}\n"
|
81 |
+
f"Respuesta correcta: {respuesta_correcta}\n"
|
82 |
+
)
|
83 |
+
|
84 |
+
# Unir la retroalimentaci贸n en un solo texto
|
85 |
+
feedback = "\n".join(retroalimentacion)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
86 |
return feedback
|
87 |
|
88 |
except Exception as e:
|