Spaces:
Sleeping
Sleeping
File size: 9,563 Bytes
b6d705d 445de93 06f94a3 445de93 06f94a3 445de93 06f94a3 445de93 178feb4 445de93 06f94a3 445de93 06f94a3 445de93 06f94a3 445de93 06f94a3 445de93 d90e9a6 445de93 06f94a3 445de93 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 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 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 | ---
title: Morphos
emoji: 🐕
colorFrom: blue
colorTo: green
sdk: docker
pinned: false
---
# Morphos — Intérprete de analíticas veterinarias asistido por I.A
## Proyecto final — Curso de Desarrollo Web 2026
---
## Descripción
Morphos es una aplicación web de apoyo al diagnóstico veterinario. Detecta patrones clínicos en tiempo real a partir de valores de laboratorio usando un motor propio de JS puro con la opción de interpretarlos mediante un modelo de inteligencia artificial especializado en medicina (medGemma 1.5 4B it multimodal de Google Deep Mind), incluye una sección de búsqueda de artículos cientíticos en PubMed relacionados con los diagnósticos diferenciales del paciente.
Está orientada a caninos y felinos, con ajuste automático de rangos de referencia por especie, edad, raza y sexo.
Ataca una necesidad real del sector veterinario que actualmente no dispone de herramientas de este tipo que sean gratuitas y de fácil uso y que permitan obtener información complementaria relevante sobre sus pacientes en muy poco tiempo y sin exponer la data sensible a los LLM.
Funcionalidades principales:
```text
Detección de patrones clínicos en tiempo real con motor nativo de JS
Interpretación con IA (HuggingFace o Ollama local)
Importación de resultados desde PDF
Análisis de citologías mediante imágenes
Búsqueda de literatura científica en PubMed
Sistema de autenticación con registro e inicio de sesión
```
---
## Objetivo del proyecto
Integrar los conocimientos del curso en una aplicación web completa que además sea útil y
cubra una necesidad de mercado:
```text
HTML semántico y accesible
CSS personalizado (variables, grid, responsive)
JavaScript modular
Sin uso de frameworks
PHP como backend de API (proxy, autenticación, base de datos)
```
Conceptos aplicados:
* Separación de responsabilidades por módulos
* Comunicación asíncrona con `fetch` (JSON y SSE)
* Sesiones PHP y autenticación con PDO
* Contraseñas hasheadas con `password_hash`
* Consultas preparadas para prevenir inyección SQL
* Detección de patrones mediante lógica clínica codificada
---
## Estructura del proyecto
```text
/api
auth.php → login, registro y cierre de sesión (PDO + sesiones)
conexion.php → conexión a la base de datos MySQL
hf_proxy.php → proxy hacia HuggingFace Space (oculta la API key)
papers_proxy.php → consulta PubMed con caché de 30 minutos
setup.php → crea la base de datos y la tabla de usuarios
.env → variables de entorno (HF_API_KEY, DB_PORT)
/js
main.js → orquestación general, eventos y renderizado
analisis.js → motor de detección de patrones clínicos
ia.js → construcción del prompt y llamadas al modelo IA
ui.js → navegación por tabs, gestos, sincronización móvil
auth.js → modal de autenticación y validación en tiempo real
papers.js → búsqueda y paginación de literatura científica
pdf-parser.js → extracción de valores desde PDF en el navegador
/css
styles.css → estilos completos (tema claro/oscuro, grid, mobile)
/data
valores_referencia.json → rangos de referencia por especie y analito
alteraciones.json → descripciones clínicas de los patrones
/assets
/fonts → Inter y JetBrains Mono (carga local)
/icons → iconos SVG de la interfaz
/lib/pdfjs → librería PDF.js en local
index.html → SPA principal
.htaccess → compresión, caché y protección de archivos sensibles
```
---
## Flujo de la aplicación
```text
[ Formulario de valores ]
|
v
analisis.js
(deteccion de patrones en tiempo real, sin servidor)
|
v
[ UI: campos coloreados + tarjetas de patron ]
|
v
Usuario pulsa "Analisis IA"
|
v
ia.js (construye el prompt con los hallazgos)
|
┌─┴──────────────┐
v v
HuggingFace Ollama local
(hf_proxy.php) (/v1/chat/completions)
| |
└────────┬────────┘
v
[ Interpretacion en pantalla ]
```
---
## Instalacion
### 1. Requisitos
* XAMPP (Apache + PHP 8.1+ + MySQL)
* El proyecto ubicado en `htdocs/morphos_proyecto_final/`
### 2. Variables de entorno
Crear el archivo `api/.env`:
```text
HF_API_KEY=tu_clave_de_huggingface
DB_PORT=3306
```
### 3. Base de datos
Acceder en el navegador a:
```text
http://localhost/morphos_proyecto_final/api/setup.php
```
Esto crea la base de datos `morphos_db` y la tabla `usuarios`. El archivo puede eliminarse tras ejecutarse.
### 4. Iniciar la aplicacion
Iniciar Apache y MySQL desde el panel de XAMPP y abrir:
```text
http://localhost/morphos_proyecto_final/
```
O bien con el servidor integrado de PHP desde la raiz del proyecto:
```bash
php -S localhost:8000
```
## Backend de IA
El modelo de IA se configura desde la propia interfaz. La seleccion se guarda en `localStorage`.
| Opcion | Descripcion |
| ------------------------- | -------------------------------------------------------------------------- |
| HuggingFace (por defecto) | Llama al Space `blackmistcode-morphos-medgemma` a traves del proxy PHP |
| Local (Ollama) | Llama directamente a `http://localhost:11434` con `medgemma1.5:latest` |
Para usar Ollama, debe estar ejecutandose con `ollama serve` y el modelo descargado.
---
## Motor de deteccion de patrones
`analisis.js` compara cada valor ingresado contra los rangos de referencia del JSON, ajustados dinamicamente segun:
* **Especie**: canino / felino
* **Edad**: cachorro, adulto, senior, geriatrico
* **Raza**: galgo/whippet (RBC y plaquetas), Shiba/Akita (RBC)
* **Sexo**: felinos machos tienen mayor tolerancia a creatinina
La gravedad se calcula como la desviacion relativa al ancho del rango de referencia. Con los hallazgos se identifican mas de 50 patrones clinicos (anemias, hepatopatias, nefropatia, alteraciones endocrinas, electrolitos, entre otros).
---
## Seguridad aplicada
* Consultas SQL con sentencias preparadas (sin interpolacion directa)
* Contrasenas hasheadas con `password_hash` / `password_verify`
* API key de HuggingFace protegida en servidor, nunca expuesta al cliente
* Archivos `.env` y `setup.php` bloqueados por `.htaccess`
* Datos externos de APIs sanitizados con `textContent` antes de insertarse en el DOM
* Sin uso de `eval`, `document.write` ni `innerHTML` con datos externos
---
## Conceptos del curso aplicados
* HTML5 semantico
* CSS personalizado: variables, fuentes fluidas, grid, flexbox, media queries, temas claro/oscuro
* JavaScript: ES Modules, `fetch`, `async/await`, eventos, DOM API
* PHP: sesiones, PDO, proxy HTTP con cURL, lectura de `.env`, caché en disco
* MariaDB: creacion de tablas, consultas con parametros, indices unicos
---
## Mejoras futuras
* Implementación de dashboard de administrador
* Desarrollo de extensión de navegador para captar datos del DOM de PIMS y obtener los datos de los analisis de los pacientes con intervención mínima del usuario
* Desarrollo de mobile app dedicada
* Integración con PIMS más utilizados en veterinaria
* Rankeo de papers basado en confiabilidad y relevancia
* Creación de Dataset específico para citologías de animales
* Hosting del modelo en VPS serverless para finetuning y menor latencia
* Ampliación de la base de alteraciones
* Parseo con OCR de fotografías de analíticas
* Incluir resultados de gasometría, coprologías, informes de histopatologías y tiempos de coagulación
## Retos
* Por la diversidad de unidades de medición que utilizan los diferentes fabricantes de equipos de laboratorio se incorporó una detección de unidades para su conversión y normalización
* El modelado del output de la I.A requirió muchísimas iteraciones de formateo del prompt y harness para evitar alucinaciones o que envíara su proceso de pensamiento, aún requiere de mucho trabajo extra de refinamiento
* Inicialmente quería usar proveedores de inferencia gratuita de medGemma (como featherless AI) pero fallaban continuamente, por eso decidí optar por hostear al modelo en Zero GPU de HF con la subscripción pro para la prueba de concepto
* Incluir las librería de parseo de pdf y las fuentes en el directorio del proyecto con la intención de reducir dependencias externas estaba generando problemas con las métricas de velocidad de lighthouse que no lograba solucionar. Claude planteó implementación de caché en htacesss y pre carga de las fuentes, lo cual llevó la puntuación de 60 a 90/100 sin mayores cambios estructurales
* Lograr una interfaz limpia y entendible requirío de muchos intentos hasta lograr un flujo de trabajo intuitivo y accsesible con la mínima friccion posible para los usuarios
* La API de PubMed sólo admite input en inglés, así que implementó un objeto con traducciones de los patrones clínicos más comúnes para poder realizar las peticiones
## Notas
* `api/setup.php` puede eliminarse una vez creada la base de datos
* El parser de PDF funciona completamente en el navegador (sin subida al servidor) para evitar enviar información privada al modelo de IA.
* La busqueda de literatura filtra los patrones detectados, los traduce al ingles y consulta PubMed via `esearch` + `esummary`
|