From 69ce0095755c2c410cf7d57f06f08e3791e33514 Mon Sep 17 00:00:00 2001 From: "Ankur Sinha (Ankur Sinha Gmail)" Date: Mon, 11 Sep 2023 16:11:39 +0100 Subject: [PATCH 1/2] feat(paths): split out recording specific bits --- source/Userdocs/Paths.md | 121 +++------------------------------------ 1 file changed, 7 insertions(+), 114 deletions(-) diff --git a/source/Userdocs/Paths.md b/source/Userdocs/Paths.md index ce89af5a..2704ff1e 100644 --- a/source/Userdocs/Paths.md +++ b/source/Userdocs/Paths.md @@ -1,8 +1,13 @@ (userdocs:paths)= # Paths -Since NeuroMLv2 and LEMS are both XML based, entities in models and simulations must be referred to using *paths* ([XPath](https://en.wikipedia.org/wiki/XPath) like). -This page documents how paths can be constructed, and how they can be used to refer to entities in NeuroML/LEMS based models and simulations (e.g. in a {ref}`LEMS Simulation file `). +Since there is a well defined hierarchy of model components in NeuroML and LEMS, there is always a "path" from one component to another. +These paths are used when a model component needs to refer to another. +The table below lists the primary operators that one can use when creating a path, and the example below illustrates some paths. + +Paths are also used when recording information from simulations. +These are similar to the "reference paths" discussed here, but have some special features. +There are discussed in the page on {ref}`quantities and recording `. ```{list-table} :header-rows: 1 @@ -11,27 +16,18 @@ This page documents how paths can be constructed, and how they can be used to re * - operator - description - function - - example * - {code}`/` - forward slash - used to split the levels in a path string - - see {ref}`below ` * - {code}`.` - single period - refers to the level of the current node (usually omitted) - - see {ref}`below ` * - {code}`..` - two periods - refers to the level of the current node's parent node - - see {ref}`below ` * - {code}`[x]` - square brackets - used to refer to a particular instance (in this case, {code}`x`) in Components/Elements that have a `size` attribute (like {ref}`population `) - - see {ref}`below ` -* - {code}`:` - - colon - - used to refer to a particular Component instance for {code}`attachments` - - [ex](https://github.com/NeuroML/NeuroML2/blob/master/LEMSexamples/LEMS_NML2_Ex25_MultiComp.xml#L45) ``` Paths start from any element and ascend/descend to refer to the entity that is to be referenced. @@ -88,106 +84,3 @@ Therefore, for the `connection` nodes, the `population` nodes are at the *parent `../IzPop0` means "go up one level to the parent level (to `projection`) and then refer to `IzPop0`". `../` can be used as many times as required and wherever required in the path. For example, `../../../` would mean "go up three levels". - -(userdocs:pyneuroml)= -## Helper functions in pyNeuroML - -```{note} -These functions require {ref}`pyNeuroML ` version 0.5.18+, and {ref}`pylems ` version 0.5.8+. -``` - -From version 0.5.18, {ref}`pyNeuroML ` includes the [list_recording_paths_for_exposures](https://pyneuroml.readthedocs.io/en/development/pyneuroml.html#pyneuroml.pynml.list_recording_paths_for_exposures) helper function that can list the exposures and their recordable paths from a NeuroML 2 model: - -```{code-block} pycon ->>> import pyneuroml.pynml ->>> help(pynml.list_recording_paths_for_exposures) - -Help on function list_recording_paths_for_exposures in module pyneuroml.pynml: - -list_recording_paths_for_exposures(nml_doc_fn, substring='', target='') - List the recording path strings for exposures. - - This wraps around `lems.model.list_recording_paths` to list the recording - paths in the given NeuroML2 model. The only difference between the two is - that the `lems.model.list_recording_paths` function is not aware of the - NeuroML2 component types (since it's for any LEMS models in general), but - this one is. -``` - -It can be run on the example {ref}`Izhikevich network example `: -```{code-block} pycon ->>> pynml.list_recording_paths_for_exposures("izhikevich2007_network.nml", substring="", target="IzNet") -['IzNet/IzPop0[0]/iMemb', - 'IzNet/IzPop0[0]/iSyn', - 'IzNet/IzPop0[0]/u', - 'IzNet/IzPop0[0]/v', - 'IzNet/IzPop0[1]/iMemb', - 'IzNet/IzPop0[1]/iSyn', - 'IzNet/IzPop0[1]/u', - 'IzNet/IzPop0[1]/v', - 'IzNet/IzPop0[2]/iMemb', - 'IzNet/IzPop0[2]/iSyn', - 'IzNet/IzPop0[2]/u', - 'IzNet/IzPop0[2]/v', - 'IzNet/IzPop0[3]/iMemb', - 'IzNet/IzPop0[3]/iSyn', - 'IzNet/IzPop0[3]/u', - 'IzNet/IzPop0[3]/v', - 'IzNet/IzPop0[4]/iMemb', - 'IzNet/IzPop0[4]/iSyn', - 'IzNet/IzPop0[4]/u', - 'IzNet/IzPop0[4]/v', - 'IzNet/IzPop1[0]/iMemb', -.. -] -``` - - -Note that this function parsers the model description only, not the built simulation description. -Therefore, it will not necessarily list the complete list of paths. -Also worth noting is that since it parses and iterates over the expanded representation of the model, it can be slow and return long lists of results on larger models. -It is therefore, best to use this with the `substring` option to narrow its scope. - -An associated helper function [list_exposures](https://pyneuroml.readthedocs.io/en/development/pyneuroml.html?highlight=list_exposures#pyneuroml.pynml.list_exposures) is also available: -```{code-block} pycon ->>> import pyneuroml.pynml ->>> help(pynml.list_exposures) - -list_exposures(nml_doc_fn, substring='') - List exposures in a NeuroML model document file. - - This wraps around `lems.model.list_exposures` to list the exposures in a - NeuroML2 model. The only difference between the two is that the - `lems.model.list_exposures` function is not aware of the NeuroML2 component - types (since it's for any LEMS models in general), but this one is. - - The returned dictionary is of the form: - - .. - { - "component": ["exp1", "exp2"] - } -``` -When run on the example {ref}`Izhikevich network example `, it will return: - -```{code-block} pycon ->>> pynml.list_exposures("izhikevich2007_network.nml") - -{: {'g': , - 'i': }, - : {'u': , - 'iSyn': , - 'iMemb': , - 'v': }, - : {'i': }, - : {'i': }, - : {'i': }, - : {'i': }, - : {'i': }, -.. -} -``` - -This second function is primarily for use by the `list_recording_paths_for_exposures` function. - -As noted in the helper documentation, these are both based on a function of the same name implemented in {ref}`PyLEMS `, version 0.5.8+. From 392d5e3191571999881744883ded8009795a9098 Mon Sep 17 00:00:00 2001 From: "Ankur Sinha (Ankur Sinha Gmail)" Date: Mon, 11 Sep 2023 16:11:50 +0100 Subject: [PATCH 2/2] wip(recording): add different use-cases --- source/Userdocs/QuantitiesAndRecording.md | 163 +++++++++++++++++++++- 1 file changed, 161 insertions(+), 2 deletions(-) diff --git a/source/Userdocs/QuantitiesAndRecording.md b/source/Userdocs/QuantitiesAndRecording.md index 0e53a1e6..3108902d 100644 --- a/source/Userdocs/QuantitiesAndRecording.md +++ b/source/Userdocs/QuantitiesAndRecording.md @@ -1,8 +1,7 @@ (userdocs:quantitiesandrecording)= # Quantities and recording -In LEMS and NeuroML, `quantities` from all `exposures` and all `events` can be recorded by referring to them using {ref}`paths `. -For examples, please see the {ref}`Getting Started with NeuroML ` section. +In LEMS and NeuroML, `quantities` from all `exposures` and all `events` are recorded by referring to them using paths. (userdocs:quantitiesandrecording:events)= ## Recording events @@ -18,3 +17,163 @@ In NeuroML, all `quantities` can be recorded to files declared using the {ref}`O Once the `OutputFile` has been declared, `quantities` to record can be selected using the {ref}`OutputColumn ` component. {ref}`pyNeuroML ` provides the [create_output_file](https://pyneuroml.readthedocs.io/en/development/pyneuroml.lems.html?highlight=add_selection_to_event_output_file#pyneuroml.lems.LEMSSimulation.LEMSSimulation.create_event_output_file) function to create a `OutputFile` to record `quantities` to, and the [add_column_to_output_file](https://pyneuroml.readthedocs.io/en/development/pyneuroml.lems.html?highlight=add_selection_to_event_output_file#pyneuroml.lems.LEMSSimulation.LEMSSimulation.create_event_output_file) function to select `quantities` to record to the declared data file(s). + +(userdocs:quantitiesandrecording:paths)= +## Paths for recording quantities + +% examples: https://github.com/search?q=org%3AOpenSourceBrain+%22quantity%3D%22+language%3AXML&type=code&l=XML&p=1 + +While the hierarchical reference scheme remains the same as that discussed in {ref}`paths `, a number of specific operators are used to refer to specifics to record, for example, what segment in a multi-compartmental cell does one want to record a particular quantity from. + +In general, quantities to be recorded can be present on a number of different components: + +- on a single compartment cell +- on a cell in a population +- on a cell instance in a population list +- on a segment on an instance of a multi-compartmental cell in a population list + +A number of extra operators are also available to help record specific quantities, such as synaptic quantities: +```{list-table} +:header-rows: 1 +:name: paths-operators + +* - operator + - description + - function + - example +* - {code}`:` + - colon + - used to refer to a particular Component instance for {code}`attachments` + - [ex](https://github.com/NeuroML/NeuroML2/blob/master/LEMSexamples/LEMS_NML2_Ex25_MultiComp.xml#L45) + +``` + +Let us go through the different cases with examples + +(userdocs:quantitiesandrecording:paths:single_comp)= +### Quantities on a single compartment cell + +TODO: Or single component? Ask Padraig. + + +(userdocs:quantitiesandrecording:paths:cell_in_pop)= +### Quantities on a cell in a population + +pop[0]/cell/segmentid/quantities + +#### On synapses + +pop/index/cell/segmentid/synapse:... + +(userdocs:quantitiesandrecording:paths:cell_in_pop_list)= +### Quantities on a cell in a population list + +pop/index/cell/segmentid/quantities + +#### On synapses + +pop/index/cell/segmentid/synapse:... + + +(userdocs:quantitiesandrecording:paths:pyneuroml)= +### Helper functions in pyNeuroML + +```{note} +These functions require {ref}`pyNeuroML ` version 0.5.18+, and {ref}`pylems ` version 0.5.8+. +``` + +From version 0.5.18, {ref}`pyNeuroML ` includes the [list_recording_paths_for_exposures](https://pyneuroml.readthedocs.io/en/development/pyneuroml.html#pyneuroml.pynml.list_recording_paths_for_exposures) helper function that can list the exposures and their recordable paths from a NeuroML 2 model: + +```{code-block} pycon +>>> import pyneuroml.pynml +>>> help(pynml.list_recording_paths_for_exposures) + +Help on function list_recording_paths_for_exposures in module pyneuroml.pynml: + +list_recording_paths_for_exposures(nml_doc_fn, substring='', target='') + List the recording path strings for exposures. + + This wraps around `lems.model.list_recording_paths` to list the recording + paths in the given NeuroML2 model. The only difference between the two is + that the `lems.model.list_recording_paths` function is not aware of the + NeuroML2 component types (since it's for any LEMS models in general), but + this one is. +``` + +It can be run on the example {ref}`Izhikevich network example `: +```{code-block} pycon +>>> pynml.list_recording_paths_for_exposures("izhikevich2007_network.nml", substring="", target="IzNet") +['IzNet/IzPop0[0]/iMemb', + 'IzNet/IzPop0[0]/iSyn', + 'IzNet/IzPop0[0]/u', + 'IzNet/IzPop0[0]/v', + 'IzNet/IzPop0[1]/iMemb', + 'IzNet/IzPop0[1]/iSyn', + 'IzNet/IzPop0[1]/u', + 'IzNet/IzPop0[1]/v', + 'IzNet/IzPop0[2]/iMemb', + 'IzNet/IzPop0[2]/iSyn', + 'IzNet/IzPop0[2]/u', + 'IzNet/IzPop0[2]/v', + 'IzNet/IzPop0[3]/iMemb', + 'IzNet/IzPop0[3]/iSyn', + 'IzNet/IzPop0[3]/u', + 'IzNet/IzPop0[3]/v', + 'IzNet/IzPop0[4]/iMemb', + 'IzNet/IzPop0[4]/iSyn', + 'IzNet/IzPop0[4]/u', + 'IzNet/IzPop0[4]/v', + 'IzNet/IzPop1[0]/iMemb', +.. +] +``` + + +Note that this function parsers the model description only, not the built simulation description. +Therefore, it will not necessarily list the complete list of paths. +Also worth noting is that since it parses and iterates over the expanded representation of the model, it can be slow and return long lists of results on larger models. +It is therefore, best to use this with the `substring` option to narrow its scope. + +An associated helper function [list_exposures](https://pyneuroml.readthedocs.io/en/development/pyneuroml.html?highlight=list_exposures#pyneuroml.pynml.list_exposures) is also available: +```{code-block} pycon +>>> import pyneuroml.pynml +>>> help(pynml.list_exposures) + +list_exposures(nml_doc_fn, substring='') + List exposures in a NeuroML model document file. + + This wraps around `lems.model.list_exposures` to list the exposures in a + NeuroML2 model. The only difference between the two is that the + `lems.model.list_exposures` function is not aware of the NeuroML2 component + types (since it's for any LEMS models in general), but this one is. + + The returned dictionary is of the form: + + .. + { + "component": ["exp1", "exp2"] + } +``` +When run on the example {ref}`Izhikevich network example `, it will return: + +```{code-block} pycon +>>> pynml.list_exposures("izhikevich2007_network.nml") + +{: {'g': , + 'i': }, + : {'u': , + 'iSyn': , + 'iMemb': , + 'v': }, + : {'i': }, + : {'i': }, + : {'i': }, + : {'i': }, + : {'i': }, +.. +} +``` + +This second function is primarily for use by the `list_recording_paths_for_exposures` function. + +As noted in the helper documentation, these are both based on a function of the same name implemented in {ref}`PyLEMS `, version 0.5.8+.