nexus-stats 6.0.1

Fixed-memory, zero-allocation streaming statistics for real-time systems
Documentation
# SlewLimiter — Hard Rate-of-Change Clamp

**Limits how fast the output can change per sample.** Different from
smoothing — this is a hard constraint, not a filter.

| Property | Value |
|----------|-------|
| Update cost | ~3 cycles |
| Memory | ~16 bytes |
| Types | `SlewF64`, `SlewI64` |
| Output | Rate-limited value |
| Error handling | Returns `Result<_, DataError>` on NaN/Inf input |

## What It Does

```
  Input with spike:              SlewLimiter output (max_rate = 5):

  Value                          Value
  100 ┤     ·                    100 ┤
   80 ┤                           80 ┤
   60 ┤                           60 ┤          ╱──── limited to +5/sample
   40 ┤  ·     ·                  40 ┤     ╱──╱
   20 ┤                           20 ┤  ╱─╱
    0 ┤─·──────── ·               0 ┤─·
      └──────────── t                └──────────── t
      spike passes through          spike is rate-clamped
```

The output can never change by more than `max_rate` per sample.
Spikes are slew-limited to a ramp. Gradual changes pass through unchanged.

## When to Use It

- Output conditioning: prevent actuator damage from sudden jumps
- Anti-spike: limit how fast a control signal can change
- Different from [EMA]ema.md (smooths everything) and [MultiGate]multi-gate.md
  (detects but doesn't correct)

## Configuration

```rust
let mut slew = SlewF64::new(5.0);  // max change of 5.0 per sample

slew.update(0.0).unwrap();    // → 0.0
slew.update(100.0).unwrap();  // → 5.0 (clamped)
slew.update(100.0).unwrap();  // → 10.0 (clamped)
slew.update(10.0).unwrap();   // → 10.0 (within range, passes through)
```

## Performance

| Operation | p50 | p99 |
|-----------|-----|-----|
| `SlewF64::update` | ~3 cycles | ~3 cycles |

Uses `clamp()` which compiles to `maxsd`/`minsd` (branchless).