erp-construccion/docs/02-definicion-modulos/MAI-005-control-obra
2026-01-04 06:12:06 -06:00
..
especificaciones Initial commit - erp-construccion 2026-01-04 06:12:06 -06:00
implementacion Initial commit - erp-construccion 2026-01-04 06:12:06 -06:00
_MAP.md Initial commit - erp-construccion 2026-01-04 06:12:06 -06:00
README.md Initial commit - erp-construccion 2026-01-04 06:12:06 -06:00

MAI-005: Control de Obra

ID: MAI-005 Fase: 1 - Alcance Inicial Presupuesto: $35,000 MXN Story Points: 52 SP Sprint: Sprint 15-18 (Semanas 29-36) Prioridad: P0 Estado: En documentación


Resumen Ejecutivo

Este módulo gestiona el control integral de avances físicos y financieros en obra, desde la programación con ruta crítica hasta la captura de evidencias fotográficas geolocalizadas. Incluye herramientas avanzadas de seguimiento con Curva S, Earned Value Management (EVM), bitácora digital, checklists de calidad con firma digital y reportes oficiales para INFONAVIT.

Problema que Resuelve

Las constructoras enfrentan desafíos críticos en el control de obra:

  • Falta de visibilidad en tiempo real del avance físico vs programado
  • Desviaciones no detectadas a tiempo en costo y tiempo
  • Registro manual de avances propenso a errores y fraudes
  • Evidencias fotográficas sin validación de ubicación o fecha
  • Reportes tardíos o incompletos para clientes y INFONAVIT
  • Falta de trazabilidad en inspecciones de calidad

Sin este módulo: Control en Excel desactualizado, avances reportados sin evidencia, desviaciones detectadas muy tarde, problemas en auditorías INFONAVIT.

Con este módulo: Seguimiento en tiempo real con métricas EVM, captura móvil geolocalizada, evidencias inmutables con hash SHA256, trazabilidad completa, reportes oficiales automatizados.


Objetivos

  1. Programación con CPM: Crear cronogramas con cálculo automático de ruta crítica
  2. Seguimiento EVM: Medir desempeño con SPI/CPI y proyecciones de costo
  3. Captura móvil eficiente: Registro de avances desde obra con geolocalización
  4. Documentación robusta: Evidencias fotográficas verificables con marca de agua
  5. Control de calidad: Checklists digitales con firma y gestión de No Conformidades
  6. Visibilidad ejecutiva: Dashboard en tiempo real con KPIs y alertas automáticas
  7. Reportes oficiales: Generación automática para INFONAVIT y clientes

Alcance Funcional

1. Programación de Obra con Ruta Crítica

  • Creación de cronogramas con actividades y dependencias
  • Algoritmo Critical Path Method (CPM) para identificar actividades críticas
  • Cálculo de holguras totales y libres
  • Diagramas de Gantt interactivos
  • Milestones con triggers de pago
  • Reprogramaciones con control de versiones
  • Baseline inmutable para comparación

2. Curva S y Earned Value Management

  • Generación automática de snapshots diarios (CRON 23:00)
  • Gráficas de líneas: Programado vs Real
  • Cálculo de métricas EVM:
    • PV (Planned Value): Valor planificado
    • EV (Earned Value): Valor ganado
    • AC (Actual Cost): Costo real
    • SPI (Schedule Performance Index): Desempeño de tiempo
    • CPI (Cost Performance Index): Desempeño de costo
    • EAC (Estimate at Completion): Proyección de costo final
    • VAC (Variance at Completion): Varianza al completar
  • Alertas si varianza >5% del presupuesto

3. Captura de Avances Físicos

  • Tres modos de registro:
    • Por porcentaje: 45% → 70% (+25%)
    • Por cantidad: 225 m³ → 350 m³ (+125 m³)
    • Por unidad: Seleccionar lotes/viviendas individuales
  • App móvil React Native:
    • Captura desde obra con interfaz intuitiva
    • Geolocalización automática con PostGIS
    • Validación de distancia del sitio (umbral 500m)
    • Fotos asociadas al avance
  • Modo offline robusto:
    • Almacenamiento local en SQLite
    • Sincronización automática al recuperar conexión
    • Cola de sincronización con reintentos
    • Resolución de conflictos
  • Workflow de aprobación:
    • Estados: Pendiente → Revisado → Aprobado/Rechazado
    • Validaciones automáticas de coherencia
    • Notificaciones a supervisores

