cesar commited on
Commit
61e86f1
verified
1 Parent(s): c17f7e8

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +35 -44
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.75,
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
- # Codificar los datos de los PDFs a base64
54
- document1 = Part.from_data(
55
- mime_type="application/pdf",
56
- data=base64.b64encode(docente_data).decode("utf-8"),
57
- )
58
-
59
- document2 = Part.from_data(
60
- mime_type="application/pdf",
61
- data=base64.b64encode(alumno_data).decode("utf-8"),
62
- )
63
-
64
- # Configuraci贸n del texto de instrucciones
65
- text1 = """Informaci贸n del examen
66
- Materia: bioquimica nutricion normal
67
- Grado/Nivel: universidad
68
- Tema: Metabolismo de lipidos
69
- Formato del examen: \\\"Preguntas de desarrollo\\\"
70
- Instrucciones para el asistente
71
- Adjunta los archivos PDF:integracion
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: