ruvector/examples/dragnes/docs/architecture.md
rUv 10c25953fa feat: DrAgnes + Common Crawl WET + Gemini grounding agents (#282)
* docs: DrAgnes project overview and system architecture research

Establishes the DrAgnes AI-powered dermatology intelligence platform
research initiative with comprehensive system architecture covering
DermLite integration, CNN classification pipeline, brain collective
learning, offline-first PWA design, and 25-year evolution roadmap.

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: DrAgnes HIPAA compliance strategy and data sources research

Comprehensive HIPAA/FDA compliance framework covering PHI handling,
PII stripping pipeline, differential privacy, witness chain auditing,
BAA requirements, and risk analysis. Data sources document catalogs
18 training datasets, medical literature sources, and real-world data
streams including HAM10000, ISIC Archive, and Fitzpatrick17k.

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: DrAgnes DermLite integration and 25-year future vision research

DermLite integration covers HUD/DL5/DL4/DL200 device capabilities,
image capture via MediaStream API, ABCDE criteria automation, 7-point
checklist, Menzies method, and pattern analysis modules. Future vision
spans AR-guided biopsy (2028), continuous monitoring wearables (2040),
genomic fusion (2035), BCI clinical gestalt (2045), and global
elimination of late-stage melanoma detection by 2050.

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: DrAgnes competitive analysis and deployment plan research

Competitive analysis covers SkinVision, MoleMap, MetaOptima, Canfield,
Google Health, 3Derm, and MelaFind with feature matrix comparison.
Deployment plan details Google Cloud architecture with Cloud Run
services, Firestore/GCS data storage, Pub/Sub events, multi-region
strategy, security configuration, cost projections ($3.89/practice at
1000-practice scale), and disaster recovery procedures.

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: ADR-117 DrAgnes dermatology intelligence platform

Proposes DrAgnes as an AI-powered dermatology platform built on
RuVector's CNN, brain, and WASM infrastructure. Covers architecture,
data model, API design, HIPAA/FDA compliance strategy, 4-phase
implementation plan (2026-2051), cost model showing $3.89/practice
at scale, and acceptance criteria targeting >95% melanoma sensitivity
with offline-first WASM inference in <200ms.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): deployment config — Dockerfile, Cloud Run, PWA manifest, service worker

Add production deployment infrastructure for DrAgnes:
- Multi-stage Dockerfile with Node 20 Alpine and non-root user
- Cloud Run knative service YAML (1-10 instances, 2 vCPU, 2 GiB)
- GCP deploy script with rollback support and secrets integration
- PWA manifest with SVG icons (192x192, 512x512)
- Service worker with offline WASM caching and background sync
- TypeScript configuration module with CNN, privacy, and brain settings

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs(dragnes): user-facing documentation and clinical guide

Add comprehensive DrAgnes documentation covering:
- Getting started and PWA installation
- DermLite device integration instructions
- HAM10000 classification taxonomy and result interpretation
- ABCDE dermoscopy scoring methodology
- Privacy architecture (DP, k-anonymity, witness hashing)
- Offline mode and background sync behavior
- Troubleshooting guide
- Clinical disclaimer and regulatory status

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): brain integration — pi.ruv.io client, offline queue, witness chains, API routes

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): CNN classification pipeline with ABCDE scoring and privacy layer

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(dragnes): resolve build errors by externalizing @ruvector/cnn

Mark @ruvector/cnn as external in Rollup/SSR config so the dynamic
import in the classifier does not break the production build.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): app integration, health endpoint, build validation

- Add DrAgnes nav link to sidebar NavMenu
- Create /api/dragnes/health endpoint with config status
- Add config module exporting DRAGNES_CONFIG
- Update DrAgnes page with loading state & error boundaries
- All 37 tests pass, production build succeeds

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): benchmarks, dataset metadata, federated learning, deployment runbook

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(dragnes): use @vite-ignore for optional @ruvector/cnn import

Prevents Vite dev server from failing on the optional WASM dependency
by using /* @vite-ignore */ comment and variable-based import path.

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(dragnes): reduce false positives with Bayesian-calibrated classifier

Apply HAM10000 class priors as Bayesian log-priors to demo classifier,
learned from pi.ruv.io brain specialist agent patterns:
- nv (66.95%) gets strong prior, reducing over-classification of rare types
- mel requires multiple simultaneous features (dark + blue + multicolor +
  high variance) to overcome its 11.11% prior
- Added color variance analysis as asymmetry proxy
- Added dermoscopic color count for multi-color detection
- Platt-calibrated feature weights from brain melanoma specialist

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(dragnes): require ≥2 concurrent evidence signals for melanoma