4. Evidencias Fotográficas

  • Procesamiento automático:
    • Marca de agua inmutable: "Proyecto | Lote | Fecha Hora"
    • Thumbnail 300x225 px para performance
    • Compresión JPEG calidad 85%
    • Hash SHA256 para verificación de integridad
  • Metadatos EXIF extraídos:
    • Dispositivo, fecha original, coordenadas GPS
    • Altitud, orientación, flash, ISO, exposición
  • Georreferenciación PostGIS:
    • Almacenamiento de coordenadas GPS
    • Mapa visual con pins por ubicación
    • Validación de ubicación en el sitio
  • Álbumes organizados:
    • Por proyecto, etapa, fecha o tema
    • Exportación a PDF con galería
    • Exportación ZIP de fotos seleccionadas

5. Bitácora Digital de Obra

  • Registro diario de eventos en obra
  • Categorías: Avance, Incidencia, Clima, Visita
  • Multimedia: Fotos, videos, grabaciones de voz
  • Geolocalización automática
  • Timeline visual por proyecto
  • Exportación a PDF para reportes oficiales

6. Checklists de Calidad

  • Templates configurables:
    • Items de tipo: Boolean, Numérico, Texto, Foto obligatoria
    • Tolerancias para mediciones (10 ± 1 cm)
    • Valores de referencia normativos
  • Registro de No Conformidades (NC):
    • Severidad: Menor, Mayor, Crítica
    • Acción correctiva propuesta
    • Responsable y fecha límite
    • Seguimiento de cierre con fotos de verificación
  • Firma digital:
    • Canvas para dibujar firma con dedo/mouse
    • Timestamp y hash del documento
    • PDF generado con firma visible
  • Cálculo de compliance:
    • % = (Items conformes / Total items) × 100
    • Semáforos: Verde ≥95%, Amarillo 80-94%, Rojo <80%

7. Dashboard en Tiempo Real

  • KPIs principales:
    • Avance físico, financiero, tiempo transcurrido
    • SPI, CPI con colores según umbral
    • Varianzas de costo y tiempo
  • Curva S interactiva: Chart.js con zoom y tooltips
  • Mapa de calor de unidades:
    • Bloques por unidad con gradiente de color
    • Verde (100%), Amarillo (50-99%), Rojo (0-49%)
  • Panel de alertas:
    • Críticas, Advertencias, Informativas
    • Acciones sugeridas
  • Widgets configurables: Drag & drop con react-grid-layout
  • Actualización WebSocket: Push en tiempo real

8. Reportes Oficiales

Tipos de reportes:

  • INFONAVIT: Formato oficial con secciones obligatorias
  • Ejecutivo: Resumen para dirección (5-10 páginas)
  • Calidad: Checklists, NCs, inspecciones
  • Financiero: Avance financiero vs presupuesto
  • Productividad: Análisis de cuadrillas y rendimientos
  • Fotográfico: Álbum de evidencias

Características:

  • Firma digital con canvas
  • Hash del documento para verificación
  • Generación a PDF con PDFKit
  • Exportación a Excel con ExcelJS
  • Envío automático programado (diario, semanal, mensual)
  • Historial con tracking de descargas

Reutilización del Core ERP

Nivel de Reutilización: 0% - Módulo vertical 100% específico de construcción

Este módulo es completamente específico de la industria de la construcción y no reutiliza componentes del core ERP genérico. Sin embargo, se integra con los módulos base del vertical:

Dependencias internas:

  • Utiliza autenticación y autorización de MAI-001
  • Consume estructura de proyectos de MAI-002
  • Lee presupuestos y partidas de MAI-003
  • Provee datos para MAI-004 (Compras) en consumo de materiales

Justificación: Los requerimientos de control de obra con CPM, EVM, geolocalización GPS, evidencias fotográficas con hash SHA256, checklists de calidad con firma digital y reportes INFONAVIT son únicos del sector construcción y no aplican a otros verticales.


Requerimientos Funcionales

RF-OBRA-001: Programación de Obra y Curva S

Descripción: Sistema de programación con Critical Path Method (CPM) y seguimiento con Curva S y Earned Value Management (EVM).

