ADR-154 §16 named three observer-side levers for closing the
saturated-regime throughput gap that (a) SIMD (commit 2) and (b) Opt D
delay-sorted CSR (commit 7) left on the table. The first lever —
dropping the sparse-Fiedler dispatch threshold — was measured in
commit 9 and turned out to be a 3× regression. This commit implements
the second: adaptive detect cadence.
Logic (14 LOC addition to src/observer/core.rs): a helper
`current_detect_interval_ms(&self)` reads the co-firing-window
density per `on_spike` call. If the window holds more than
`5 × num_neurons` spikes — equivalent to ≥ 100 Hz average per
neuron over the 50 ms window — back off to a 4× cadence (20 ms
instead of 5 ms). Drop back to 5 ms as soon as density falls below
threshold. Both sides are deterministic given the spike stream, so
AC-1 repeatability is preserved.
Measured on the reference host (N=1024, 120 ms saturated, SIMD
default on Ryzen-class CPU):
lif_throughput_n_1024/baseline : 6.86 s → 1.70 s (4.03× vs pre)
lif_throughput_n_1024/optimized : 6.74 s → 1.57 s (4.29× vs pre)
ADR-154 §3.2 saturated-regime target was ≥ 2× over scalar-opt.
**Measured: 4.29×. HIT — the first optimization on this branch to
clear that target at the top-line bench.**
Acceptance-test suite impact (proportional to detector share each
test spent in saturation):
acceptance_causal (AC-5) 395 s → 100 s (4.0×)
acceptance_core (AC-1..AC-4) 63 s → 16 s (4.0×)
integration 32 s → 8.5 s (3.8×)
sparse_fiedler_10k 20 ms unchanged (well below threshold)
AC-4-strict guarantee preserved. The 20 ms backoff interval gives
≥ 2 detects inside any 50 ms lead window, so the precognitive claim
(≥ 50 ms lead on ≥ 70 % of 30 trials) is unaffected. Test passes
with 30/30 trials detecting the constructed-collapse marker on the
new cadence.
AC-1 bit-exactness preserved. Two repeat runs produce identical
spike traces — the adaptive interval is deterministic per
`(connectome_seed, engine_seed, stimulus_schedule)`.
Knock-on effect on Opt D (commit 7): with the detector no longer
dominating by 450:1, Opt D's ~5 ms-per-step kernel savings should
now represent ~120 ms of the new 1.57 s median. A clean paired-
sample criterion bench to isolate the Opt-D-attributable share is
named as follow-up.
Commit arc summary at head:
Commit 2 SIMD (Opt C) 1.013× — MISS
Commit 7 Opt D delay-sorted CSR 1.00× — MISS at top-line
Commit 9 Drop sparse-Fiedler threshold 3× regression (disproven)
Commit 10 Adaptive detect cadence 4.29× — HIT ≥ 2× target
The lesson the full arc makes concrete: throughput gaps diagnosed
as "kernel-bound" via a pre-measurement guess can turn out to be
*detector-bound* (commit 7's surprise), and even after that
correction the right remediation is not necessarily the
structurally-obvious one (commit 9's regression). The win came
from changing *when* the detector runs, not *what* it does or *how*
it is represented.
All 58 tests pass. Positioning rubric held across all 10 commits.
Co-Authored-By: claude-flow <ruv@ruv.net>
ADR-154 §16 (commit 8) named three candidate levers for closing the
saturated-regime throughput gap that Opt D (delay-sorted CSR) exposed.
The first-listed lever was "adjust the sparse-Fiedler dispatch
threshold so the saturated N=1024 detector uses the sparse path,"
predicted to drop detector cost by ≥ 10× and make Opt D's 1.5×
kernel win visible on the top-line bench.
Commit 9 measures that prediction:
- SPARSE_FIEDLER_N_THRESHOLD lowered from 1024 to 96 (sparse path
covers everything above the Jacobi exact-path ceiling).
- AC-1 bit-exact at N=1024 still passes (191 s vs prior 60 s; 3×
slower — a precursor of the full-bench result).
- `cargo bench -p connectome-fly --bench lif_throughput --
lif_throughput_n_1024`: baseline 6.75 s → 20.1 s on the same
host. **3× regression, not a win.**
Root cause (the lesson):
The sparse path (ruvector-sparsifier::SparseGraph) accumulates edges
into a HashMap, then canonicalises into CSR, then runs shifted-power
iteration. At n ≥ 10 000 that total is cheaper than building a dense
n×n matrix (40× memory win, measured at n=10K in 19 ms — BENCHMARK
§4.8). At n ≈ 1024 the HashMap + canonicalisation hop is MORE
expensive than just allocating the n² floats — calloc's OS-zeroed-
page trick makes the dense allocation nearly free, while the HashMap
pays per-insert overhead for every co-firing edge.
**The sparse path is a scale win at n ≥ 10 000, not a speed win at
demo n ≈ 1024.** This is the 5th measurement-driven discovery on this
branch and the 2nd one that directly disproves a pre-measurement
prediction:
1. Degree-stratified AC-5 null collapses at N=1024 SBM (commit 3)
2. SIMD saturated gain = 1.013×, not ≥ 2× (commit 4)
3. Observer buffer-reuse is 3% slower than calloc (reverted)
4. Fiedler detector dominates saturated bench 450:1 (commit 7)
5. Sparse-Fiedler threshold drop is 3× slower at N=1024 (this)
Threshold restored to 1024 in `src/observer/core.rs`. ADR-154 §16
updated with the measurement and the corrected next-lever ordering:
adaptive detect cadence + incremental Fiedler accumulator remain
the two plausible levers. The ADR §14 risk register already carried
the "pre-measurement diagnosis mis-directs the next optimization"
row from commit 8; this commit extends the lesson: even after a
correct top-level diagnosis, the obvious remediation still needs
the measurement.
No test weakened. AC-1 still bit-exact at N=1024. All 58 tests on
this branch still pass.
BENCHMARK.md §4.7 extended with the full regression narrative and
the corrected roadmap.
Co-Authored-By: claude-flow <ruv@ruv.net>
Merges commits 5 (cf21327c9), 6 (b805d7158), 7 (a3cca1c5c) produced
concurrently by a 3-agent hierarchical swarm in isolated worktrees.
Each agent touched a disjoint subtree; the three merges landed clean
in commit-order and the consolidated test suite is green:
58 tests pass / 0 fail across 11 test binaries:
lib (unit) 16 (was 13, +3 delay-csr + gpu fallback units)
flywire_ingest 17 (new)
sparse_fiedler_10k 2 (new)
delay_csr_equivalence 2 (new)
acceptance_core 4 (AC-1, AC-2, AC-4-any, AC-4-strict)
acceptance_partition 2 (AC-3a structural, AC-3b functional)
acceptance_causal 1 (AC-5)
integration 3
analysis_coherence 2
connectome_schema 5
lif_correctness 4
Docs updated:
- ADR-154 §11: full 7-commit timeline (this is commit 8).
- ADR-154 §13: 3 items of the follow-up list marked ✓ shipped with
"→ next" tails pointing at the remaining production levers.
- ADR-154 §14 (risk register): new row — "Pre-measurement diagnosis
mis-directs the next optimization". Commit 2 named three candidate
hot paths for the saturated-regime gap; commit 7's measurement found
the actual dominant cost was a fourth item (the Fiedler detector).
- ADR-154 §16 (new): the measurement-driven discovery. Delay-sorted
CSR is 1.5× at the kernel but 1.00× top-line because the Fiedler
detector dominates wallclock by ~450:1 at saturated N=1024. The
detector's sparse path (commit 6) is already shipped but dispatches
at n > 1024, just above the saturated bench's active-set ceiling.
The right next lever is adjusting that threshold, not more SIMD
lanes or more kernel tricks.
- BENCHMARK.md §0: summary table grows a delay-csr row and a sparse-
fiedler row; both with measured numbers.
- BENCHMARK.md §4.7: new — Opt D measured results + the ~450:1
detector-dominates finding + the three named observer-side levers
to make the kernel win visible on the top-line bench.
- BENCHMARK.md §4.8: new — sparse-Fiedler dispatch table + memory
budget at four scales (from N=1024 where dense still wins to
N=139 000 where dense is infeasible, ~100× memory reduction).
- BENCHMARK.md §4.9: new — FlyWire v783 ingest module notes.
- README §What's new: top-level summary of the three capabilities.
- README directory layout: reflects the new modules and tests.
Four honest findings surfaced on this branch:
1. Degree-stratified AC-5 null collapses at N=1024 SBM (commit 3)
2. SIMD saturated-regime speedup = 1.013×, not ≥ 2× (commit 4)
3. Buffer-reuse in Observer is a 3% regression vs calloc (reverted)
4. Fiedler detector dominates saturated bench by ~450:1 (this)
Each finding is documented; each names the next lever rather than
relaxing a threshold. No test was weakened to force a green.
Positioning rubric (no consciousness / upload / AGI) held across
all 8 commits.
Co-Authored-By: claude-flow <ruv@ruv.net>
Commit 7a83adffe investigated a degree-stratified random null for AC-5
but shipped the interior-edge null after the stratified variant
collapsed the effect size at N=1024 synthetic SBM (hub concentration
made matched-degree cuts equally disruptive — mean_cut = mean_rand =
0.373 Hz exactly). ADR-154 §8.4 §9.2 §9.5 §11 §13 and README line 50
and the determinism section were still framed around the stratified
null as if it had landed. This commit corrects the record.
- ADR-154 §8.1: AC-5 row — "degree-matched random edges" → "non-boundary
interior edges"
- ADR-154 §8.4: rewrite — attempted stratified null, why it collapsed,
why shipped null is interior-edge, named as FlyWire-ingest follow-up
- ADR-154 §9.2: claim rephrased to interior-edge null (shipped) with
stratified null at FlyWire scale as future work; includes measured
z_cut = 5.55σ and honest z_rand = 1.57σ gap
- ADR-154 §9.5: scope/evidence table row updated
- ADR-154 §11: Commit 2 paragraph corrected with full six-deliverable
inventory (SIMD, GPU, AC-3 split, AC-4-strict, BASELINES.md, ADR
expansion) + explicit test count delta (27 → 32) + explicit revert
note for the stratified null
- ADR-154 §13: added "Degree-stratified AC-5 null at FlyWire ingest
scale" as named follow-up; prototype sampler preserved in git
history for direct port
- README.md §Directory layout: acceptance_causal.rs description
corrected to "interior-edge null"
- README.md §Determinism: extended to reflect the three LIF paths
(baseline heap+AoS, optimized wheel+SoA, SIMD wheel+SoA+f32x8)
instead of the prior two, and points at ADR-154 §15.1
No code or test changes. All 32 tests still pass unchanged.
Co-Authored-By: claude-flow <ruv@ruv.net>
Follow-up to 757f4fa22. Closes the gaps the SOTA-closer agent was
chasing before it stalled. Validated on 2026-04-22 (session restart).
Landed
------
- SIMD LIF path (src/lif/simd.rs, 308 LOC): wide::f32x8 vectorized
subthreshold update (V, g_exc, g_inh) gated behind the `simd`
feature (on by default). Falls back to scalar on hosts that cannot
issue the wider ops. Unit-equivalence test: SIMD output matches
scalar to 1e-6 on deterministic random input.
- GPU SDPA module (src/analysis/gpu.rs, 205 LOC + GPU.md):
cudarc-backed scaled-dot-product-attention for 100 ms spike-raster
embeddings. Gated behind `gpu-cuda`; panics loudly with a clear
diagnostic if cudarc cannot link against the host CUDA toolkit.
Determinism preserved via fixed-seed RNG; CPU fallback unit-tested.
- AC-3 dual path (tests/acceptance_partition.rs +216/-111):
* AC-3a structural: ruvector-mincut on the static connectome,
compared to SBM ground-truth module labels via ARI.
* AC-3b functional: coactivation-mincut + class-histogram L1
distance (the original test, now scoped to what it actually
measures).
src/analysis/structural.rs (204 LOC) wraps the static-graph path
so the production future-work (connectome-crate split, ADR-154 §5)
has a clean extension point.
- BASELINES.md (75 lines): honest side-by-side against Brian2 +
C++ codegen, Auryn, NEST. Published numbers + our measured numbers
on identical workload (1024 neurons, 120 ms simulated). No
rhetorical spin — the ablation table shows where we win and
where we lose. Brian2/Auryn/NEST numbers cite their published
papers (see §4 footnotes).
- BENCHMARK.md expansion (+214 lines → 295 total): SIMD-path
ablation rows, GPU throughput projection, CPU baseline vs
optimized vs SIMD, full reproducibility metadata (CPU model,
frequency, cache sizes, rustc/cargo/kernel versions, RNG seeds,
RUSTFLAGS), one-liner repro command.
- ADR-154 expansion (+214 lines → 416 total): §3.4 AC-3 dual-path
rationale, §4.2 GPU SDPA scope boundaries, §8.4 honest null-model
follow-up (see "AC-5 degree-stratified null" below).
- Feature-flag hygiene: Cargo.toml defaults to `simd`; `gpu-cuda`
opt-in. Clippy clean at --all-features. fmt clean.
Not landed (documented)
-----------------------
- AC-5 degree-stratified null: implemented, but the matched-degree
random sample drew edges from the same high-degree hubs as the
boundary, collapsing the effect size (z_cut = z_rand = 2.12
exactly). This is a scientifically interesting finding — it says
that *at demo scale, any hub-matched cut is equally disruptive*,
which is itself a result worth investigating at production scale.
ADR-154 §8.4 records this as nightly-bench follow-up work.
acceptance_causal.rs reverted to 757f4fa22's interior-edge null,
which is the known-green formulation (z_cut = 5.55σ, z_rand = 1.57σ
on re-run).
Tests
-----
32 pass, 0 fail across 9 test binaries (was 27 at 757f4fa22, +5):
lib 10 (was 7; +3: simd equivalence,
gpu cpu-fallback determinism,
gpu cpu-fallback range)
acceptance_core 4 (was 3; +1: AC-4 strict lead)
acceptance_partition 2 (was 1; +1: AC-3a structural)
acceptance_causal 1 (unchanged: AC-5 pass)
analysis_coherence 2
connectome_schema 5
integration 3
lif_correctness 4
bin (run_demo) 1
All five acceptance criteria (AC-1..AC-5) pass. No hype language
added. No MuJoCo / NeuroMechFly bindings. No modifications to
sibling crates.
Do NOT push.
Co-Authored-By: claude-flow <ruv@ruv.net>
Main recently merged ADR-151 (Miller-Rabin prime optimizations, PR #358)
and ADR-152 is reserved for Obsidian Brain Plugin (ADR-SYS-152), so
renumber the kalshi integration ADR to 153 to avoid collision.
- Rename docs/adr/ADR-151-kalshi-neural-trader-integration.md →
docs/adr/ADR-153-kalshi-neural-trader-integration.md
- Update 5 references: workspace Cargo.toml comment, the two kalshi
crate descriptions, the lib.rs doc-comment, and the ADR title line.
- Resolve .gitignore: keep both trailing additions (.kalshi + bench_data/).
Co-Authored-By: claude-flow <ruv@ruv.net>
New crate ruvector-kalshi: RSA-PSS-SHA256 signer (PKCS#1/#8), GCS/local/env
secret loader with 5-min cache, typed REST + WS DTOs, Kalshi→MarketEvent
normalizer (reuses neural-trader-core), transport-free FeedDecoder,
reqwest-backed REST client with live-trade env gate, and an offline
sign+verify example that validates against the real PEM.
New crate neural-trader-strategies: venue-agnostic Strategy trait, Intent
type, RiskGate (position cap, daily-loss kill, concentration, min-edge,
live gate, cash check), and ExpectedValueKelly prior-driven strategy.
36 unit tests pass across both crates. End-to-end offline validation
confirmed against the real Kalshi PEM via both local and GCS sources.
Co-Authored-By: claude-flow <ruv@ruv.net>
Phase 0 implementation revealed that the original PRD §6 targets
(50 ns / 200 ns for is_prime_u64 worst case) were structurally
unachievable in safe Rust on Apple-silicon. Apples-to-apples competitor
benchmark in the same binary on the same machine measured num-prime
0.4.4 at 884 ns vs ours at 15.63 µs — ~17.7× headroom recoverable via
Montgomery reduction in Phase 0.1, but not the ~300× the original target
implied. The 50 ns figure was a pre-implementation estimate that did not
survive contact with measured hardware.
ADR-151 (docs/adr/ADR-151-miller-rabin-prime-optimizations.md)
- Status promoted from "Proposed" to "Accepted (Phase 0 landed
2026-04-16; performance targets revised)".
- New "Phase 0 Findings (2026-04-16)" section documenting what landed,
measurements vs original targets, num-prime competitor baseline, the
revised target band, and Phase 0.1 scope (Montgomery only).
- Explicit rejection of swapping to the empirical 7-witness set:
Sinclair-12 is theorem-proven across all u64; the 7-witness sets in
the literature are empirically tested up to 2^64 but not proven, and
swapping invalidates the A014233(11) canary in the pseudoprime test.
PRD §6 (docs/research/miller-rabin-optimizations/PRD.md)
- Revision header noting the relaxation.
- is_prime_u64(p) worst-case row updated to ≤ 1 µs (was 50 ns) M-series
/ ≤ 4 µs (was 200 ns) WASM.
- New §6.1 "Empirical findings (Phase 0)" with the measurement table
and the num-prime baseline data.
GROK-REVIEW-REQUEST.md (new, 424 lines)
- Self-contained briefing used to obtain external Grok review of the
Phase 0 design and Phase 0.1 plan: §1 binding context, §2 implementation
embedded verbatim, §3 measurements + competitor baseline, §4 four-section
ask (correctness, perf plan ranked, architecture, validation
methodology), §5 response format. Constraints block forbids
"just use num-prime" answers and pins the canary witness set.
Adds the binding ADR and full PRD for the Prime-Indexed Acceleration
Layer (PIAL): a single ~250-LoC Miller-Rabin primality utility in
crates/ruvector-collections that unblocks five independent prime-aware
optimizations across hashing, sharding, sketching, and the pi-brain
witness chain.
Use cases:
* Shard-router prime modulus — closes ADR-058 finding #6
* HNSW prime-bucket adjacency — micro-hnsw-wasm, hyperbolic-hnsw
* Certified-prime LSH modulus — sparsifier, attn-mincut
* Witness-chain ephemeral primes — pi-brain brain_share payload
* Anti-aliasing prime strides — sparsifier sampler
Generation strategy combines a compile-time table of primes near 2^k
(fast path, ~1ns) with a Miller-Rabin descent fallback (~250ns). The
table is generated by build.rs from the MR implementation and
cross-checked against MR in CI, so MR remains the source of truth.
Includes HANDOFF.md with Phase 0 deliverables for the next session.
ADR and PRD pin acceptance criteria, performance targets, and a
six-phase rollout (each phase ships as a separate PR).
The Related field incorrectly referenced ADR-003 as KV Cache and
ADR-005 as LoRA Adapter Loading. In the actual repo:
- ADR-003 is SIMD Optimization Strategy
- ADR-004 is KV Cache Management (correct target)
- ADR-005 is WASM Runtime Integration (correct name)
No LoRA Adapter Loading ADR exists; ADR-005 (WASM) is the genuine
related decision for memory management concerns.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Offload embedding from Cloud Run HashEmbedder (128-dim, hash-based) to
local RuvLtra Q4 transformer (896-dim, ANE-optimized, with SONA learning).
Architecture:
- Mac Mini runs new ruvltra-embed-server binary on :8090
- Tailscale mesh VPN connects Cloud Run brain to Mac Mini
- TailscaleEmbedder variant added to brain embedder chain
- HashEmbedder fallback on unreachable endpoint
- 3-week migration plan for 10K existing memories
Expected: 7x semantic info per embedding, NDCG@10 0.3→0.85,
$0/month cost (Tailscale free, Mac Mini already on), 50ms per embed
(acceptable on write path).
Co-Authored-By: claude-flow <ruv@ruv.net>
Add deep research into three-axis KV cache compression:
- TriAttention (arXiv:2604.04921): trigonometric RoPE-based token sparsity, 10.7x
- Stacked compression: TriAttention × TurboQuant for ~50x KV reduction
- ADR-147: formal architecture decision with GOAP implementation plan
No published work combines these orthogonal methods. First-mover opportunity
for ruvLLM edge inference (128K context in 175MB on Pi 5).
Co-authored-by: Reuven <cohen@ruv-mac-mini.local>
ADR-145: Fix training pipeline issues across WASM and NAPI bindings.
WASM (ruvector-attention-wasm):
- Replace serde_wasm_bindgen deserialization of negatives param with
explicit js_sys::Float32Array conversion. TypedArrays don't
deserialize via serde — use js_sys::Array iteration instead.
NAPI (ruvector-attention-node):
- Add stepInPlace() to SGD, Adam, AdamW optimizers for zero-copy
in-place parameter mutation via Float32Array's AsMut<[f32]>
- Document that step() returns a NEW array (callers must use return)
Note: LoRA B=0 initialization in learning-wasm is correct by design
(Hu et al. 2021) — documented in ADR-145, no code change needed.
Co-authored-by: Reuven <cohen@ruv-mac-mini.local>
Full 981-module output too large for git (621MB).
Available as GitHub release download (121MB tar.gz):
https://github.com/ruvnet/rudevolution/releases/tag/v0.1.0-claude-code-v2.1.91
Repo keeps: modules-manifest.json (lists all 661 modules),
witness.json, metrics.json, README.md
Co-Authored-By: claude-flow <ruv@ruv.net>
Full decompile: 885/885 modules parse (100%)
Manifest lists all modules with sizes.
Full source too large for git (419MB) — generate via:
cargo run --release -p ruvector-decompiler --example run_on_cli -- \
$(npm root -g)/@anthropic-ai/claude-code/cli.js --output-dir ./decompiled
Co-Authored-By: claude-flow <ruv@ruv.net>
v2 model trained on 8,201 pairs (5x expansion):
- Val accuracy: 75.7% → 95.7% (+20 points)
- Val loss: 0.914 → 0.149 (6x improvement)
- Beats JSNice (63%), DIRE (65.8%), VarCLR (72%) by wide margin
Updated all ADRs and research docs with v2 results.
Exported weights-v2.bin (2.6MB) for pure Rust inference.
Co-Authored-By: claude-flow <ruv@ruv.net>
SOTA research: added implementation status table, validation results
showing 75.7% accuracy beating JSNice (63%), DIRE (65.8%), VarCLR (72%).
Model weight analysis: added Section 8 with trained model details,
inference backends, training pipeline, and ADR status.
Co-Authored-By: claude-flow <ruv@ruv.net>
Three fixes for recurring pi.ruv.io outages:
1. SSE connection limiter (max 50) — prevents MCP reconnect storms from
exhausting Cloud Run concurrency slots. Tracks active count with
AtomicUsize, rejects excess with 429.
2. Pipeline optimize rate limiter — max 1 concurrent request with 30s
cooldown. Prevents scheduler thundering herd from CPU-saturating
the instance.
3. Firestore pagination offset fallback — when page tokens go stale
after OOM restart (400 Bad Request), switches to offset-based
pagination to load all documents instead of stopping at first batch.
Also adds /v1/ready lightweight probe (zero-cost, no state access)
for Cloud Run health checks.
ADR-130 documents the full decoupling architecture (SSE service split).