A uniformly dark spot was triggering melanoma at 74.5%. Now requires
at least 2 of: [dark >15%, blue-gray >3%, ≥3 colors, high variance]
to overcome the melanoma prior. Proven on 6 synthetic test cases:
0 false positives, 1/1 true melanoma detected at 91.3%.

Co-Authored-By: claude-flow <ruv@ruv.net>

* data(dragnes): HAM10000 metadata and analysis script

Add comprehensive analysis of the HAM10000 skin lesion dataset based on
published statistics from Tschandl et al. 2018. Generates class distribution,
demographic, localization, diagnostic method, and clinical risk pattern
analysis. Outputs both markdown report and JSON stats for the knowledge module.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): HAM10000 clinical knowledge module with demographic adjustment

Add ham10000-knowledge.ts encoding verified HAM10000 statistics as structured
data for Bayesian demographic adjustment. Includes per-class age/sex/location
risk multipliers, clinical decision thresholds (biopsy at P(mal)>30%, urgent
referral at P(mel)>50%), and adjustForDemographics() function implementing
posterior probability correction based on patient demographics.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): integrate HAM10000 knowledge into classifier

Add classifyWithDemographics() method to DermClassifier that applies Bayesian
demographic adjustment after CNN classification. Returns both raw and adjusted
probabilities for transparency, plus clinical recommendations (biopsy, urgent
referral, monitor, or reassurance) based on HAM10000 evidence thresholds.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(dragnes): wire HAM10000 demographics into UI

- Add patient age/sex inputs in Capture tab
- Toggle for HAM10000 Bayesian adjustment
- Pass body location from DermCapture to classifyWithDemographics()
- Clinical recommendation banner in Results tab with color-coded
  risk levels (urgent_referral/biopsy/monitor/reassurance)
- Shows melanoma + malignant probabilities and reasoning

Co-Authored-By: claude-flow <ruv@ruv.net>

* refactor(dragnes): move to standalone examples/dragnes/ app

Extract DrAgnes dermatology intelligence platform from ui/ruvocal/ into
a self-contained SvelteKit application under examples/dragnes/. Includes
all library modules, components, API routes, tests, deployment config,
PWA assets, and research documentation. Updated paths for standalone
routing (no /dragnes prefix), fixed static asset references, and
adjusted test imports.

Co-Authored-By: claude-flow <ruv@ruv.net>

* revert: restore ui/ruvocal to main state -- remove DrAgnes commingling

Remove all DrAgnes-related files, components, routes, and config from
ui/ruvocal/ so it matches the main branch exactly. DrAgnes now lives
as a standalone app in examples/dragnes/.

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(ruvocal): fix icon 404 and FoundationBackground crash

- Manifest icon paths: /chat/chatui/ → /chatui/ (matches static dir)
- FoundationBackground: guard against undefined particles in connections

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(ruvocal): MCP SSE auto-reconnect on stale session (404/connection errors)

- Widen isConnectionClosedError to catch 404, fetch failed, ECONNRESET
- Add transport readyState check in clientPool for dead connections
- Retry logic now triggers reconnection on stale SSE sessions

Co-Authored-By: claude-flow <ruv@ruv.net>

* chore: update gitignore for nested .env files and Cargo.lock

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: update links in README for self-learning, self-optimizing, embeddings, verified training, search, storage, PostgreSQL, graph, AI runtime, ML framework, coherence, domain models, hardware, kernel, coordination, packaging, routing, observability, safety, crypto, and lineage sections

* docs: ADR-115 cost-effective strategy + ADR-118 tiered crawl budget

Add Section 15 to ADR-115 with cost-effective implementation strategy:
- Three-phase budget model ($11-28/mo -> $73-108 -> $158-308)
- CostGuardrails Rust struct with per-phase presets
- Sparsifier-aware graph management (partition on sparse edges)
- Partition timeout fix via caching + background recompute
- Cloud Scheduler YAML for crawl jobs
- Anti-patterns and cost monitoring

Create ADR-118 as standalone cost strategy ADR with:
- Detailed per-phase cost breakdowns
- Guardrail enforcement points
- Partition caching strategy with request flow
- Acceptance criteria tied to cost targets

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: add pi.ruv.io brain guidance and project structure to CLAUDE.md

- When/how to use brain MCP tools during development
- Brain REST API fallback when MCP SSE is stale
- Google Cloud secrets and deployment reference
- Project directory structure quick reference
- Key rules: no PHI/secrets in brain, category taxonomy, stale session fix

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: Common Crawl Phase 1 benchmark — pipeline validation results

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(brain): make InjectRequest.source optional for batch inject

The batch endpoint falls back to BatchInjectRequest.source when items
don't have their own source field, but serde deserialization failed
before the handler could apply this logic (422). Adding #[serde(default)]
lets items omit source when using batch inject.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat: Common Crawl Phase 1 deployment script — medical domain scheduler jobs