Funcionalidades:

  • CRUD de cronogramas con actividades y dependencias
  • Algoritmo CPM para cálculo de ruta crítica
  • Generación automática de snapshots de Curva S
  • Métricas EVM (PV, EV, AC, SPI, CPI, EAC, VAC)
  • Diagramas de Gantt interactivos
  • Reprogramaciones con control de versiones

Documento: RF-OBRA-001

RF-OBRA-002: Captura de Avances Físicos

Descripción: Captura de avances desde app móvil con geolocalización, modo offline y workflow de aprobación.

Funcionalidades:

  • Captura por porcentaje, cantidad o unidad
  • App React Native con SQLite offline
  • Geolocalización PostGIS con validación de radio
  • Sincronización automática con cola de reintentos
  • Workflow de aprobación multinivel
  • Actualización automática de métricas

Documento: RF-OBRA-002

RF-OBRA-003: Evidencias Fotográficas y Checklists

Descripción: Gestión de evidencias fotográficas geolocalizadas con marca de agua inmutable y checklists de calidad con firma digital.

Funcionalidades:

  • Procesamiento automático con marca de agua
  • Hash SHA256 para integridad
  • Metadatos EXIF y georreferenciación PostGIS
  • Templates de checklists configurables
  • Gestión de No Conformidades (NC)
  • Firma digital con canvas
  • Exportación a PDF y ZIP

Documento: RF-OBRA-003

RF-OBRA-004: Dashboard y Reportes de Avances

Descripción: Dashboard ejecutivo en tiempo real con WebSocket y generación de reportes oficiales con firma digital.

Funcionalidades:

  • KPIs en tiempo real (físico, financiero, SPI, CPI)
  • Curva S interactiva con Chart.js
  • Mapa de calor de unidades
  • Panel de alertas categorizadas
  • Widgets configurables drag & drop
  • Generación de reportes PDF/Excel
  • Firma digital y hash de documentos
  • Envío automático programado

Documento: RF-OBRA-004


Integración con App Móvil

MOB-003: App Supervisor de Obra

Este módulo se integra completamente con la aplicación móvil MOB-003: App Supervisor de Obra, diseñada para residentes y supervisores de obra.

Funcionalidades móviles:

  • F-MOB003-01: Captura de avances (8 SP)

    • Registro de % avance por concepto
    • Tres modos: Porcentaje, Cantidad, Por unidad
    • Asociación automática a actividades del cronograma
  • F-MOB003-02: Fotos geoetiquetadas (5 SP)

    • Evidencia con GPS embebido (PostGIS)
    • Marca de agua automática
    • Hash SHA256 para integridad
  • F-MOB003-03: Checklist de inspección (4 SP)

    • Listas de verificación configurables
    • Firma digital en dispositivo móvil
    • Registro de No Conformidades
  • F-MOB003-04: Bitácora digital (4 SP)

    • Registro de notas diarias
    • Multimedia: Fotos, videos, voz
    • Categorización de eventos
  • F-MOB003-05: Modo offline (4 SP)

    • Trabajo sin conexión con SQLite
    • Sincronización automática
    • Resolución de conflictos

Stack tecnológico móvil:

  • React Native 0.73+ con Expo 50
  • TypeScript 5.3+
  • WatermelonDB para almacenamiento offline
  • expo-camera para fotos con EXIF
  • expo-location para GPS
  • Zustand para state management

Documento de referencia: EPIC-MAI-019: Apps Móviles


Dependencias con Otros Módulos

MAI-001: Fundamentos (Autenticación y Autorización)

Relación: Consume servicios de autenticación Datos compartidos:

  • Usuarios con roles (Residente, Jefe de Proyecto, Director)
  • Sesiones JWT para API y WebSocket
  • Permisos por acción (crear, aprobar, firmar)

MAI-002: Proyectos y Estructura

Relación: Consume estructura de proyectos Datos compartidos:

  • Proyectos activos con ubicación GPS
  • Unidades/lotes con identificadores únicos
  • Etapas de construcción
  • Cuadrillas y personal asignado

MAI-003: Presupuestos y Costos

Relación: Lee presupuestos y actualiza costos reales Datos compartidos:

  • Catálogo de partidas presupuestales
  • Cantidades y precios unitarios
  • Presupuesto total por proyecto (BAC para EVM)
  • Costos reales ejecutados (AC para EVM)

MAI-004: Compras e Inventarios (Opcional)

Relación: Compara materiales consumidos vs presupuesto Datos compartidos:

  • Consumo de materiales por actividad
  • Validación de órdenes vs avances
  • Alertas de desviaciones de costo

