hoc2swc is a Python library that converts the morphology of neuron models defined using NEURON simulator HOC files to the popular SWC morphology format. The library can also be used to convert cell morphologies instantiated in NEURON simulator (e.g. models that were built using NEURON+Python).
Once converted to SWC, tools that can consume SWC files can be used to compute SWC morphology metrics, create professional 3D neuron morphology visualizations, etc...
hoc2swc requires a working version of NEURON 7.5+ either installed from a package/installer (easier) or compiled (more challenging). Linux, Mac, and Windows versions are supported.
You must be able to run at least one of these commands in a terminal window without errors:
nrniv -python
- Or
python -c 'from neuron import h'
If you cannot run any of these commands, it indicates that there is something amiss with your NEURON installation. Search the error messages on the NEURON forum for help.
The library assumes that the .mod files (mechanisms) used by the .hoc file are stored in the same directory as the .hoc file. You may need to place the .hoc and .mod files in the same folder before running this script.
Attention Windows users: Once .mod and .hoc files are in the same location, the .mod files have to be compiled. Follow these steps to compile the .mod files on Windows. Linux and Mac users can skip this step, as the library will compile the .mod files automatically.
Installation and usage depends on how you installed NEURON simulator (installed vs. compiled). More customizable functionality is available for those who compiled.
Download and extract this hoc2swc ZIP file to a known folder. This folder will have a script named hoc2swc.py
. Note its location.
Then, to convert a HOC file, run the following command in terminal (note the '-'s before the hoc and swc paths):
nrniv -python path/to/hoc2swc.py -path/to/cell.hoc -path/to/converted.swc
The command will start NEURON, load the HOC file, and convert it to SWC.
To install the library, simply type in pip install hoc2swc
in your terminal.
Then in a Python session, run the following to convert a HOC file to SWC.
from hoc2swc import hoc2swc
hoc2swc("path/to/cell.hoc", "out.swc")
The command will start NEURON, load the HOC file, and convert it to SWC. NEURON is started in a separate process and the last line can be repeated multiple times to convert multiple HOC files.
See the following Jupyter Notebook for a working example: hoc2swc NEURON+Python Usage.ipynb
If a cell is not defined in a HOC file (e.g. defined using a custom script or using Python) or requires special steps to load it, you can first instantiate the cell in NEURON and when it is ready for export to SWC, use the following Python script to save all instantiated cells to SWC.
# Load your cell
from neuron import h
run_scripts_build_cell_etc()
# Export loaded cell to SWC
from hoc2swc import neuron2swc # this function exports all loaded cells to SWC
neuron2swc("out.swc")
Note to packaged NEURON users, if you start nrniv -python
from the directory where the hoc2swc.py file is located OR append the location to the PYTHONPATH environment variable, the above lines will work for you as well.
Surprisingly, there is no easy way to save cell morphologies built using NEURON as SWC files. Which means, it's difficult to compute cell model morphology metrics using tools like L-Measure, or use an SWC viewer, which works with SWC files. It's possible to import SWC files into NEURON, but not export. There is NLMorphologyConverter, but none of the versions available were able to convert any of the HOC files I tested.
However, NEURON allows traversing all 3D points of an instantiated model. This can then be used to create the list of points for the SWC file.
While this approach requires a running instance of NEURON, it avoids the need to write a NEURON HOC file parser -- it simply leverages NEURON's HOC parser and h.xyzdiam3d() methods. As a side effect, this approach also allows converting NEURON cell model morphologies to SWC, even if HOC was not used to build the cell model (e.g. multiple HOC files or a Python script).
In theory, one could perform the above steps and implement a Neuron->SWC converter on their own. However, this library has been packaged and made freely available to reduce the above effort to just a few lines of code. If you find any bugs with this library, and were prepared to implement your own converter, consider fixing the bug and submitting a pull-request instead -- it might be faster to fix a bug here than to write the converter from scratch.
If you encounter an issue, first make sure it's not due to NEURON itself -- this library simply interacts with the NEURON executables. If it is, please contact the NEURON team. If the issue is with this library, please create an issue on Github.
To contribute, please open an issue first and discuss your plan for contributing. Then fork this repository and commit a pull-request with your changes.