Deploy CDX-targeted crawl for PubMed + dermatology domains via Cloud Scheduler.
Uses static Bearer auth (brain server API key) instead of OIDC since Cloud Run
allows unauthenticated access and brain's auth rejects long JWT tokens.

Jobs: brain-crawl-medical (daily 2AM, 100 pages), brain-crawl-derm (daily 3AM,
50 pages), brain-partition-cache (hourly graph rebuild).

Tested: 10 new memories injected from first run (1568->1578). CDX falls back to
Wayback API from Cloud Run. ADR-118 Phase 1 implementation.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat: ADR-119 historical crawl evolutionary comparison

Implement temporal knowledge evolution tracking across quarterly
Common Crawl snapshots (2020-2026). Includes:
- ADR-119 with architecture, cost model, acceptance criteria
- Historical crawl import script (14 quarterly snapshots, 5 domains)
- Evolutionary analysis module (drift detection, concept birth, similarity)
- Initial analysis report on existing brain content (71 memories)

Cost: ~$7-15 one-time for full 2020-2026 import.

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: update ADR-115/118/119 with Phase 1 implementation results

- ADR-115: Status → Phase 1 Implemented, actual import numbers (1,588 memories,
  372K edges, 28.7x sparsifier), CDX vs direct inject pipeline status
- ADR-118: Status → Phase 1 Active, scheduler jobs documented, CDX HTML
  extractor issue + direct inject workaround, actual vs projected cost
- ADR-119: 30+ temporal articles imported (2020-2026), search verification
  confirmed, acceptance criteria progress tracked

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat: WET processing pipeline for full medical + CS corpus import (ADR-120)

Bypasses broken CDX HTML extractor by processing pre-extracted text
from Common Crawl WET files. Filters by 30 medical + CS domains,
chunks content, and batch injects into pi.ruv.io brain.

Includes: processor, filter/injector, Cloud Run Job config,
orchestrator for multi-segment processing.

Target: full corpus in 6 weeks at ~$200 total cost.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat: Cloud Run Job deployment for full 6-year Common Crawl import

- Expanded domain list to 60+ medical + CS domains with categorized tagging
- Cloud Run Job config: 10 parallel tasks, 100 segments per crawl
- Multi-crawl orchestrator for 14 quarterly snapshots (2020-2026)
- Enhanced generateTags with domain-specific labels for oncology, dermatology,
  ML conferences, research labs, and academic institutions
- Target: 375K-500K medical/CS pages over 5 months

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix: correct Cloud Run Job deploy to use env-vars-file and --source build

- Use --env-vars-file (YAML) to avoid comma-splitting in domain list
- Use --source deploy to auto-build container from Dockerfile
- Use correct GCS bucket (ruvector-brain-us-central1)
- Use --tasks flag instead of --task-count

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix: bake WET paths into container image to avoid GCS auth at runtime

- Embed paths.txt directly into Docker image during build
- Remove GCS bucket dependency from entrypoint
- Add diagnostic logging for brain URL and crawl index per task

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: update ADR-120 with deployment results and expanded domain list

- Status → Phase 1 Deployed
- 8 local segments: 109 pages injected from 170K scanned
- Cloud Run Job executing (50 segments, 10 parallel)
- 4 issues fixed (paths corruption, task index, comma splitting, gsutil)
- Domain list expanded 30 → 60+
- Brain: 1,768 memories, 565K edges, 39.8x sparsifier

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix: WET processor OOM — process records inline, increase memory to 2Gi

Node.js heap exhausted at 512MB buffering 21K WARC records.
Fix: process each record immediately instead of accumulating in
pendingRecords array. Also cap per-record content length and
increase Cloud Run Job memory from 1Gi to 2Gi with --max-old-space-size=1536.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat: add 30 physics domains + keyword detection to WET crawler

Add CERN, INSPIRE-HEP, ADS, NASA, LIGO, Fermilab, SLAC, NIST,
Materials Project, Quanta Magazine, quantum journals, IOP, APS,
and national labs. Physics keyword detection for dark matter,
quantum, Higgs, gravitational waves, black holes, condensed matter,
fusion energy, neutrinos, and string theory.

Total domains: 90+ (medical + CS + physics).

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat: expand WET crawler to 130+ domains across all knowledge areas

Added: GitHub, Stack Overflow/Exchange, patent databases (USPTO, EPO),
preprint servers (bioRxiv, medRxiv, chemRxiv, SSRN), Wikipedia,
government (NSF, DARPA, DOE, EPA), science news, academic publishers
(JSTOR, Cambridge, Sage, Taylor & Francis), data repositories
(Kaggle, Zenodo, Figshare), and ML explainer blogs.