MAE-014: Finanzas (Indirecto)

Relación: Provee métricas financieras Datos compartidos:

  • Flujo de caja por proyecto
  • Proyecciones de costos (EAC)
  • Varianzas financieras (VAC)

Arquitectura del Módulo

Diagrama de Arquitectura

┌─────────────────────────────────────────────────────────────────┐
│                        FRONTEND WEB                              │
│  ┌──────────────┐  ┌──────────────┐  ┌──────────────┐          │
│  │  Dashboard   │  │  Programación│  │   Reportes   │          │
│  │   React +    │  │   CPM/Gantt  │  │   PDF/Excel  │          │
│  │  Chart.js    │  │  react-gantt │  │    jsPDF     │          │
│  └──────────────┘  └──────────────┘  └──────────────┘          │
│         ▲                  ▲                  ▲                  │
│         │                  │                  │                  │
│         └──────────────────┴──────────────────┘                 │
│                            │                                     │
│                     WebSocket (Socket.io)                        │
│                            │                                     │
└────────────────────────────┼─────────────────────────────────────┘
                             │
┌────────────────────────────┼─────────────────────────────────────┐
│                        BACKEND NESTJS                            │
│  ┌──────────────┐  ┌──────────────┐  ┌──────────────┐          │
│  │  Schedule    │  │   Progress   │  │   Evidence   │          │
│  │   Service    │  │    Service   │  │    Service   │          │
│  │   (CPM/EVM)  │  │  (Approval)  │  │  (Photos/QC) │          │
│  └──────────────┘  └──────────────┘  └──────────────┘          │
│         │                  │                  │                  │
│         ├──────────────────┼──────────────────┤                 │
│         │                  │                  │                  │
│  ┌──────────────┐  ┌──────────────┐  ┌──────────────┐          │
│  │ CPM Algorithm│  │  Sync Queue  │  │  Image Proc  │          │
│  │  Calculator  │  │   (BullMQ)   │  │   (Sharp)    │          │
│  └──────────────┘  └──────────────┘  └──────────────┘          │
│         │                  │                  │                  │
│         ▼                  ▼                  ▼                  │
└─────────────────────────────────────────────────────────────────┘
                             │
┌────────────────────────────┼─────────────────────────────────────┐
│                     POSTGRESQL 15+                               │
│  ┌──────────────┐  ┌──────────────┐  ┌──────────────┐          │
│  │   schedules  │  │   progress   │  │   evidence   │          │
│  │  (CPM, S-    │  │  (Records,   │  │  (Photos,    │          │
│  │   Curve)     │  │   Approval)  │  │  Checklists) │          │
│  └──────────────┘  └──────────────┘  └──────────────┘          │
│         │                  │                  │                  │
│         │         PostGIS Extension          │                  │
│         │         (Geolocation)               │                  │
│         │                                     │                  │
│  ┌──────────────────────────────────────────────────┐          │
│  │            analytics (KPIs, Alerts)              │          │
│  └──────────────────────────────────────────────────┘          │
└─────────────────────────────────────────────────────────────────┘
                             │
┌────────────────────────────┼─────────────────────────────────────┐
│                  MOBILE APP (React Native)                       │
│  ┌──────────────┐  ┌──────────────┐  ┌──────────────┐          │
│  │  Progress    │  │  Camera +    │  │  Checklist   │          │
│  │  Capture     │  │  GPS Geo     │  │  + Signature │          │
│  └──────────────┘  └──────────────┘  └──────────────┘          │
│         │                  │                  │                  │
│         ▼                  ▼                  ▼                  │
│  ┌────────────────────────────────────────────────┐            │
│  │          SQLite (Offline Storage)              │            │
│  │          + Sync Queue (WatermelonDB)           │            │
│  └────────────────────────────────────────────────┘            │
└─────────────────────────────────────────────────────────────────┘
                             │
┌────────────────────────────┼─────────────────────────────────────┐
│                    STORAGE (AWS S3 / GCS)                        │
│  ┌──────────────┐  ┌──────────────┐  ┌──────────────┐          │
│  │   Original   │  │  Thumbnails  │  │    PDFs      │          │
│  │    Photos    │  │  (300x225)   │  │  (Reports)   │          │
│  └──────────────┘  └──────────────┘  └──────────────┘          │
└─────────────────────────────────────────────────────────────────┘

