Spaces:
Sleeping
Sleeping
Update modules/studentact/current_situation_interface.py
Browse files
modules/studentact/current_situation_interface.py
CHANGED
|
@@ -114,64 +114,76 @@ def display_current_situation_interface(lang_code, nlp_models, t):
|
|
| 114 |
|
| 115 |
def display_radar_chart(metrics):
|
| 116 |
"""
|
| 117 |
-
Muestra un gráfico de radar con las
|
| 118 |
"""
|
| 119 |
try:
|
| 120 |
-
#
|
| 121 |
-
|
| 122 |
-
|
| 123 |
-
|
| 124 |
-
|
| 125 |
-
|
| 126 |
-
|
| 127 |
-
|
| 128 |
-
|
| 129 |
-
|
| 130 |
-
|
| 131 |
-
|
| 132 |
-
|
| 133 |
-
|
| 134 |
-
|
| 135 |
-
|
| 136 |
-
|
| 137 |
-
|
| 138 |
-
|
| 139 |
-
|
| 140 |
-
|
| 141 |
-
|
| 142 |
-
|
| 143 |
-
|
| 144 |
-
|
| 145 |
-
|
| 146 |
-
|
| 147 |
-
|
| 148 |
-
|
| 149 |
-
|
| 150 |
-
|
| 151 |
-
|
| 152 |
-
|
| 153 |
-
|
| 154 |
-
|
| 155 |
-
|
| 156 |
-
|
| 157 |
-
|
| 158 |
-
|
| 159 |
-
|
| 160 |
-
|
| 161 |
-
|
| 162 |
-
|
| 163 |
-
|
| 164 |
-
|
| 165 |
-
|
| 166 |
-
|
| 167 |
-
|
| 168 |
-
|
| 169 |
-
|
| 170 |
-
|
| 171 |
-
|
| 172 |
-
|
| 173 |
-
|
| 174 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 175 |
|
| 176 |
except Exception as e:
|
| 177 |
logger.error(f"Error generando gráfico de radar: {str(e)}")
|
|
|
|
| 114 |
|
| 115 |
def display_radar_chart(metrics):
|
| 116 |
"""
|
| 117 |
+
Muestra un gráfico de radar con las métricas del usuario y el patrón ideal.
|
| 118 |
"""
|
| 119 |
try:
|
| 120 |
+
# Container con proporción reducida
|
| 121 |
+
with st.container():
|
| 122 |
+
# Métricas en la parte superior
|
| 123 |
+
col1, col2, col3, col4 = st.columns(4)
|
| 124 |
+
with col1:
|
| 125 |
+
st.metric("Vocabulario", f"{metrics['vocabulary']['normalized_score']:.2f}", "1.00")
|
| 126 |
+
with col2:
|
| 127 |
+
st.metric("Estructura", f"{metrics['structure']['normalized_score']:.2f}", "1.00")
|
| 128 |
+
with col3:
|
| 129 |
+
st.metric("Cohesión", f"{metrics['cohesion']['normalized_score']:.2f}", "1.00")
|
| 130 |
+
with col4:
|
| 131 |
+
st.metric("Claridad", f"{metrics['clarity']['normalized_score']:.2f}", "1.00")
|
| 132 |
+
|
| 133 |
+
# Contenedor para el gráfico con ancho controlado
|
| 134 |
+
_, graph_col, _ = st.columns([1,2,1])
|
| 135 |
+
|
| 136 |
+
with graph_col:
|
| 137 |
+
# Preparar datos
|
| 138 |
+
categories = ['Vocabulario', 'Estructura', 'Cohesión', 'Claridad']
|
| 139 |
+
values_user = [
|
| 140 |
+
metrics['vocabulary']['normalized_score'],
|
| 141 |
+
metrics['structure']['normalized_score'],
|
| 142 |
+
metrics['cohesion']['normalized_score'],
|
| 143 |
+
metrics['clarity']['normalized_score']
|
| 144 |
+
]
|
| 145 |
+
values_pattern = [1.0, 1.0, 1.0, 1.0] # Patrón ideal
|
| 146 |
+
|
| 147 |
+
# Crear figura más compacta
|
| 148 |
+
fig = plt.figure(figsize=(6, 6))
|
| 149 |
+
ax = fig.add_subplot(111, projection='polar')
|
| 150 |
+
|
| 151 |
+
# Número de variables
|
| 152 |
+
num_vars = len(categories)
|
| 153 |
+
|
| 154 |
+
# Calcular ángulos
|
| 155 |
+
angles = [n / float(num_vars) * 2 * np.pi for n in range(num_vars)]
|
| 156 |
+
angles += angles[:1]
|
| 157 |
+
|
| 158 |
+
# Extender valores para cerrar polígonos
|
| 159 |
+
values_user += values_user[:1]
|
| 160 |
+
values_pattern += values_pattern[:1]
|
| 161 |
+
|
| 162 |
+
# Configurar ejes y etiquetas
|
| 163 |
+
ax.set_xticks(angles[:-1])
|
| 164 |
+
ax.set_xticklabels(categories, fontsize=8)
|
| 165 |
+
|
| 166 |
+
# Círculos concéntricos y etiquetas
|
| 167 |
+
circle_ticks = np.arange(0, 1.1, 0.2) # Reducido a 5 niveles
|
| 168 |
+
ax.set_yticks(circle_ticks)
|
| 169 |
+
ax.set_yticklabels([f'{tick:.1f}' for tick in circle_ticks], fontsize=8)
|
| 170 |
+
ax.set_ylim(0, 1)
|
| 171 |
+
|
| 172 |
+
# Dibujar patrón ideal
|
| 173 |
+
ax.plot(angles, values_pattern, 'g--', linewidth=1, label='Patrón', alpha=0.5)
|
| 174 |
+
ax.fill(angles, values_pattern, 'g', alpha=0.1)
|
| 175 |
+
|
| 176 |
+
# Dibujar valores del usuario
|
| 177 |
+
ax.plot(angles, values_user, 'b-', linewidth=2, label='Tu escritura')
|
| 178 |
+
ax.fill(angles, values_user, 'b', alpha=0.2)
|
| 179 |
+
|
| 180 |
+
# Leyenda
|
| 181 |
+
ax.legend(loc='upper right', bbox_to_anchor=(0.1, 0.1), fontsize=8)
|
| 182 |
+
|
| 183 |
+
# Ajustes finales
|
| 184 |
+
plt.tight_layout()
|
| 185 |
+
st.pyplot(fig)
|
| 186 |
+
plt.close()
|
| 187 |
|
| 188 |
except Exception as e:
|
| 189 |
logger.error(f"Error generando gráfico de radar: {str(e)}")
|