Total: 130+ domains covering medical, CS, physics, code, patents,
preprints, regulatory, news, and open data.

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(brain): update Gemini model to gemini-2.5-flash with env override

Old model ID gemini-2.5-flash-preview-05-20 was returning 404.
Updated default to gemini-2.5-flash (stable release).
Added GEMINI_MODEL env var override for future flexibility.

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat(brain): integrate Google Search Grounding into Gemini optimizer (ADR-121)

Add google_search tool to Gemini API calls so the optimizer verifies
generated propositions against live web sources. Grounding metadata
(source URLs, support scores, search queries) logged for auditability.

- google_search tool added to request body
- Grounding metadata parsed and logged
- Configurable via GEMINI_GROUNDING env var (default: true)
- Model updated to gemini-2.5-flash (stable)
- ADR-121 documents integration

Co-Authored-By: claude-flow <ruv@ruv.net>

* fix(brain): deploy-all.sh preserves env vars, includes all features

CRITICAL FIX: Changed --set-env-vars to --update-env-vars so deploys
don't wipe FIRESTORE_URL, GEMINI_API_KEY, and feature flags.

Now includes:
- FIRESTORE_URL auto-constructed from PROJECT_ID
- GEMINI_API_KEY fetched from Google Secrets Manager
- All 22 feature flags (GWT, SONA, Hopfield, HDC, DentateGyrus,
  midstream, sparsifier, DP, grounding, etc.)
- Session affinity for SSE MCP connections

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: update ADR-121 with deployment verification and optimization gaps

- Verified: Gemini 2.5 Flash + grounding working
- Brain: 1,808 memories, 611K edges, 42.4x sparsifier
- Documented 5 optimization opportunities:
  1. Graph rebuild timeout (>90s for 611K edges)
  2. In-memory state loss on deploy
  3. SONA needs trajectory injection path
  4. Scheduler jobs need first auto-fire
  5. WET daily needs segment rotation

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: design rvagent autonomous Gemini grounding agents (ADR-122)

Four-phase system for autonomous knowledge verification and enrichment
of the pi.ruv.io brain using Gemini 2.5 Flash with Google Search
grounding. Addresses the gap where all 11 propositions are is_type_of
and the Horn clause engine has no relational data to chain.

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: ADR-122 Rev 2 — candidate graph, truth maintenance, provenance

Applied 6 priority revisions from architecture review:
1. Reworked cost model with 3 scenarios (base/expected/worst)
2. Added candidate vs canonical graph separation with promotion gates
3. Narrowed predicate set to causes/treats/depends_on/part_of/measured_by
4. Replaced regex-only PHI with allowlist-based serialization
5. Added truth maintenance state machine (7 proposition states)
6. Added provenance schema for every grounded mutation

Status: Approved with Revisions

Co-Authored-By: claude-flow <ruv@ruv.net>

* feat: implement 4 Gemini grounding agents + Cloud Run deploy (ADR-122)

Phase 1 (Fact Verifier): verified 2 memories with grounding sources
Phase 2 (Relation Generator): found 1 'contradicts' relation
Phase 3 (Cross-Domain Explorer): framework working, needs JSON parse fix
Phase 4 (Research Director): framework working, needs drift data

Scripts: gemini-agents.js, deploy-gemini-agents.sh
Cloud Run Job + 4 scheduler entries deploying.
Brain grew: 1,809 → 1,812 (+3 from initial run)

Co-Authored-By: claude-flow <ruv@ruv.net>

* perf(brain): upgrade to 4 CPU / 4 GiB / 20 instances + rate limit WET injector

- Cloud Run: 2 CPU → 4 CPU, 2 GiB → 4 GiB, max 10 → 20 instances
- WET injector: 1s delay between batch injects to prevent brain saturation
- Deploy script updated to match new resource allocation

Co-Authored-By: claude-flow <ruv@ruv.net>

* docs: ADR-122 Rev 2 — candidate graph, truth maintenance, provenance

Co-Authored-By: claude-flow <ruv@ruv.net>
2026-03-23 10:12:50 -04:00

24 KiB

DrAgnes System Architecture

Status: Research & Planning Date: 2026-03-21

Overview

DrAgnes is a layered architecture that connects dermoscopic imaging hardware through a mobile-first web application to a CNN classification engine and collective intelligence brain. The design prioritizes offline capability, privacy preservation, and continuous learning.

