# HelioX Bundle (no git history)

This directory is a clean snapshot of three projects copied under `$HOME/` with **no `.git/` history**:

- `heliox/` — HelioX (C++/CUDA + Python bindings)
- `L5PC_TEST/` — NEURON vs HelioX comparison repro + HPC passive test
- `worm_demo/` — worm learning demo (NEURON frontend + HelioX backend)
- `hpc_net_learn/` — HPC network learning demo (PassiveHPC-based, includes MOD files + MNIST subset)

The copies exclude common build/run artifacts (e.g. `output/`, `runs/`, `__pycache__/`, `x86_64/`), but HelioX’s `build_sys/` is included so the shipped `python_lib/heliox*.so` symlink works.

## 0) Quick environment variables

In a shell, from this folder:

```bash
cd "$HOME/heliox_bundle_20260129_111148"
export HELIOX_PYTHON_LIB="$PWD/heliox/python_lib"
export NRN_PYTHON_LIB="${NRN_PYTHON_LIB:-$HOME/nrn/install/lib/python}"
export PYTHONPATH="$NRN_PYTHON_LIB:${PYTHONPATH:-}"
```

If you already have `neuron` installed in your Python environment, you can omit `NRN_PYTHON_LIB`.

## 1) HelioX Python import check

```bash
PYTHON=python3
$PYTHON - <<'PY'
import os, sys
sys.path.insert(0, os.environ["HELIOX_PYTHON_LIB"])
import heliox
print("heliox ok:", heliox)
PY
```

## 2) L5PC compare repro

```bash
cd "$HOME/heliox_bundle_20260129_111148/L5PC_TEST"

# Example: run NEURON + HelioX GPU and plot
PYTHONPATH="$NRN_PYTHON_LIB:${PYTHONPATH:-}" \
HELIOX_PYTHON_LIB="$HELIOX_PYTHON_LIB" \
python run_save_traces.py --mode neuron --case demo --stim-preset repro_moderate

PYTHONPATH="$NRN_PYTHON_LIB:${PYTHONPATH:-}" \
HELIOX_PYTHON_LIB="$HELIOX_PYTHON_LIB" \
python run_save_traces.py --mode heliox-gpu --case demo --stim-preset repro_moderate

python plot_compare_to_neuron.py --out-dir output --case demo --baseline neuron --modes heliox_gpu
```

PassiveHPC (HPC) test is documented in `L5PC_TEST/README.md`.

## 3) Worm demo (HelioX backend)

```bash
cd "$HOME/heliox_bundle_20260129_111148/worm_demo"

# Install python deps for the demo environment (if needed)
python3 -m pip install -r requirements.txt

# Run a short smoke (200ms)
HELIOX_PYTHON_LIB="$HELIOX_PYTHON_LIB" PYTHON=python3 \
  ./run.sh --epochs 1 --tstop-ms 200 --replay 1 --out ./runs/smoke --suffix smoke
```

Notes:
- The demo will auto-build NEURON mechanisms into `x86_64/` if needed (not committed here).
- If `import neuron` doesn’t work, set `NRN_PYTHON_LIB` as shown above.

## 4) HPC Net Learn (from hpc-net-learn.tar)

This is a separate, standalone demo folder copied into the bundle as `hpc_net_learn/`.

It includes:
- `PassiveHPC.hoc` + morphology `.asc`
- MOD files under `hpc_net_learn/mod/`
- `mnist.npz` used by the training scripts

Typical workflow (NEURON mechanisms must be compiled once):

```bash
cd "$HOME/heliox_bundle_20260129_111148/hpc_net_learn"
export PYTHONPATH="$NRN_PYTHON_LIB:${PYTHONPATH:-}"

# Build mechanisms (creates x86_64/, ignored by git in this bundle)
nrnivmodl mod

# Run training (adjust script/args as needed)
python3 train_hpc_net.py
```