Schema de Base de Datos

Schemas principales:

  • schedules - Programación, actividades, Curva S, milestones
  • progress - Registros de avance, aprobaciones, batch updates, offline sync
  • evidence - Fotos, checklists, templates, álbumes, NCs
  • analytics - KPIs, alertas, productividad, widgets, reportes

Tablas clave:

schedules
   schedule_activities (CPM: ES, EF, LS, LF, total_float, is_critical_path)
   milestones (payment_trigger, planned_date, actual_date)
   s_curve_snapshots (planned_pct, actual_pct, spi, cpi, eac, vac)

progress_records
   unit_progress (percent_complete, start_date, completion_date)
   offline_sync_queue (device_id, local_id, payload JSONB, sync_status)
   approval_workflows (levels JSONB, applies_to_activities[])

photos (sha256_hash, geolocation POINT, exif_data JSONB, has_watermark)
quality_checklists (items JSONB, compliance_percent, signature_data, pdf_path)

kpi_metrics (physical_progress, spi, cpi, eac, etc, vac, critical_alerts)
alerts (severity, related_entity_type, actions_taken JSONB)

Features de PostgreSQL:

  • PostGIS POINT para coordenadas GPS
  • JSONB para items flexibles (actividades, checklists)
  • Triggers para actualización automática de estados
  • Stored procedures para cálculo de CPM, EVM, compliance
  • Materialized views para performance (dashboard summary)
  • Full-text search en descripciones y notas

Stack Tecnológico

Backend

framework: NestJS 10+
language: TypeScript 5+
database: PostgreSQL 15+ (schemas: schedules, progress, evidence, analytics)
extensions: PostGIS para geolocalización
orm: TypeORM con migraciones
async_processing: Bull/BullMQ para batch updates y sync offline
scheduler: node-cron para snapshots diarios (23:00)
image_processing: Sharp para compresión y watermark
metadata: ExifReader para metadatos EXIF
hashing: crypto (SHA256) para integridad
pdf_generation: PDFKit
excel_export: ExcelJS
email: SendGrid / AWS SES
real_time: WebSocket (Socket.io)
storage: AWS S3 / Google Cloud Storage

Frontend Web

framework: React 18
language: TypeScript
state: Zustand
data_fetching: React Query (cache y sincronización)
charts: Chart.js / Recharts para Curva S y KPIs
gantt: react-gantt-chart para diagramas
maps: Leaflet para geolocalización
file_upload: react-dropzone
signature: react-signature-canvas
grid: react-grid-layout para widgets drag&drop
websocket: Socket.io-client
dates: date-fns
pdf_client: jsPDF

Mobile App

framework: React Native 0.73+
platform: Expo 50
language: TypeScript
offline_db: SQLite con WatermelonDB
sync: Background fetch + Queue
network_detection: NetInfo
camera: expo-camera con EXIF
geolocation: expo-location
file_system: expo-file-system / react-native-fs
local_storage: AsyncStorage
state: Zustand

Infraestructura

containers: Docker + Docker Compose
orchestration: Kubernetes (producción)
storage: AWS S3 / Google Cloud Storage
cdn: CloudFront / Cloud CDN
monitoring: Prometheus + Grafana
logging: Winston + ELK Stack
ci_cd: GitHub Actions / GitLab CI

Flujos de Trabajo

Flujo 1: Creación de Programa de Obra

1. [Director] Crea cronograma nuevo
2. [Director] Agrega actividades con duración, dependencias y lag
3. [Sistema] Ejecuta algoritmo CPM:
   - Forward Pass: Calcula ES (Earliest Start), EF (Earliest Finish)
   - Backward Pass: Calcula LS (Latest Start), LF (Latest Finish)
   - Float Calculation: TF = LF - EF, FF = min(ES[successors]) - EF
   - Identifica Critical Path: actividades donde TF == 0
4. [Director] Envía para aprobación
5. [Jefe] Aprueba → Estado: Active, isBaseline: true (v1)
6. [Sistema] Genera snapshot inicial de Curva S

Flujo 2: Captura y Aprobación de Avances

1. [Residente] (App Móvil):
   - Selecciona proyecto y actividad
   - Captura % avance o cantidad
   - Toma fotos con GPS automático
   - Envía (online) o guarda en SQLite (offline)