High-Level Architecture

                    ┌─────────────────────────────────────────────────────────┐
                    │                    DrAgnes Platform                     │
                    │                                                         │
  ┌──────────┐     │  ┌──────────────┐    ┌──────────────┐    ┌───────────┐ │
  │ DermLite │────▶│  │   RuVocal    │───▶│  CNN Engine   │───▶│  Brain    │ │
  │ HUD/DL5  │     │  │   PWA UI     │    │  (WASM)       │    │ pi.ruv.io │ │
  └──────────┘     │  └──────────────┘    └──────────────┘    └───────────┘ │
                    │        │                    │                   │       │
  ┌──────────┐     │        ▼                    ▼                   ▼       │
  │ Phone    │────▶│  ┌──────────────┐    ┌──────────────┐    ┌───────────┐ │
  │ Camera   │     │  │ Image Capture│    │  HNSW Search  │    │ PubMed    │ │
  └──────────┘     │  │ & Preprocess │    │  + GNN Topo   │    │ Enrichment│ │
                    │  └──────────────┘    └──────────────┘    └───────────┘ │
                    │                                                         │
                    │  ┌──────────────────────────────────────────────────┐   │
                    │  │              Privacy & Compliance Layer           │   │
                    │  │  PII Strip │ Diff. Privacy │ Witness Chain │ BAA  │   │
                    │  └──────────────────────────────────────────────────┘   │
                    │                                                         │
                    │  ┌──────────────────────────────────────────────────┐   │
                    │  │              Google Cloud Infrastructure          │   │
                    │  │  Cloud Run │ Firestore │ GCS │ Pub/Sub │ CDN    │   │
                    │  └──────────────────────────────────────────────────┘   │
                    └─────────────────────────────────────────────────────────┘

Component Architecture

1. DermLite Device Integration Layer

DermLite devices attach to smartphones and provide standardized dermoscopic imaging.

Supported Devices:

  • DermLite HUD (Heads-Up Display): Hands-free dermoscopy with built-in camera. Connects via Bluetooth for metadata. Captures 1920x1080 polarized and non-polarized images.
  • DermLite DL5: Flagship handheld dermatoscope. 10x magnification, hybrid polarized/non-polarized mode. USB-C or Lightning adapter for phone attachment.
  • DermLite DL4: Compact pocket dermatoscope. Smartphone adapter available. LED illumination with polarization.
  • DermLite DL200 Hybrid: Contact and non-contact dermoscopy. Magnetic phone adapter.

Image Capture Flow:

DermLite Adapter
    │
    ├── Phone Camera (MediaStream API)
    │       │
    │       ▼
    │   getUserMedia({ video: { facingMode: 'environment',
    │                           width: 1920, height: 1080 } })
    │       │
    │       ▼
    │   Canvas capture (ImageData → Uint8Array)
    │       │
    │       ▼
    │   Preprocessing Pipeline
    │       ├── Color normalization (Shades of Gray)
    │       ├── Hair removal (DullRazor algorithm via WASM)
    │       ├── Lesion segmentation (Otsu + GrabCut via WASM)
    │       ├── Resize to 224x224 (bilinear interpolation)
    │       └── ImageNet normalization (mean=[0.485,0.456,0.406],
    │                                   std=[0.229,0.224,0.225])
    │
    ▼
Preprocessed Tensor [1, 3, 224, 224] float32

DermLite-Specific Processing:

  • Auto-detect polarization mode from EXIF metadata
  • Calibrate white balance using DermLite's known LED spectrum (4500K)
  • Extract measurement scale from DermLite's ruler overlay
  • Compensate for contact plate reflection artifacts in contact dermoscopy mode

2. CNN Classification Engine

Built on ruvector-cnn with MobileNetV3 Small backbone, compiled to WASM for browser execution.

Architecture:

Input [1, 3, 224, 224]
    │
    ▼
MobileNetV3 Small Backbone
    │   ├── Conv2D layers with SE (Squeeze-Excite) blocks
    │   ├── Inverted residuals with h-swish activation
    │   └── SIMD128 accelerated (AVX2 on server, WASM SIMD in browser)
    │
    ▼
Feature Vector [576-dim] (fp32 or INT8 quantized)
    │
    ├──▶ HNSW Search (k=5 nearest neighbors in brain)
    │       │
    │       ▼
    │     Reference cases with known diagnoses
    │
    ├──▶ SONA MicroLoRA Classifier (rank-2)
    │       │
    │       ├── Online adaptation per practice
    │       ├── EWC++ (lambda=2000) catastrophic forgetting prevention
    │       └── 7-class output probabilities
    │
    ├──▶ Grad-CAM Heatmap Generation
    │       │
    │       └── Spatial attention overlay on original image
    │
    └──▶ ABCDE Risk Scoring Module
            │
            ├── Asymmetry score (contour analysis)
            ├── Border irregularity (fractal dimension)
            ├── Color variance (histogram analysis across 6 color channels)
            ├── Diameter estimation (calibrated from DermLite scale)
            └── Evolution tracking (temporal comparison with prior images)

