-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into magkanar/nrn_reg
- Loading branch information
Showing
45 changed files
with
2,701 additions
and
451 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
Ions | ||
==== | ||
|
||
NEURON supports computing the ion currents and ion concentrations. For each segment | ||
there can be separate current for separate ions, i.e. one for sodium ions and | ||
another for calcium ions. | ||
|
||
There are five variables associated with ions: the current (``ina``), the | ||
concentration inside the segment adjacent to the membrane (``nai``), the | ||
concentration outside the segment adjacent to the membrane (``nao``), the | ||
reversal potential (``ena``) and the derivative if the current w.r.t. the | ||
voltage (``dinadv``). The names should be split as ``i{na}`` and therefore | ||
refer to the value for sodium, for calcium it would have been ``ica``. | ||
|
||
These variables are physical properties of the segment. Therefore, there exists | ||
one mechanism per ion. MOD files can include code to read or write these | ||
variables. | ||
|
||
NDMOL Keywords | ||
-------------- | ||
A MOD file seeking to use ions should use ``USEION`` as follows: | ||
|
||
.. code:: | ||
NEURON { | ||
USEION na READ ina WRITE ena | ||
} | ||
ASSIGNED { | ||
ena (mV) | ||
ina (mA / cm2) | ||
} | ||
Multiple ions are expressed by one line of ``USEION`` per ion. | ||
|
||
The ``{ion_name}`` is a string giving the ion a name. For sodium it's ``na`` | ||
and for calcium ``ca``. If the no other mechanisms have defined an ion with | ||
this name a new ion mechanism is created. | ||
|
||
Both ``READ`` and ``WRITE`` are optional and are followed by a comma separated | ||
list of ion variable names, e.g. ``ina, ena``. | ||
|
||
Keyword: WRITE | ||
~~~~~~~~~~~~~~ | ||
|
||
Writing Ion Currents | ||
^^^^^^^^^^^^^^^^^^^^ | ||
|
||
In MOD file one can set the value of ion variables. | ||
|
||
.. code:: | ||
BREAKPOINT { | ||
ina = gna*(v - ena) | ||
} | ||
Semantically, this states that the contribution of the Hodgkin-Huxley model to | ||
the overall sodium current in that segment is ``gna*(v - ena)``. Since | ||
everything is at the level of segment, we'll not keep repeating "for that | ||
segment". Similarly, each mechanism computes a `local` contribution, i.e. the | ||
contribution due to this mechanism to the actual `global` ion current. | ||
|
||
Therefore, code for the following must be generated: | ||
|
||
1. Compute the local contribution to the sodium current. | ||
2. Increment the total, local, current contribution by ``ina``. | ||
3. Increment the global sodium current by ``ina``. | ||
4. Compute local derivative of ``ina`` w.r.t. the voltage. | ||
5. Increment the global derivative of the sodium current w.r.t. the voltage. | ||
|
||
The global current must also be updated as usual. However, this isn't ion | ||
specific and hence omitted. | ||
|
||
|
||
Storage | ||
------- | ||
|
||
Each mechanism that specifies ``USEION na`` contains a copy of all used ion | ||
variables and pointers to the shared values in the ion mechanism, see Figure 1. | ||
|
||
The pointer to the variable in the ion mechanism is prefixed with ``ion_``, | ||
e.g. during initialization we might copy the shared value ``*ion_ena[i]`` to | ||
``ena[i]`` (the copy local to the mechanism using the ion). | ||
|
||
.. figure:: ../images/ion_storage.svg | ||
|
||
Figure 1: Ion mechanism for sodium (``na``) and its use in the | ||
Hodgkin-Huxley mechanism. This figure shows the NEURON memory layout. | ||
|
||
|
||
Optimizing Storage | ||
~~~~~~~~~~~~~~~~~~ | ||
|
||
Since the common pattern is to only access the values of a particular instance, | ||
the local copy isn't needed. I might facilitate SIMD, but it could be replaces | ||
by local variables, see Figure 2. | ||
|
||
.. figure:: ../images/ion_storage-opt.svg | ||
|
||
Figure 2: Optimized ion storage layout. | ||
|
||
|
||
This optimization is implemented in NMODL. It can be activated on the CLI via | ||
|
||
.. code:: sh | ||
nmodl ... codegen --opt-ionvar-copy | ||
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
NMODL "pointers" | ||
================ | ||
|
||
Mechanisms can refer to values in other mechanisms, e.g. the sodium current | ||
``ina``. Therefore, it supports a notion of "pointer", called ``Datum``. A datum | ||
can store a pointer to a double, a stable pointer to a double, integers, or | ||
pointers to anything else. | ||
|
||
Integer Variables | ||
----------------- | ||
One important subset of Datum are pointers to RANGE variables. Meaning they are | ||
pointers to parameters in other mechanisms or pointers to the parameters | ||
associated with each node, e.g. the voltage. Since the storage of RANGE | ||
variable is controlled by NEURON/CoreNEURON, these pointers have stronger | ||
semantics than a ``double*``. | ||
|
||
These make up the majority of usecases for Datum; and are considered the | ||
well-mannered subset. | ||
|
||
In CoreNEURON this subset of Datums are treated differently for other Datums. | ||
Because CoreNEURON stores the values these Datums can point to in a single | ||
contiguous array of doubles, the "pointers" can be expressed as indices into | ||
this array. | ||
|
||
Therefore, this subset of Datums is referred to as "integer variables". | ||
|
||
In NEURON these pointers are a ``data_handle`` to the value they point to. | ||
Before the simulation phase they are "resolved" and a cache stores a list of | ||
``double*`` to the appropriate values. | ||
|
Oops, something went wrong.