docs: PLAN_MACRO.md — plan de ejecución global del ecosistema
Compilación del input de planificación recibido el 2026-05-19: 21 módulos totales (12 existentes + 9 nuevos + 1 rename), 6 servicios compartidos como libraries horizontales, ~60-110K LOC nuevo código. Estructura del plan: - Fase A (sem 1-2): foundations cleanup (rename, brain split, lifecycle extract, pivot_root+overlayfs, transport-ssh) - Fase B (sem 2-5): core libraries (sandokan, dime, discovery-dht) - Fase C (sem 4-12): apps standalone paralelos (carmen, akashi, matilda, takiy, dominium, ágora) - Fase D (multi-mes): charka outlier (parser COBOL completo) - Fase E (sem 12-18): yachay integrador - Fase F (continuo): cobertura tests + cerrar stubs cosmo/pineal - Fase G (post): backlog (rimay, yuyay, apu, tinkuy, nutu + 4) Critical path: 17-23 semanas (4-5.5 meses) sin charka completo. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,362 @@
|
||||
# PLAN MACRO — Brahman Ecosystem
|
||||
|
||||
**Fecha de cierre del plan input:** 2026-05-19
|
||||
**Estado:** plan compilado, pendiente de ejecución.
|
||||
|
||||
---
|
||||
|
||||
## 0 · Resumen ejecutivo
|
||||
|
||||
- **21 módulos** totales: 12 existentes + 9 nuevos planeados + 1 rename pendiente.
|
||||
- **6 servicios compartidos** (libraries horizontales) que sostienen a los módulos de dominio.
|
||||
- **~60,000-110,000 LOC** de código nuevo proyectado (charka domina con su parser COBOL).
|
||||
- **Plazo realista**: 4-8 meses con AI assistance + paralelismo agresivo (charka extiende el cronograma a ~12-18 meses).
|
||||
- **Filosofía consolidada**: modularidad horizontal, separabilidad UI, sin daemons supremos, todo a través de Cards.
|
||||
|
||||
---
|
||||
|
||||
## 1 · Inventario completo
|
||||
|
||||
### Infraestructura (capa de soporte)
|
||||
|
||||
| módulo | estado | rol |
|
||||
|---|---|---|
|
||||
| `protocol/` | existe (7,278 LOC) | contratos canónicos + routing |
|
||||
| `init/` | existe (4,301 LOC) | PID 1 + encarnación Linux |
|
||||
| `runtime/` | existe (3,418 LOC) | bus + cas + wasm + brain |
|
||||
| `compat/` | existe (3,435 LOC) | shims D-Bus systemd |
|
||||
|
||||
### Servicios compartidos (libraries horizontales)
|
||||
|
||||
| servicio | estado | rol | consumidores |
|
||||
|---|---|---|---|
|
||||
| `sandokan` | nuevo | orquestador library (LocalEngine + DaemonEngine + RemoteEngine + auto()) | shuma, nahual, matilda, ssh-mode admin, todos los binarios que ejecuten Cards |
|
||||
| `sandokan-lifecycle` | extraer de shuma | TTL + restart + quota + drain + snapshot | shuma, matilda Ghost, charka-shadow, carmen, yachay |
|
||||
| `discovery-dht` | nuevo | DHT library agnóstica sobre brahman-net | minga (código), card-discovery (Cards), ágora (Personas), tinkuy (futuro) |
|
||||
| `transport-ssh-multiplex` | nuevo | russh + canales paralelos + reconexión silenciosa | sandokan::RemoteEngine, matilda LinkerSSH |
|
||||
| `dime` | nuevo | embeddings multi-backend (cohere/bge/mini/fastembed); daemons coexisten por modelo | chasqui, akashi, charka-semantic, takiy-ai, apu (futuro) |
|
||||
| `card-discovery` | nuevo | búsqueda Cards local + DHT (sobre discovery-dht) | nahual-shell (card-browser widget), ágora |
|
||||
|
||||
### Módulos de dominio
|
||||
|
||||
**Existentes:**
|
||||
|
||||
| módulo | estado | LOC aprox | pendientes |
|
||||
|---|---|---|---|
|
||||
| `chasqui` | rename de akasha | 4,395 | rename mecánico + migrar a dime + tests cluster |
|
||||
| `minga` | existe | 5,091 | minga-vfs (FUSE proyección código) + integración discovery-dht |
|
||||
| `nahual` | existe | 15,968 | card-browser widget + separabilidad widgets/lib |
|
||||
| `pineal` | existe | ~4,000 | 6 stubs (polar, heatmap, treemap, flow, mesh, export) |
|
||||
| `nakui` | existe | 7,063 | mantenimiento + docs morfismos |
|
||||
| `shuma` | existe | 6,907 | extraer lifecycle + tap a tee(2)/splice |
|
||||
| `gioser` | existe | 2,535 | estable |
|
||||
| `pluma` | existe | 178 | AST con inline elements |
|
||||
| `vista` | existe | 530 | estable |
|
||||
| `barra` | existe | 280 | estable |
|
||||
| `cosmobiologia` | existe | 21,502 | tests canvas/tree + roadmap GR/FFT/3D/rectificador |
|
||||
|
||||
**Nuevos:**
|
||||
|
||||
| módulo | rol | LOC aprox proyectada |
|
||||
|---|---|---|
|
||||
| `carmen` | compositor Wayland (smithay + ente-incarnate sandbox + delegación de regiones) | 8,000-12,000 |
|
||||
| `akashi` | notes app con ECS + 4 lentes + gravedad semántica + Susurros | 10,000-15,000 |
|
||||
| `charka` | transpilador COBOL→Rust + runtime determinista + shadow validator | 25,000-50,000 |
|
||||
| `matilda` | administrador servidores + vhosts + Docker (con Ghost remoto) | 6,000-9,000 |
|
||||
| `takiy` | composición musical (fundsp + ort + canvas) | 5,000-8,000 |
|
||||
| `dominium` | simulador psicológico campo medio + render isométrico CPU | 3,000-6,000 |
|
||||
| `yachay` | notebooks computacionales reproducibles (integración cross-módulos) | 5,000-9,000 |
|
||||
| `ágora` | identidad humana federada + attestations + grafo + negociación | 6,000-10,000 |
|
||||
|
||||
**Backlog (5 + 4 honorable mentions):**
|
||||
|
||||
| nombre | rol breve |
|
||||
|---|---|
|
||||
| `rimay` | traducción memoria + lenguas indígenas |
|
||||
| `yuyay` | spaced repetition + flashcards |
|
||||
| `apu` | AI personal soberana (LoRA local sobre datos propios) |
|
||||
| `tinkuy` | foros federados semánticos |
|
||||
| `nutu` | bóveda historia clínica personal encriptada |
|
||||
| `mama-pacha` | citizen-science ambiental |
|
||||
| `willay` | mensajería E2E P2P |
|
||||
| `inti` | energy management solar |
|
||||
| `kawsay` | time tracking semántico |
|
||||
|
||||
---
|
||||
|
||||
## 2 · Grafo de dependencias críticas
|
||||
|
||||
```
|
||||
┌─────────────────┐
|
||||
│ protocol/ │ Cards + handshake + broker + net + sidecar
|
||||
└────────┬────────┘
|
||||
│
|
||||
┌────────────────────┼────────────────────┐
|
||||
↓ ↓ ↓
|
||||
┌─────────┐ ┌──────────┐ ┌──────────┐
|
||||
│ init/ │ │ runtime/ │ │ compat/ │
|
||||
└────┬────┘ └────┬─────┘ └──────────┘
|
||||
│ │
|
||||
│ ente-incarnate │ brain-split: rules, cognitive, audit
|
||||
│ (+ pivot_root, │ ente-cas, ente-bus, ente-wasm
|
||||
│ overlayfs) │
|
||||
│ │
|
||||
└──────────┬────────┘
|
||||
│
|
||||
↓
|
||||
┌──────────────────┐
|
||||
│ sandokan │ ← lifecycle (extracted de shuma)
|
||||
│ (orchestrator) │ transport-ssh-multiplex
|
||||
└────────┬─────────┘
|
||||
│
|
||||
┌────────────┼───────────────────────────────┐
|
||||
↓ ↓ ↓
|
||||
┌─────────┐ ┌──────────┐ ┌─────────────┐
|
||||
│ shuma │ │ carmen │ (delegación │ discovery- │
|
||||
│ matilda │ │ Wayland │ via wl_subsurf) │ dht │
|
||||
│ charka- │ │ │ └──────┬──────┘
|
||||
│ shadow │ └────┬─────┘ │
|
||||
└─────────┘ │ ┌────────────┼────────────┐
|
||||
│ ↓ ↓ ↓
|
||||
│ ┌──────────┐ ┌──────────┐ ┌────────┐
|
||||
│ │ minga │ │ card- │ │ ágora │
|
||||
│ │ (código) │ │discovery │ │(Pers.) │
|
||||
│ └──────────┘ └─────┬────┘ └────────┘
|
||||
│ │
|
||||
┌──────┼──────┐ ┌────────┘
|
||||
↓ ↓ ↓ ↓
|
||||
┌─────────────────────────────────────────┐
|
||||
│ nahual-shell (card-browser + launcher)│
|
||||
└─────────────────────────────────────────┘
|
||||
|
||||
┌────────────┐
|
||||
│ dime │ (multi-backend embeddings)
|
||||
└─────┬──────┘
|
||||
│
|
||||
┌──────────┬────────┼────────┬──────────┐
|
||||
↓ ↓ ↓ ↓ ↓
|
||||
┌─────────┐ ┌────────┐ ┌────────┐ ┌──────┐ ┌──────┐
|
||||
│ chasqui │ │ akashi │ │ charka │ │takiy │ │ apu │
|
||||
│ migrar │ │ 384d │ │1024d │ │audio │ │futuro│
|
||||
└─────────┘ └────────┘ └────────┘ └──────┘ └──────┘
|
||||
|
||||
┌──────────┐
|
||||
│ yachay │ embebe todos los demás:
|
||||
│(integ.) │ pineal, dominium, takiy,
|
||||
└──────────┘ charka, akashi, chasqui
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 3 · Plan por fases
|
||||
|
||||
### Fase A · Foundations cleanup (semanas 1-2)
|
||||
|
||||
Pre-requisitos antes de meter código nuevo. La mayoría paralelizable.
|
||||
|
||||
| # | item | bloquea | tiempo |
|
||||
|---|---|---|---|
|
||||
| #24 | Rename akasha → chasqui | claridad de naming downstream | 1 día |
|
||||
| #13 | Split brain en brain-rules + brain-cognitive + brain-audit | sandokan, ágora | 3-5 días |
|
||||
| #14 | Unificar loader en brahman-cards | reduce duplicación | 1-2 días |
|
||||
| #16 | Promover lifecycle a sandokan-lifecycle | sandokan, matilda, charka-shadow, carmen | 4-7 días |
|
||||
| #19 | pivot_root + overlayfs en ente-incarnate | carmen, matilda Ghost, sandokan completo | 4-7 días |
|
||||
| #20 | transport-ssh-multiplex | sandokan::RemoteEngine, matilda | 3-5 días |
|
||||
|
||||
Trabajo paralelo posible: 3-4 tracks. Estimación realista: **2 semanas**.
|
||||
|
||||
### Fase B · Core libraries (semanas 2-5)
|
||||
|
||||
Servicios compartidos que sostienen aplicaciones.
|
||||
|
||||
| # | item | depende de | tiempo |
|
||||
|---|---|---|---|
|
||||
| #15 | sandokan (LocalEngine + DaemonEngine + RemoteEngine + auto) | Fase A | 1-2 semanas |
|
||||
| #22 | dime (4 backends + daemon multi-instancia) | (independiente) | 1-2 semanas |
|
||||
| #28 | discovery-dht (library) + card-discovery | brahman-net | 1-2 semanas |
|
||||
| protocol | Extender CardKind con Person/Community/Alliance/Institution | (independiente) | 1-2 días |
|
||||
|
||||
Paralelizable. Estimación realista: **3 semanas**.
|
||||
|
||||
### Fase C · Apps standalone (semanas 4-12, paralelo)
|
||||
|
||||
Módulos de dominio que pueden empezar cuando sus deps de Fase B estén estables.
|
||||
|
||||
| # | módulo | depende de | LOC | tiempo |
|
||||
|---|---|---|---|---|
|
||||
| #27 | dominium | (mayormente independiente) | 3-6K | 3-4 semanas |
|
||||
| #26 | takiy | dime (instancia ort) | 5-8K | 4-6 semanas |
|
||||
| #23 | akashi | dime (instancia 384d), separabilidad UI | 10-15K | 6-10 semanas |
|
||||
| #21 | matilda | sandokan-lifecycle, ente-incarnate enhanced, transport-ssh | 6-9K | 5-8 semanas |
|
||||
| #29 | carmen | ente-incarnate enhanced, sandokan, ente-logind-compat | 8-12K | 8-12 semanas |
|
||||
| #31 | ágora | CardKind extension, discovery-dht, brain-audit | 6-10K | 5-8 semanas |
|
||||
|
||||
Paralelizable hasta 4-6 tracks simultáneos. Estimación realista: **10-12 semanas**.
|
||||
|
||||
### Fase D · Charka (paralelo, multi-mes)
|
||||
|
||||
| # | módulo | tiempo |
|
||||
|---|---|---|
|
||||
| #17 | charka — parser COBOL completo + IR + semantic + runtime BCD + shadow + codegen | **6-12 meses** |
|
||||
|
||||
Outlier por la complejidad del parser COBOL completo (CICS + SQL embedded + dialectos IBM Enterprise). Corre en paralelo con Fase C pero NO bloquea otras cosas.
|
||||
|
||||
### Fase E · Yachay e integración cross-módulo (semanas 12-18)
|
||||
|
||||
| # | item | depende de | tiempo |
|
||||
|---|---|---|---|
|
||||
| #30 | yachay — notebooks reproducibles | pineal stubs cerrados, dominium estable, takiy estable, charka mínimo viable, akashi base, chasqui migrado | 4-6 semanas |
|
||||
| #25 | Aplicar separabilidad UI retroactiva donde bloquee | (cuando se necesite) | 1-3 semanas |
|
||||
|
||||
Yachay es el módulo más integrador; tiene sentido al final cuando todos sus embeds están maduros.
|
||||
|
||||
### Fase F · Roadmap previo a estabilizar (paralelo throughout)
|
||||
|
||||
Items del ROADMAP.md original (de docs/) que conviven con las fases nuevas:
|
||||
|
||||
- Cobertura tests cosmobiologia-canvas/tree (5,145 LOC sin tests)
|
||||
- Cobertura tests chasqui-cluster (k-means)
|
||||
- Cerrar 6 stubs de pineal (polar/heatmap/treemap/flow/mesh/export)
|
||||
- minga-vfs (FUSE proyección de código)
|
||||
- TODOs concentrados: brain-* (post-split), handshake fase 4, shuma supervision avanzada
|
||||
- Compat avanzado systemd (Inhibit, SetVariable, MachineImage)
|
||||
- Cosmobiología roadmap (GR + FFT + 3D + rectificador)
|
||||
|
||||
Suma estimada: **4-6 semanas continuas** distribuidas entre Fases A-E.
|
||||
|
||||
### Fase G · Backlog (post-Fase E si alcanza)
|
||||
|
||||
Los 5 + 4 honorable mentions. Cuando el monorepo esté maduro y haya capacidad sobrante.
|
||||
|
||||
---
|
||||
|
||||
## 4 · Cronograma agregado
|
||||
|
||||
```
|
||||
sem 1-2 sem 2-5 sem 4-12 sem 12-18 sem 18+
|
||||
├Fase A──►
|
||||
├Fase B────►
|
||||
├Fase C ──parallel─────►
|
||||
├Fase E──►
|
||||
├Fase D ──charka (multi-mes)────────────►
|
||||
├Fase F (cobertura tests + stubs cosmo/pineal)─────►
|
||||
├Fase G─►
|
||||
```
|
||||
|
||||
**Tiempo estimado a v1 funcional**:
|
||||
- Sin charka: ~4-5 meses
|
||||
- Con charka completo: ~6-12 meses (depende del parser COBOL)
|
||||
- Con backlog y polish: ~12-18 meses
|
||||
|
||||
Con paralelismo agresivo (3-5 tracks simultáneos asistidos por AI): **factor 1.5-2× de aceleración**.
|
||||
|
||||
---
|
||||
|
||||
## 5 · Critical path (camino crítico)
|
||||
|
||||
El camino más largo de dependencias que define el plazo mínimo:
|
||||
|
||||
```
|
||||
A: rename + brain split + lifecycle + pivot_root (2 sem)
|
||||
↓
|
||||
B: sandokan + dime + discovery-dht (3 sem)
|
||||
↓
|
||||
C: carmen + ágora (8-12 sem)
|
||||
↓
|
||||
E: yachay (4-6 sem)
|
||||
─────────────────────────────────────
|
||||
TOTAL critical path: 17-23 semanas (4-5.5 meses)
|
||||
```
|
||||
|
||||
Charka corre EN PARALELO al critical path (no lo extiende) pero su propia trayectoria es ~6-12 meses.
|
||||
|
||||
---
|
||||
|
||||
## 6 · Paralelismos máximos posibles
|
||||
|
||||
Asumiendo que se quiere maximizar throughput con múltiples agentes/personas trabajando:
|
||||
|
||||
| momento | tracks paralelos |
|
||||
|---|---|
|
||||
| Fase A | 4 tracks: rename, brain-split+loader, lifecycle, incarnate+ssh |
|
||||
| Fase B | 3 tracks: sandokan, dime, discovery-dht |
|
||||
| Fase C | 4-6 tracks: dominium, takiy, akashi, matilda, carmen, ágora |
|
||||
| Fase D | 1 track dedicado: charka (multi-mes) |
|
||||
| Fase E | 1-2 tracks: yachay + separabilidad retroactiva |
|
||||
| Fase F | 1-2 tracks distribuidos en todas las fases (tests cobertura, stubs) |
|
||||
|
||||
**Pico simultáneo**: ~6-8 tracks (mitad de Fase C, con charka corriendo aparte).
|
||||
|
||||
---
|
||||
|
||||
## 7 · Riesgos identificados
|
||||
|
||||
| riesgo | severidad | mitigación |
|
||||
|---|---|---|
|
||||
| Parser COBOL completo es enorme (6-12 meses) | **alta** | Aceptado por usuario. Empezar charka temprano, paralelo. Considerar subset COBOL'85 puro como primer hito antes de CICS+SQL embed. |
|
||||
| CRIU sobre Wayland no funciona out-of-box | media | Marcado como futuro en carmen. Documentar limitaciones. |
|
||||
| Cross-platform determinism bit-exact (dominium) | alta | Plan ya incluye dep libm + BTreeMap + rand_chacha + serial reductions. CI cross-compile x86+ARM verificando hashes. |
|
||||
| ZKP en ágora v2 es complejo (bbs-signatures) | media | v1 sin ZKP, v2 al final. Documentar limitaciones de v1. |
|
||||
| Doble (o triple) descarga de modelos AI por falta de daemon dime | media | dime daemon multi-instancia desde Fase B. CAS para blob sharing. |
|
||||
| Acoplo UI legacy de nahual widgets a GPUI | media | Separabilidad retroactiva en #25, aplicar solo donde bloquee. |
|
||||
| Wayland compositor robusto requiere expertise específico (smithay) | alta | Empezar carmen con Fase 1 minimal (foot/alacritty rendering) antes de ambicionar fractal/delegación. |
|
||||
| Sobre-ingeniería del fractal en carmen | media | "Si es forzado no, cuando sea grande sí" — explicit del usuario. NO en v1. |
|
||||
|
||||
---
|
||||
|
||||
## 8 · Hitos verificables (acceptance criteria)
|
||||
|
||||
Para considerar cada fase "cerrada":
|
||||
|
||||
**Fase A**:
|
||||
- [ ] `cargo check --workspace` verde tras rename a chasqui
|
||||
- [ ] brain split: 3 crates separados, brain umbrella opcional, loader unificado
|
||||
- [ ] sandokan-lifecycle extraído con tests pasando que cubren shuma's lifecycle existente
|
||||
- [ ] ente-incarnate con pivot_root + overlayfs + tests (chroot básico)
|
||||
- [ ] transport-ssh-multiplex con tests sobre russh
|
||||
|
||||
**Fase B**:
|
||||
- [ ] sandokan auto() detecta socket y elige Local/Daemon correctamente
|
||||
- [ ] dime con al menos 2 backends operativos (recomendado bge + fastembed) + daemon multi-instancia
|
||||
- [ ] discovery-dht: publish + lookup funciona sobre brahman-net libp2p
|
||||
|
||||
**Fase C** (por módulo):
|
||||
- [ ] dominium: tick deterministic bit-exact cross-platform; 4 lentes funcionan; CI cross-compile pasa
|
||||
- [ ] takiy: latencia audio <10ms; persistencia ambos formatos
|
||||
- [ ] akashi: 4 lentes implementadas; Susurros activos; storage sqlite-vss funcional
|
||||
- [ ] matilda: Inspect/Diff/Apply ciclo cerrado; al menos provider Docker funcional
|
||||
- [ ] carmen: arranca compositor; renderea alacritty; sandbox via ente-incarnate
|
||||
- [ ] ágora: emite + verifica + revoca attestations; grafo navegable; integrado con CardKind
|
||||
|
||||
**Fase D**:
|
||||
- [ ] charka: parsea COBOL'85 puro (subset). Hito intermedio. CICS + SQL después.
|
||||
|
||||
**Fase E**:
|
||||
- [ ] yachay: notebook ejecutable bit-exacto-reproducible; embeds pineal+dominium+takiy probados
|
||||
|
||||
---
|
||||
|
||||
## 9 · Decisiones de ejecución pendientes
|
||||
|
||||
Antes de arrancar Fase A queda por decidir:
|
||||
|
||||
1. **Persona dedica tiempo full-time o spaced?** → afecta el cronograma absoluto.
|
||||
2. **¿Cuántos tracks paralelos** vas a sostener vos solo + Claude/AI assistants?
|
||||
3. **¿Charka prioritario o relegado?** → si lo dejás al final, ahorrás tiempo al critical path; si lo querés temprano, paralelizá desde Fase B.
|
||||
4. **¿yachay como integrador o standalone?** → si es integrador (recomendado), va al final; si standalone, puede empezar antes pero pierde el embed de los demás.
|
||||
|
||||
---
|
||||
|
||||
## 10 · Una vez aprobado este plan
|
||||
|
||||
Próximos pasos concretos cuando se dé la señal:
|
||||
|
||||
1. Empezar Fase A con rename akasha → chasqui (script reorg.py reusable, ya está en `scripts/`).
|
||||
2. Crear branch `phase-a-foundations` para los refactors mecánicos.
|
||||
3. Tests cobertura paralelo (Fase F) corre desde día 1.
|
||||
4. Cada item completado: commit + push (política `feedback_commit_push.md`).
|
||||
5. Actualizar `docs/STATUS.md` al cerrar cada fase.
|
||||
|
||||
---
|
||||
|
||||
**Plan compilado.** Cuando digas, arrancamos por Fase A.
|
||||
Reference in New Issue
Block a user