Classification Taxonomy (7 classes, aligned with HAM10000):

Class Label Risk Level
akiec Actinic keratosis / Bowen's Medium-High
bcc Basal cell carcinoma High
bkl Benign keratosis (solar lentigo, seborrheic keratosis) Low
df Dermatofibroma Low
mel Melanoma Critical
nv Melanocytic nevus (mole) Low
vasc Vascular lesion (angioma, angiokeratoma, pyogenic granuloma) Low

Performance Targets:

Metric Target Notes
Inference latency (WASM) <200ms On mid-range phone (Snapdragon 778G)
Inference latency (server) <50ms Cloud Run with AVX2
Melanoma sensitivity >95% Critical -- minimize false negatives
Melanoma specificity >85% Balance against unnecessary biopsies
Model size (INT8) <5MB For offline PWA cache
Embedding dimension 576 MobileNetV3 Small penultimate layer

3. Brain Integration Layer

The pi.ruv.io brain serves as the collective intelligence backbone.

Data Flow:

Diagnosis Complete
    │
    ▼
PII Stripping Pipeline
    │   ├── Remove patient identifiers
    │   ├── Remove GPS/location from EXIF
    │   ├── Remove device serial numbers
    │   ├── Generalize age to decade bracket
    │   ├── Generalize skin type to Fitzpatrick scale
    │   └── Hash remaining quasi-identifiers (k-anonymity, k>=5)
    │
    ▼
Differential Privacy Layer (epsilon=1.0)
    │   ├── Laplace noise on continuous features
    │   ├── Randomized response on categorical features
    │   └── Privacy budget tracking per practice per epoch
    │
    ▼
RVF Cognitive Container
    │   ├── Segment 0: 576-dim embedding (no raw image)
    │   ├── Segment 1: Classification probabilities
    │   ├── Segment 2: ABCDE scores
    │   ├── Segment 3: De-identified metadata
    │   │       ├── Fitzpatrick type (I-VI)
    │   │       ├── Body location (categorical)
    │   │       ├── Age decade
    │   │       ├── Lesion diameter (mm, bucketed)
    │   │       └── Dermoscopic features present
    │   └── Segment 4: Witness chain (SHAKE-256)
    │
    ▼
Brain Memory Insert
    │   ├── HNSW index update (128-dim projected via RlmEmbedder)
    │   ├── Knowledge graph edge creation
    │   ├── Sparsifier incremental update (ADR-116)
    │   └── GNN topology enrichment
    │
    ▼
Cross-Practice Learning
    │   ├── PageRank-weighted similarity across all practices
    │   ├── SONA meta-learning for population-level patterns
    │   ├── PubMed enrichment for newly observed lesion subtypes
    │   └── Federated model update (no raw data exchange)

Brain Endpoints Used:

Endpoint Purpose
brain_share Submit de-identified diagnosis embedding to collective
brain_search Find similar historical cases by embedding similarity
brain_page_create Create structured dermatology knowledge pages
brain_page_evidence Attach PubMed evidence to diagnostic findings
brain_drift Monitor embedding space drift as new lesion types emerge
brain_partition Cluster lesion subtypes via MinCut partitioning
brain_sync Sync local model updates with collective

4. RuVocal Chat Interface

The existing RuVocal SvelteKit application serves as the user interface, extended with dermatology-specific components.

UI Components:

RuVocal DrAgnes Mode
    │
    ├── Camera Capture Panel
    │       ├── Live viewfinder with DermLite overlay
    │       ├── Capture button (high-res still)
    │       ├── Image quality indicator
    │       └── Body location selector (anatomical diagram)
    │
    ├── Analysis Dashboard
    │       ├── Classification probabilities (bar chart)
    │       ├── Grad-CAM heatmap overlay (toggle)
    │       ├── ABCDE score breakdown (radar chart)
    │       ├── Similar cases panel (from brain search)
    │       └── Risk assessment summary (traffic light)
    │
    ├── Clinical Decision Support
    │       ├── Recommended action (monitor / biopsy / refer)
    │       ├── 7-point checklist auto-scoring
    │       ├── Menzies method evaluation
    │       ├── PubMed literature links
    │       └── Clinical guidelines citations (AAD, BAD)
    │
    ├── Patient Timeline
    │       ├── Lesion evolution tracking
    │       ├── Side-by-side comparison (temporal)
    │       ├── ABCDE score trend graphs
    │       └── Dermoscopic feature change detection
    │
    └── Chat Interface
            ├── Natural language queries about lesion
            ├── Differential diagnosis discussion
            ├── Literature search via brain
            └── Clinical note generation

5. Offline Architecture

Service Worker Strategy:

