Metadata-Version: 2.4
Name: pyfibers
Version: 0.4.2
Summary: Modeling stimulation of peripheral nerve fibers
Keywords: stimulation,modeling,computational,fibers,peripheral nerve
Author: Daniel Marshall, Elie Farah, Eric Musselman
Requires-Python: >=3.10
Description-Content-Type: text/markdown
Classifier: Development Status :: 3 - Alpha
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Operating System :: OS Independent
License-File: LICENSE
Requires-Dist: matplotlib==3.10.*
Requires-Dist: multiprocess==0.*
Requires-Dist: numpy==2.2.*
Requires-Dist: pandas==2.2.*
Requires-Dist: scipy==1.15.*
Requires-Dist: seaborn==0.13.*
Requires-Dist: nd_line==0.2.*
Requires-Dist: aenum==3.1.*
Requires-Dist: mock==5.* ; extra == "dev"
Requires-Dist: pre-commit==4.0.* ; extra == "dev"
Requires-Dist: pytest==8.* ; extra == "dev"
Requires-Dist: pytest-cov==6.* ; extra == "dev"
Requires-Dist: pytest-sugar==1.* ; extra == "dev"
Requires-Dist: sphinx==7.* ; extra == "dev"
Requires-Dist: sphinx-rtd-theme==3.* ; extra == "dev"
Requires-Dist: sphinx-copybutton==0.5.* ; extra == "dev"
Requires-Dist: IPython==8.* ; extra == "dev"
Requires-Dist: enum-tools[sphinx]==0.12.* ; extra == "dev"
Requires-Dist: sphinxcontrib-bibtex==2.6.* ; extra == "dev"
Requires-Dist: moviepy==2.1.* ; extra == "dev"
Requires-Dist: sphinx_autodoc_typehints==2.3.* ; extra == "dev"
Requires-Dist: piccolo-theme==0.24.* ; extra == "dev"
Requires-Dist: myst-nb==1.2.* ; extra == "dev"
Provides-Extra: dev

# PyFibers
This package implements biophysical models of axons in the NEURON simulation environment using Python. With our package, you can model the responses of axons to electrical stimulation (e.g., find the minimum current amplitude required to activate or block an action potential). You can add your own fiber models and simulations protocols. You can use analytical tools for extracellular potentials, or import from FEM (e.g., COMSOL).

We have implemented the following models:
- MRG (McIntyre, Richardson, and Grill)
   - MRG-discrete
   - MRG-interpolation
   - Small MRG-interpolation
- Thio
   - Autonomic
   - Cutaneous
- Sundt
- Tigerholm
- Rattay
- Schild
   - Schild 1994
   - Schild 1997

## Installation
Note: It is recommended you create a new virtual environment for PyFibers. For example, using Anaconda/Miniconda:
  - `conda create -n pyfibers`
  - `conda activate pyfibers`
1. Install NEURON and add to PATH (https://nrn.readthedocs.io/en/latest/)
   - Make sure your NEURON and Python versions are compatible (https://nrn.readthedocs.io/en/latest/changelog.html)
   - Check your installation by running the following command: `python -c "import neuron; neuron.test(); quit()"`. If successful, test outputs along with "OK" should be printed to the terminal.
2. Using git, clone PyFibers to your computer (Once the package is released, this step will be eliminated. Also skip if you downloaded or were provided a zipped copy of the repository)
3. Install the package using pip
   - Open your terminal where Python is callable (e.g., Anaconda Prompt)
   - Navigate to the repository root directory
   - Run the command `pip install .` if you do not plan to develop PyFibers code.
   - If you do plan to develop the package, instead do the following:
     - Install PyFibers alongside development dependencies with `pip install .[dev]` (If using a zsh shell, use the command `pip install .'[dev]'`)
     - Install pre-commit hooks with `pre-commit install`
4. To compile the mod files, in Anaconda prompt, run the command `pyfibers_compile`
   - It is normal to see the following message during compilation: `NEURON mechanisms not found in <path>.` Check the NEURON output that follows for a message that the mechanisms were compiled successfully. (e.g., for Windows: `nrnmech.dll was built successfully.`). In the future while using PyFibers, if you see the `NEURON mechanisms not found in <path>.` message, this is cause for concern, as this means PyFibers cannot find the compiled mechanisms. Failed compiles will commonly cause the error message `Argument not a density mechanism name` to appear when trying to create fibers.
   - Careful! Make sure that that the correct NEURON installation is in your path, as the first found installation will be used for compilation. The version used for compilation must be the same version used to run PyFibers code.
   - Note: if you receive a message that the `pyfibers_compile` command is not found, find the executable for this command in the `Scripts` path of your python directory (e.g. `C:\Users\<username>\Anaconda3\envs\pyfibers\Scripts`) and run the executable (e.g., `pyfibers_compile.exe`).


## Usage
See the Documentation for detailed information on usage:
- [Tutorials](https://wmglab.pages.oit.duke.edu/wmglab-neuron/tutorials/index.html) on various operations.
- [API Documentation](https://wmglab.pages.oit.duke.edu/wmglab-neuron/autodoc/index.html) on function/class arguments and outputs.

The basic steps for running a PyFibers simulation are as follows:
### Creating a model fiber
Use the build_fiber function to create fiber object. The fiber object consists of NEURON sections with ion channel mechanisms inserted for the fiber model chosen when the object is initialized. Users can add custom fiber models as well as using our provided models (See [Custom Fiber Models](https://wmglab.pages.oit.duke.edu/wmglab-neuron/custom.html#how-to-create-a-new-fiber-model))

```python
from pyfibers import build_fiber

fiber = build_fiber(
    fiber_model=FiberModel.MRG_DISCRETE,
    diameter=10,  # um
    n_nodes=25,  # um
    temperature=37,  # C
)
```
### Running a Simulatiion
The fiber object can be run in simulations using our provided `ScaledStim` class; alternatively, users can create their own custom simulation setup (See [Custom Simulations](https://wmglab.pages.oit.duke.edu/wmglab-neuron/custom.html#custom-simulations)). Once you have a fiber object, you can create a `ScaledStim` instance, which is a set of instructions for stimulating model fibers.

```python
# Add extracellular potentials
fiber.potentials = potential_values

# Create instance of ScaledStim class
stimulation = ScaledStim(waveform=waveform, dt=time_step, tstop=time_stop)

# run threshold search
amp, _ = stimulation.find_threshold(fiber)
print(f"Threshold for 5.7 micron fiber: {amp} (mA)")
```
For more examples, see the documentation.

## Contributing
If you develop additional functionality that would be generally useful to our users, please open a Pull Request for us to review.

## Authors and acknowledgment
   - Developed at Duke University by Daniel Marshall, Elie Farrah, and Eric Musselman
   - Please see: \<Paper REF Forthcoming>

## License
See LICENSE

