hnn_core.Cell

class hnn_core.Cell(name, pos, sections, synapses, sect_loc, cell_tree, gid=None)[source]

Create a cell object.

Parameters:
namestr

The name of the cell.

postuple

The (x, y, z) coordinates.

sectionsdict of Section

Dictionary with keys as section name.

synapsesdict of dict

Keys are name of synaptic mechanism. Each synaptic mechanism has keys for parameters of the mechanism, e.g., ‘e’, ‘tau1’, ‘tau2’. sections.

sect_locdict of list

Can have keys ‘proximal’ or ‘distal’ each containing names of section locations that are proximal or distal.

gidint or None (optional)

Each cell in a network is uniquely identified by it’s “global ID”: GID. The GID is an integer from 0 to n_cells, or None if the cell is not yet attached to a network. Once the GID is set, it cannot be changed.

cell_treedict of list

Stores the tree representation of a cell. Root is the 0 end of ‘soma’. Nodes are a tuple (sec_name, node_pos) where sec_name is the name of the section and node_pos is the 0 end or 1 end. The data structure is the adjacency list representation of a tree. The keys of the dict are the parent nodes. The value is the list of nodes (children nodes) connected to the parent node.

Examples

>>> section_soma = Section(
        L=39,
        diam=20,
        cm=0.85,
        Ra=200.,
        end_pts=[[0, 0, 0], [0, 39., 0]]
    )
Attributes:
poslist of length 3

The position of the cell.

sectionsnested dict

The section parameters. The key is the name of the section and the value is a dictionary parametrizing the morphology of the section and the mechanisms inserted.

synapsesdict

The synapses that the cell can use for connections.

dipole_pplist of h.Dipole()

The Dipole objects (see dipole.mod).

vsecdict

Recording of section specific voltage. Must be enabled by running simulate_dipole(net, record_vsec=True) or simulate_dipole(net, record_vsoma=True)

isecdict

Contains recording of section specific currents indexed by synapse type (keys can be soma_gabaa, soma_gabab etc.). Must be enabled by running simulate_dipole(net, record_isec=True) or simulate_dipole(net, record_isoma=True)

cadict

Contains recording of section speicifc calcium concentration. Must be enabled by running simulate_dipole(net, record_ca=True).

tonic_biaseslist of h.IClamp

The current clamps inserted at each section of the cell for tonic biasing inputs.

gidint

GID of the cell in a network (or None if not yet assigned)

sect_locdict of list

Can have keys ‘proximal’ or ‘distal’ each containing names of section locations that are proximal or distal.

cell_treedict of list

Stores the tree representation of a cell. Root is the 0 end of ‘soma’. Nodes are a tuple (sec_name, node_pos) where sec_name is the name of the section and node_pos is the 0 end or 1 end. The data structure is the adjacency list representation of a tree. The keys of the dict are the parent nodes. The value is the list of nodes (children nodes) connected to the parent node.

Methods

build([sec_name_apical])

Build cell in Neuron and insert dipole if applicable.

copy()

Return copy of instance.

create_tonic_bias(amplitude, t0, tstop[, ...])

Create tonic bias at defined section.

define_shape(node)

Redefines end_pts according to section lengths.

distance_section(target_sec_name, curr_node)

Find distance between the current node and the target section.

modify_section(sec_name[, L, diam, cm, Ra])

Change attributes of section specified by sec_name

parconnect_from_src(gid_presyn, nc_dict, ...)

Parallel receptor-centric connect FROM presyn TO this cell,

plot_morphology([ax, color, pos, xlim, ...])

Plot the cell morphology.

record([record_vsec, record_isec, record_ca])

Record current and voltage from all sections

setup_source_netcon(threshold)

Created for _PC.cell and specifies SOURCES of spikes.

syn_create(secloc, e, tau1, tau2)

Create an h.Exp2Syn synapse.

to_dict()

Converts an object of Cell class to a dictionary.

__repr__()[source]

Return repr(self).

build(sec_name_apical=None)[source]

Build cell in Neuron and insert dipole if applicable.

Parameters:
sec_name_apicalstr | None

If not None, a dipole will be inserted in this cell in alignment with this section. The section should belong to the apical dendrite of a pyramidal neuron.

copy()[source]

Return copy of instance.