2. [Sistema] (Sincronización si offline):
   - Al recuperar conexión, detecta registros pendientes
   - Cola BullMQ procesa registros
   - Sube fotos a S3/GCS
   - Marca como synced

3. [Jefe de Proyecto] (Web):
   - Recibe notificación de avance pendiente
   - Abre detalle con validaciones automáticas:
     * Incremento de % coherente
     * Fotos geolocalizadas en el sitio
     * Sin duplicados
   - Aprueba o Rechaza con motivo

4. [Sistema] (Al aprobar):
   - Actualiza schedule_activity.percent_complete
   - Actualiza unit_progress.percent_complete
   - Recalcula KPIs (físico, SPI, CPI, EAC)
   - Genera snapshot de Curva S (si aplica)
   - Emite evento WebSocket → Dashboard se actualiza en vivo

Flujo 3: Inspección con Checklist de Calidad

1. [Residente] Selecciona template de checklist (ej: "Acabados Vivienda")
2. [Residente] Completa items uno por uno:
   - Boolean: ¿Pintura uniforme? ✅
   - Numérico: Espesor de piso = 10.2 cm (tolerancia: 10 ± 1) ✅
   - Foto: Toma foto de evidencia
3. [Residente] Registra No Conformidades (NC) si encuentra:
   - Severidad: Mayor
   - Descripción: "Grietas en muro norte"
   - Acción correctiva: "Resanar y repintar"
   - Responsable: Juan Pérez
   - Fecha límite: 2025-12-10
4. [Residente] Dibuja firma digital en canvas
5. [Sistema]:
   - Calcula compliance_percent = (conformes / total) × 100
   - Genera timestamp y hash del documento
   - Genera PDF con firma visible
   - Almacena en S3/GCS
6. [Jefe] Recibe notificación de NC y da seguimiento

Flujo 4: Generación de Reporte Oficial INFONAVIT

1. [Director] Selecciona "Generar Reporte INFONAVIT"
2. [Director] Configura:
   - Período: 2025-12-01 a 2025-12-31
   - Formato: PDF
   - Secciones: Carátula, Resumen, Avance por Etapa, Curva S, Fotos
   - Requiere firma: Sí
3. [Sistema] (Background job):
   - Ejecuta queries SQL para recopilar datos
   - Calcula KPIs y métricas EVM
   - Genera gráficas (Chart.js server-side con node-canvas)
   - Procesa fotografías seleccionadas
   - Compila PDF con PDFKit
4. [Director] Recibe notificación "Reporte listo para firma"
5. [Director] Dibuja firma digital en canvas
6. [Sistema]:
   - Captura firma Base64 + timestamp
   - Calcula hash SHA256 del documento completo
   - Inserta firma en PDF
   - Sube a S3/GCS
7. [Sistema] Envía por email a contactos de INFONAVIT (si configurado)
8. [Sistema] Guarda registro en reports_generated con tracking

Roles y Permisos

Rol Permisos
Residente de Obra Capturar avances móvil, tomar fotos, crear checklists, bitácora
Jefe de Proyecto Crear cronogramas, aprobar avances, ver dashboard, generar reportes ejecutivos
Director de Proyecto Aprobar programas, autorizar reprogramaciones, firmar reportes oficiales
Inspector de Calidad Crear templates de checklists, registrar NCs, dar seguimiento
Finanzas Ver métricas EVM (AC, EAC, VAC), exportar datos financieros
Cliente/INFONAVIT Consultar reportes oficiales, ver galería de fotos (solo lectura)

Indicadores Clave (KPIs)

KPIs del Sistema

  1. Eficiencia en Programación

    • Tiempo promedio para aprobar programa: <48h
    • % Programas con ruta crítica identificada: 100%
    • Precisión de proyecciones de término: ±5 días
  2. Adopción de Captura Móvil

    • % Avances registrados desde app: >90%
    • % Registros con geolocalización: >95%
    • % Sincronizaciones exitosas (offline): >98%
  3. Calidad de Evidencias

    • % Fotos con metadatos EXIF completos: >95%
    • % Fotos georreferenciadas: >90%
    • % Checklists completados con firma: 100%
  4. Exactitud de Seguimiento

    • Diferencia Curva S proyectada vs real: <5%
    • % Avances aprobados en <24h: >80%
    • % Alertas críticas atendidas en <48h: >90%
  5. Generación de Reportes

    • Tiempo de generación de reporte: <60s
    • % Reportes entregados a tiempo: >95%
    • % Reportes con firma digital: 100% (oficiales)

