# L5PC_COMPARE: L5PC voltage-diff repro (NEURON / CoreNEURON / HelioX)

This folder is a small, shareable repro to compare the soma voltage trace when
running the *same* L5PC model with different engines:

- `neuron` (baseline)
- `coreneuron` CPU (via NEURON's CoreNEURON interface)
- `coreneuron` GPU (via NEURON's CoreNEURON interface)
- `heliox` on CPU
- `heliox` on GPU

To make debugging easier, the workflow is split into two phases:

1. **Run-and-save** (deterministic): run one backend at a time and save `t` and `v(t)` into `.npz`
2. **Plot/compare**: load the saved files and compare everything against the NEURON baseline

This avoids re-running multiple backends every time you just want to tweak plotting/metrics.

## Phase 1: run + save traces

Run a single mode:

```bash
python run_save_traces.py --mode neuron --case demo --stim-preset repro_moderate
python run_save_traces.py --mode coreneuron-cpu --case demo --stim-preset repro_moderate
python run_save_traces.py --mode coreneuron-gpu --case demo --stim-preset repro_moderate
python run_save_traces.py --mode heliox-cpu --case demo --stim-preset repro_moderate
python run_save_traces.py --mode heliox-gpu --case demo --stim-preset repro_moderate
```

Or run all 4 modes via subprocess isolation:

```bash
python run_save_traces.py --mode all --case demo --stim-preset repro_moderate
```

It writes (by default under `output/`):

- `output/demo__neuron.npz`
- `output/demo__coreneuron_cpu.npz`
- `output/demo__coreneuron_gpu.npz`
- `output/demo__heliox_cpu.npz`
- `output/demo__heliox_gpu.npz`

## Phase 2: plot + compare (baseline = NEURON)

```bash
python plot_compare_to_neuron.py --case demo
```

Outputs:

- `output/demo__compare.png`
- `output/demo__errors.npz` (contains per-mode errors + JSON stats)

## PassiveHPC (HPC) test (NEURON vs HelioX)

This repo also vendors a small PassiveHPC network test so recipients do not need any external `newhpc/` checkout.

Run a quick NEURON baseline and a HelioX GPU run (saves `t` and `v(t)` for cell 0 soma):

```bash
export PYTHONPATH="$HOME/nrn/install/lib/python:$PYTHONPATH"
export HELIOX_PYTHON_LIB="/path/to/heliox/python_lib"  # or any heliox python_lib path

python hpc_passive_run_save_traces.py --mode neuron --case hpc_smoke --ncell 1 --dt 0.025 --tstop 10
python hpc_passive_run_save_traces.py --mode heliox-gpu --case hpc_smoke --ncell 1 --dt 0.025 --tstop 10

python plot_compare_to_neuron.py --out-dir output --case hpc_smoke --baseline neuron --modes heliox_gpu \\
  --abs-error-unit 1e-10 --abs-error-ymax 2 --no-log-abs-error
```

Notes:

- The script will auto-build `hpc_assets/mod/vecevent.mod` into `hpc_assets/x86_64/` if needed (ignored by git).
- For larger networks, increase `--ncell` (e.g. `--ncell 500`) and shorten `--tstop` as needed.

## Requirements

- NEURON Python module available (`python -c "import neuron"` works)
  - Your local NEURON checkout is at `$HOME/nrn` (on this machine), but recipients can use any NEURON install.
- HelioX Python module available (`python -c "import heliox"` works)
  - If HelioX is not installed, set:
    - `HELIOX_PYTHON_LIB=/path/to/heliox/python_lib`
- For the `coreneuron` mode: CoreNEURON-enabled NEURON build + CoreNEURON mech library for these MOD files:
  - `nrnivmodl -coreneuron mod` (creates `x86_64/libcorenrnmech.so`)
  - On this machine/NEURON build, `nrnivmodl -coreneuron` requires NMODL embedded-python env vars:
    - `export NMODLHOME=$HOME/nrn/install`
    - `export NMODL_PYLIB=/usr/lib/libpython3.14.so`
  - If you use NVHPC for CoreNEURON GPU builds, you may need to source:
    - `source /opt/nvidia/hpc_sdk/activate`

## Notes

- All scripts intentionally do **single-run** only (no multi-run loops).
- We set `usetable_* = 0` to avoid lookup-table drift in exported data.
- Default stimulus uses **69 dendritic IClamps**. You can switch to a single soma clamp via `--stim soma_single`.
- `repro_single_run.py` is a legacy "one-shot plot" script (NEURON vs HelioX) kept for convenience, but the preferred workflow is `run_save_traces.py` + `plot_compare_to_neuron.py`.
