Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fixed typos etc #2339

Merged
merged 6 commits into from
Aug 7, 2024
Merged
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
57 changes: 29 additions & 28 deletions doc/python/simulation.rst
Original file line number Diff line number Diff line change
Expand Up @@ -6,37 +6,37 @@ Simulations
From recipe to simulation
-------------------------

To build a simulation the following concepts are needed:
To build a simulation, the following concepts are needed:

* an :py:class:`arbor.recipe` that describes the cells and connections in the model;
* an :py:class:`arbor.context` used to execute the simulation.

The workflow to build a simulation is to first generate an
:class:`arbor.domain_decomposition` based on the :py:class:`arbor.recipe` and :py:class:`arbor.context` describing the distribution of the model
over the local and distributed hardware resources (see :ref:`pydomdec`). Then, the simulation is build using this :py:class:`arbor.domain_decomposition`.
over the local and distributed hardware resources (see :ref:`pydomdec`). Then, the simulation is built using this :py:class:`arbor.domain_decomposition`.

.. container:: example-code

.. code-block:: python

import arbor
import arbor as A

# Get a communication context (with 4 threads, no GPU)
context = arbor.context(threads=4, gpu_id=None)
context = A.context(threads=4, gpu_id=None)

# Initialise a recipe of user defined type my_recipe with 100 cells.
# Initialise a recipe of user-defined type my_recipe with 100 cells.
n_cells = 100
recipe = my_recipe(n_cells)

# Get a description of the partition of the model over the cores.
decomp = arbor.partition_load_balance(recipe, context)
decomp = A.partition_load_balance(recipe, context)

# Instantiate the simulation.
sim = arbor.simulation(recipe, decomp, context)
sim = A.simulation(recipe, decomp, context)

# Run the simulation for 2000 ms with time stepping of 0.025 ms
tSim = 2000
dt = 0.025
# Run the simulation for 2000 ms with a time step of 0.025 ms
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These should have units ;)

tSim = 2000 * U.ms
dt = 0.025 * U.ms
sim.run(tSim, dt)

.. currentmodule:: arbor
Expand All @@ -53,7 +53,7 @@ over the local and distributed hardware resources (see :ref:`pydomdec`). Then, t
* an :py:class:`arbor.recipe` that describes the model;
* an :py:class:`arbor.domain_decomposition` that describes how the cells in the model are assigned to hardware resources;
* an :py:class:`arbor.context` which is used to execute the simulation.
* a non-negative :py:class:`int` in order to seed the pseudo pandom number generator (optional)
* a non-negative :py:class:`int` in order to seed the pseudo random number generator (optional)

Simulations provide an interface for executing and interacting with the model:

Expand Down Expand Up @@ -94,7 +94,7 @@ over the local and distributed hardware resources (see :ref:`pydomdec`). Then, t

.. function:: run(tfinal, dt)

Run the simulation from current simulation time to ``tfinal``,
Run the simulation from the current simulation time to ``tfinal``,
with maximum time step size ``dt``.

:param tfinal: The final simulation time [ms].
Expand All @@ -105,7 +105,7 @@ over the local and distributed hardware resources (see :ref:`pydomdec`). Then, t

.. function:: record(policy)

Disable or enable recorder of rank-local or global spikes, as determined by the ``policy``.
Disable or enable the recorder of rank-local or global spikes, as determined by the ``policy``.

:param policy: Recording policy of type :py:class:`spike_recording`.

Expand Down Expand Up @@ -224,22 +224,22 @@ Spikes recorded during a simulation are returned as a NumPy structured datatype

.. code-block:: python

import arbor
import arbor as A

# Instantiate the simulation.
sim = arbor.simulation(recipe, decomp, context)
sim = A.simulation(recipe, decomp, context)

# Direct the simulation to record all spikes, which will record all spikes
# across multiple MPI ranks in distrubuted simulation.
# To only record spikes from the local MPI rank, use arbor.spike_recording.local
sim.record(arbor.spike_recording.all)
# across multiple MPI ranks in distributed simulation.
# To only record spikes from the local MPI rank, use A.spike_recording.local
sim.record(A.spike_recording.all)

# Run the simulation for 2000 ms with time stepping of 0.025 ms
tSim = 2000
dt = 0.025
# Run the simulation for 2000 ms with a time step of 0.025 ms
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same here, units missing. Again, not your fault, but let's do it right

tSim = 2000 * U.ms
ErbB4 marked this conversation as resolved.
Show resolved Hide resolved
dt = 0.025 * U.ms
sim.run(tSim, dt)

# Print the spikes and according spike time
# Print the spikes: time and source
for s in sim.spikes():
print(s)

Expand Down Expand Up @@ -288,31 +288,32 @@ There are three parts to the process of recording cell data over a simulation.

The contents of ``data`` will depend upon the specifics of the probe, but note:

i. The object type and structure of ``data`` is fully determined by the metadata.
i. The object type and structure of ``data`` are fully determined by the metadata.

ii. All currently implemented probes return data that is a NumPy array, with one
row per sample, first column being sample time, and the remaining columns containing
row per sample, the first column being sample time, and the remaining columns containing
the corresponding data.

Example
*******

.. code-block:: python

import arbor
import arbor as A
from arbor import units as U

# [... define recipe, decomposition, context ... ]
# Initialize simulation:

sim = arbor.simulation(recipe, decomp, context)
sim = A.simulation(recipe, decomp, context)

# Sample probeset id (0, 0) (first probeset id on cell 0) every 0.1 ms

handle = sim.sample((0, 0), arbor.regular_schedule(0.1))
handle = sim.sample((0, 0), A.regular_schedule(0.1))
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

unit!

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

okkkkkkk

ErbB4 marked this conversation as resolved.
Show resolved Hide resolved

# Run simulation and retrieve sample data from the first probe associated with the handle.

sim.run(tfinal=3, dt=0.1)
sim.run(tfinal=3 * U.ms, dt=0.1 * U.ms)
data, meta = sim.samples(handle)[0]
print(data)

Expand Down