Métricas EVM

  • SPI (Schedule Performance Index): >0.95 (verde), 0.85-0.95 (amarillo), <0.85 (rojo)
  • CPI (Cost Performance Index): >0.95 (verde), 0.85-0.95 (amarillo), <0.85 (rojo)
  • VAC (Variance at Completion): Alerta si >5% del presupuesto

Puntos Críticos

  1. Complejidad del algoritmo CPM

    • Riesgo: Cálculos incorrectos de ruta crítica
    • Mitigación: Algoritmo probado con tests extensivos, casos edge documentados
  2. Sincronización offline

    • Riesgo: Pérdida de datos o duplicados
    • Mitigación: Cola robusta con reintentos, resolución de conflictos, SQLite transaccional
  3. Performance con miles de fotos

    • Riesgo: Lentitud en carga de galería
    • Mitigación: Thumbnails, lazy loading, paginación, CDN
  4. Validación de geolocalización

    • Riesgo: Registros falsos desde fuera del sitio
    • Mitigación: Validación PostGIS de radio, alertas de ubicaciones sospechosas
  5. Integridad de evidencias

    • Riesgo: Manipulación de fotos o documentos
    • Mitigación: Hash SHA256, marca de agua inmutable, firma digital con timestamp

Documentos Relacionados

Requerimientos Funcionales

Especificaciones Técnicas

Historias de Usuario

Referencias Técnicas


Estimación y Planificación

Distribución por Sprint

Sprint 15 (13 SP): Programación CPM + Curva S + EVM

  • US-OBRA-001: Crear Programa de Obra (8 SP)
  • US-OBRA-002: Seguimiento con Curva S (5 SP)

Sprint 16 (13 SP): Captura móvil + Aprobaciones

  • US-OBRA-003: Capturar Avances desde Obra (8 SP)
  • US-OBRA-004: Aprobar Avances (5 SP)

Sprint 17 (13 SP): Evidencias fotográficas + Checklists QC

  • US-OBRA-005: Evidencias Fotográficas (8 SP)
  • US-OBRA-006: Checklists de Calidad (5 SP)

Sprint 18 (13 SP): Dashboard + Reportes oficiales

  • US-OBRA-007: Dashboard Ejecutivo (8 SP)
  • US-OBRA-008: Reportes Oficiales (5 SP)

Total: 52 Story Points en 4 sprints (8 semanas)

Equipo Sugerido

  • 2 Backend developers (NestJS + PostgreSQL + PostGIS)
  • 1 Mobile developer (React Native + SQLite)
  • 2 Frontend developers (React + Chart.js + WebSocket)
  • 1 QA engineer
  • 1 Product Owner (medio tiempo)

Riesgos y Mitigaciones

Riesgo Probabilidad Impacto Mitigación
Complejidad del algoritmo CPM Media Alto Algoritmo probado, tests extensivos con casos edge
Sincronización offline Media Medio Cola con reintentos, SQLite robusto, WatermelonDB
Performance con miles de fotos Media Medio Thumbnails, lazy loading, paginación, CDN
Cálculo de EVM incorrecto Baja Alto Validación con experto PMI, tests unitarios
WebSocket desconexiones Media Bajo Reconexión automática, fallback a polling
Manipulación de evidencias Baja Alto Hash SHA256, marca de agua, firma digital

Próximos Pasos

Implementación

  1. Documentación completa
  2. Sprint Planning con equipo
  3. Setup de infraestructura (BD con PostGIS, storage S3/GCS)
  4. Sprint 15: Programación CPM y Curva S
  5. Sprint 16: Captura móvil y aprobaciones
  6. Sprint 17: Evidencias fotográficas y checklists
  7. Sprint 18: Dashboard y reportes
  8. Testing integral y UAT
  9. Capacitación a usuarios (residentes, jefes, directores)
  10. Go-live escalonado (1 proyecto piloto)

Integraciones Futuras

  • BI avanzado con Power BI / Tableau
  • Integración con drones para fotogrametría aérea
  • Machine learning para predicción de retrasos
  • App móvil nativa (Swift/Kotlin) para mejor performance
  • Integración con BIM (Building Information Modeling)
  • Exportación a MS Project / Primavera P6

Generado: 2025-12-06 Estado: Documentado Mantenedores: @tech-lead @backend-team @frontend-team @mobile-team