Service Worker (Workbox)
    │
    ├── Cache-First Strategy
    │       ├── CNN model weights (.onnx → WASM, ~5MB)
    │       ├── Application shell (HTML, CSS, JS)
    │       ├── WASM module (ruvector-cnn-wasm)
    │       └── Reference image embeddings (top-1000 from brain)
    │
    ├── Network-First Strategy
    │       ├── Brain search queries
    │       ├── PubMed enrichment
    │       └── Cross-practice sync
    │
    └── Background Sync
            ├── Queue diagnosis submissions for brain
            ├── Sync model updates when online
            └── Pull new reference embeddings nightly

Offline Capabilities:

  • Full CNN inference (WASM, no server needed)
  • ABCDE scoring (local computation)
  • Grad-CAM visualization (local computation)
  • HNSW search against cached reference embeddings
  • Queue-and-sync for brain submissions

6. Multi-Practice Knowledge Sharing

Privacy-Preserving Federation:

Practice A                    pi.ruv.io Brain                  Practice B
    │                              │                               │
    ├── De-identified ────────────▶│◀──────────── De-identified ───┤
    │   embedding                  │              embedding        │
    │                              │                               │
    │                    ┌─────────┴─────────┐                     │
    │                    │  Collective Model  │                     │
    │                    │  ── ── ── ── ── ─  │                     │
    │                    │  No raw images     │                     │
    │                    │  No patient IDs    │                     │
    │                    │  No practice IDs   │                     │
    │                    │  Only: embeddings  │                     │
    │                    │  + de-id metadata  │                     │
    │                    │  + witness chains  │                     │
    │                    └─────────┬─────────┘                     │
    │                              │                               │
    │◀── Updated model ───────────┤──────────── Updated model ───▶│
    │    weights (LoRA)            │             weights (LoRA)    │
    │                              │                               │

Key Privacy Guarantees:

  1. No raw images ever leave the device
  2. Only 576-dim embeddings are shared (non-invertible)
  3. Differential privacy (epsilon=1.0) applied to all shared data
  4. Practice identifiers are stripped before brain ingestion
  5. k-anonymity (k>=5) enforced on metadata attributes

7. Data Model

Core Entities:

interface DermImage {
  id: string;                          // UUID v7 (time-ordered)
  captureTimestamp: number;            // Unix ms
  deviceModel: DermLiteModel;          // 'HUD' | 'DL5' | 'DL4' | 'DL200'
  polarizationMode: 'polarized' | 'non_polarized' | 'hybrid';
  contactMode: 'contact' | 'non_contact';
  resolution: [number, number];        // pixels
  bodyLocation: BodyLocation;          // anatomical enum
  preprocessed: boolean;
  localStorageRef: string;             // IndexedDB key (never uploaded)
}

interface LesionClassification {
  imageId: string;
  modelVersion: string;                // semver of CNN weights
  brainEpoch: number;                  // brain state at classification time
  probabilities: Record<LesionClass, number>;  // 7-class
  topClass: LesionClass;
  confidence: number;
  abcdeScores: ABCDEScores;
  sevenPointScore: number;
  menziesScore: MenziesResult;
  gradCamOverlay: Uint8Array;          // local only, never uploaded
  witnessHash: string;                 // SHAKE-256
}

interface DiagnosisRecord {
  classificationId: string;
  clinicianReview: 'confirmed' | 'corrected' | 'pending';
  correctedClass?: LesionClass;        // ground truth if corrected
  clinicalAction: 'monitor' | 'biopsy' | 'excision' | 'refer' | 'dismiss';
  histopathologyResult?: HistopathClass; // gold standard if biopsy performed
  followUpScheduled?: number;          // Unix ms
}

interface PatientEmbedding {
  // This is what gets shared with the brain -- NO PHI
  embedding: Float32Array;             // 576-dim CNN embedding
  projectedEmbedding: Float32Array;    // 128-dim for HNSW
  classLabel: LesionClass;             // 7-class
  fitzpatrickType: FitzpatrickScale;   // I-VI
  bodyLocationCategory: string;        // generalized (e.g., 'trunk', 'extremity')
  ageDecade: number;                   // 20, 30, 40, ... (bucketed)
  diameterBucket: string;              // '<3mm', '3-6mm', '6-10mm', '>10mm'
  dermoscopicFeatures: string[];       // ['globules', 'streaks', 'blue_white_veil']
  dpNoise: Float32Array;               // Laplace noise applied (epsilon=1.0)
  witnessChain: Uint8Array;            // SHAKE-256 provenance
}

interface ABCDEScores {
  asymmetry: number;         // 0-2 (0=symmetric, 2=asymmetric both axes)
  border: number;            // 0-8 (irregular border segments out of 8)
  color: number;             // 1-6 (number of colors present)
  diameter: number;          // mm (calibrated from DermLite)
  evolution: number | null;  // change score vs prior image, null if first capture
  totalScore: number;        // weighted sum
  riskLevel: 'low' | 'moderate' | 'high' | 'critical';
}