create_tonic_bias(amplitude, t0, tstop, section='soma', loc=0.5)[source]

Create tonic bias at defined section.

Parameters:
amplitudefloat

The amplitude of the input.

t0float

The start time of tonic input (in ms).

tstopfloat

The end time of tonic input (in ms).

sectionstr

Section tonic input is applied to.

locfloat (0 to 1)

The location of the input in the section.

define_shape(node)[source]

Redefines end_pts according to section lengths.

Detects change in section lengths of the sections in the subtree of the input node.

Parameters:
nodetuple of size 2

The first element is the section name The second element is the node end used (0 or 1)

distance_section(target_sec_name, curr_node)[source]

Find distance between the current node and the target section.

Parameters:
target_sec_namestring

Name of the target section

curr_nodetuple

Source node from where search begins. It is of the the form (sec_name, end_pt).

Returns:
distancefloat

Path distance between source node and mid of the target section.

modify_section(sec_name, L=None, diam=None, cm=None, Ra=None)[source]

Change attributes of section specified by sec_name

Parameters:
sec_namestr

Name of section to be modified. Must be a key of Cell.sections

Lfloat | int | None

length of a section in microns. Default None.

diamfloat | int | None

diameter of a section in microns.

cmfloat | int | None

membrane capacitance in micro-Farads.

Rafloat | int | None

axial resistivity in ohm-cm.

Notes

Leaving default of None produces no change.

parconnect_from_src(gid_presyn, nc_dict, postsyn, inplane_distance)[source]
Parallel receptor-centric connect FROM presyn TO this cell,

based on GID.

Parameters:
gid_presynint

The cell ID of the presynaptic neuron

nc_dictdict

Dictionary with keys: pos_src, A_weight, A_delay, lamtha Defines the connection parameters

postsyninstance of h.Exp2Syn

The postsynaptic cell object.

inplane_distancefloat

The in plane-distance (in um) between pyramidal cell somas in the square grid.

Returns:
ncinstance of h.NetCon

A network connection object.

plot_morphology(ax=None, color=None, pos=(0, 0, 0), xlim=(-250, 150), ylim=(-100, 100), zlim=(-100, 1200), show=True)[source]

Plot the cell morphology.

Parameters:
axinstance of Axes3D

Matplotlib 3D axis

colorstr | dict | None

Color of cell. If str, entire cell plotted with color indicated by str. If dict, colors of individual sections can be specified. Must have a key for every section in cell as defined in the Cell.sections attribute.

| Ex: ``{‘apical_trunk’: ‘r’, ‘soma’: ‘b’, …}``
postuple of int or float | None

Position of cell soma. Must be a tuple of 3 elements for the (x, y, z) position of the soma in 3D space. Default: (0, 0, 0)

xlimtuple of int | tuple of float

x limits of plot window. Default (-250, 150)

ylimtuple of int | tuple of float

y limits of plot window. Default (-100, 100)

zlimtuple of int | tuple of float

z limits of plot window. Default (-100, 1200)

showbool

If True, show the plot

Returns:
axesinstance of Axes3D

The matplotlib 3D axis handle.

record(record_vsec=False, record_isec=False, record_ca=False)[source]

Record current and voltage from all sections

Parameters:
record_vsec‘all’ | ‘soma’ | False

Option to record voltages from all sections (‘all’), or just the soma (‘soma’). Default: False.

record_isec‘all’ | ‘soma’ | False

Option to record voltages from all sections (‘all’), or just the soma (‘soma’). Default: False.

record_ca‘all’ | ‘soma’ | False

Option to record calcium concentration from all sections (‘all’), or just the soma (‘soma’). Default: False.

setup_source_netcon(threshold)[source]

Created for _PC.cell and specifies SOURCES of spikes.

Parameters:
thresholdfloat

The voltage threshold for action potential.

syn_create(secloc, e, tau1, tau2)[source]

Create an h.Exp2Syn synapse.

Parameters:
seclocinstance of nrn.Segment

The section location. E.g., soma(0.5).

e: float

Reverse potential (in mV)

tau1: float

Rise time (in ms)

tau2: float

Decay time (in ms)

Returns:
syninstance of h.Exp2Syn

A two state kinetic scheme synapse.

to_dict()[source]

Converts an object of Cell class to a dictionary.

Returns:
dictionary form of an object of Cell class.