8. API Design

RESTful + WebSocket Endpoints:

POST   /api/v1/analyze              Analyze a dermoscopic image (returns classification)
POST   /api/v1/analyze/batch        Batch analyze multiple images
GET    /api/v1/similar/:embeddingId Search brain for similar cases
POST   /api/v1/feedback             Submit clinician feedback/correction
GET    /api/v1/patient/:id/timeline Get lesion evolution timeline
WS     /api/v1/stream               Real-time analysis with progressive results

POST   /api/v1/brain/contribute     Share de-identified embedding with collective
GET    /api/v1/brain/search         Search collective for similar cases
GET    /api/v1/brain/literature     PubMed-enriched context for a lesion type
GET    /api/v1/brain/stats          Brain health and contribution metrics

GET    /api/v1/model/status         Current model version and performance metrics
POST   /api/v1/model/sync           Trigger model sync with brain
GET    /api/v1/model/weights        Download latest LoRA weights

GET    /api/v1/audit/trail/:id      Witness chain verification for a classification
GET    /api/v1/audit/provenance     Full provenance graph for a diagnosis

9. Security Architecture

┌─────────────────────────────────────────────────────────┐
│                    Security Layers                       │
│                                                          │
│  ┌────────────────────────────────────────────────────┐  │
│  │ L1: Transport Security                             │  │
│  │     TLS 1.3 (all connections)                      │  │
│  │     Certificate pinning (mobile)                   │  │
│  │     HSTS with preloading                           │  │
│  └────────────────────────────────────────────────────┘  │
│                                                          │
│  ┌────────────────────────────────────────────────────┐  │
│  │ L2: Authentication & Authorization                 │  │
│  │     OAuth 2.0 + PKCE (Google Identity)             │  │
│  │     RBAC: Admin, Clinician, Technician, Viewer     │  │
│  │     Practice-level tenancy isolation                │  │
│  │     Session timeout: 15 min inactive               │  │
│  └────────────────────────────────────────────────────┘  │
│                                                          │
│  ┌────────────────────────────────────────────────────┐  │
│  │ L3: Data Protection                                │  │
│  │     AES-256-GCM at rest (Google CMEK)              │  │
│  │     Field-level encryption for sensitive metadata  │  │
│  │     Raw images never leave device (IndexedDB)      │  │
│  │     Embeddings are non-invertible by design        │  │
│  └────────────────────────────────────────────────────┘  │
│                                                          │
│  ┌────────────────────────────────────────────────────┐  │
│  │ L4: Privacy Engineering                            │  │
│  │     PII stripping (brain redaction pipeline)       │  │
│  │     Differential privacy (epsilon=1.0, Laplace)    │  │
│  │     k-anonymity (k>=5) on quasi-identifiers        │  │
│  │     Witness chain audit trail (SHAKE-256)          │  │
│  └────────────────────────────────────────────────────┘  │
│                                                          │
│  ┌────────────────────────────────────────────────────┐  │
│  │ L5: Application Security                           │  │
│  │     CSP headers (strict)                           │  │
│  │     CORS whitelist (practice domains only)         │  │
│  │     Input validation at all boundaries             │  │
│  │     Rate limiting (100 analyses/hour/practice)     │  │
│  └────────────────────────────────────────────────────┘  │
└─────────────────────────────────────────────────────────┘

10. 25-Year Architecture Evolution

Phase 1 (2026-2028): Foundation

  • Mobile-first PWA with DermLite integration
  • 7-class CNN classification (HAM10000 base)
  • Brain integration for collective learning
  • HIPAA-compliant deployment on Google Cloud

Phase 2 (2028-2032): Expansion

  • 50+ lesion subtypes (expanded taxonomy)
  • Multi-modal input (clinical photo + dermoscopic + metadata)
  • EHR integration (Epic FHIR, Cerner, athenahealth)
  • Teledermatology workflow (store-and-forward)
  • Whole-body photography with lesion change detection

Phase 3 (2032-2040): Advanced Imaging

  • Confocal microscopy integration (RCM)
  • Optical coherence tomography (OCT) fusion
  • Multispectral imaging analysis
  • 3D lesion reconstruction and volumetric analysis
  • Genomic risk score integration (GWAS SNP panels)

Phase 4 (2040-2051): Autonomous Intelligence

  • AR-guided biopsy and surgery overlay
  • Continuous monitoring via smart wearables and ambient sensors
  • Brain-computer interface for clinical gestalt augmentation
  • Self-evolving models that discover new lesion subtypes
  • Global elimination of late-stage melanoma detection