File: internals.rst

package info (click to toggle)
neuron 8.2.6-2
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 34,760 kB
  • sloc: cpp: 149,571; python: 58,465; ansic: 50,329; sh: 3,510; xml: 213; pascal: 51; makefile: 35; sed: 5
file content (263 lines) | stat: -rwxr-xr-x 7,182 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
Debugging and Internals Access
------------------------------

.. seealso::

    :func:`neuron.nrn_dll`


Namespace Related
~~~~~~~~~~~~~~~~~

.. function:: name_declared

    Syntax:
        ``type = h.name_declared("name")``

        ``type = h.name_declared("name", 1)``

        ``type = h.name_declared("name", 2)``

    Description:
        Return 0 if the name is not in the NEURON/HOC symbol table. The first form looks 
        for names in the top level symbol table. The second form looks in the 
        current object context. The last form also looks in the top level
        symbol table but is useful in Python to distinguish subtypes of
        variables which appear as doubles in HOC but internally are really
        not doubles and so cannot be pointed to by double*, eg. h.secondorder
        which is <type 'int'> or h.nseg which returns either
        ``TypeError: Section access unspecified`` or
        ``nseg  not a USERPROPERTY that can be pointed to``
         
        If the name exists return 
         
        2 if an objref
         
        3 if a Section 
         
        4 if a :ref:`strdef <keyword_strdef>` 
         
        5 if a scalar or :ref:`double <keyword_double>` variable. (if second arg is not 2)

          if second arg is 2

          5 if a scalar double

          6 if a double array

          7 if an integer

          8 if a section property
         	         
        1 otherwise 

        .. ::

            A HOC work-around that is not relevant in Python.

            Note that names can be (re)declared only if they do not already 
            exist or are already of the same type. 
            This is too useful to require the user to waste an objref in creating a 
            :class:`StringFunctions` class to use :meth:`~StringFunctions.is_name`. 

            .. code-block::
                none

                name_declared("nrnmainmenu_") 
                {object_push(nrnmainmenu_) print name_declared("ldfile", 0) object_pop()} 
                {object_push(nrnmainmenu_) print name_declared("ldfile", 1) object_pop()} 

    .. note::

        This function checks the NEURON/HOC symbol table; Python objects are handled separately.

        To test if a simple name is a local variable in Python, use:

        .. code-block::
            python

            if 'soma' in locals():
                # do something

        Checking against ``globals()`` and ``dir()`` are also often useful.

        If the name is known in advance, use a ``try``/``except`` block and catch NameError and AttributeError:

        .. code-block::
            python

            try:
                h.soma.squiggle
            except (NameError, AttributeError):
                print('Name does not exist')

        Combining this with an ``eval`` can allow testing arbitrary names, but is potentially unsafe as it allows
        execution of arbitrary code.


----

.. function:: symbols

    Name:
        symbols --- type the names of HOC functions and variables 

    Syntax:
        ``h.symbols()``

    Description:
        Types a list of functions and variable names defined in HOC.  Dimensions 
        of arrays are also indicated. 

    .. warning::
        No longer works. The nearest replacement is :func:`SymChooser` . 





Object Related
~~~~~~~~~~~~~~


.. function:: object_id

    Syntax:
        ``h.object_id(objref)``

        ``h.object_id(objref, 1)``

    Description:
        Returns 0 if the object reference does not point to an object instance. 
        (Otherwise returns the pointer cast to a double, not a very useful number,
        except that this is equal to the value returned by Python's ``hash`` function.) 
         
        If the second argument is 1, it returns the index of the object name. Returns 
        -1 if the object is the NULLObject. 

    Example:

        .. code-block::
            python

            from neuron import h

            a, b, c = h.List(), h.List(), h.Vector()

            print(h.object_id(a))       # displays a double; equal to hash(a)
            print(h.object_id(a, 1))    # 0 since a == h.List[0]
            print(h.object_id(b, 1))    # 1 since b == h.List[1]
            print(h.object_id(c, 1))    # 0 since c == h.Vector[0]

----

.. function:: allobjectvars

    Syntax:
        ``h.allobjectvars()``

    Description:
        Prints all the HOC object references (objref variables) that have been 
        declared along with the class type of the object they reference and the 
        number of references. Objects created via Python and not assigned to a 
        HOC objref

    Example:

        .. code-block::
            python

            >>> h('objref foo')
            1
            >>> h.foo = h.Vector()
            >>> h.allobjectvars()
            obp hoc_obj_[0] -> NULL
            obp hoc_obj_[1] -> NULL
            obp foo[0] -> Vector[0] with 1 refs.
            0.0
            >>> banana = h.foo
            >>> h.allobjectvars()
            obp hoc_obj_[0] -> NULL
            obp hoc_obj_[1] -> NULL
            obp foo[0] -> Vector[0] with 2 refs.
            0.0

----

.. function:: allobjects

    Syntax:
        ``h.allobjects()``

        ``h.allobjects("templatename")``

        ``nref = h.allobjects(objectref)``

    Description:
        Prints the internal names of all class instances (objects) available 
        from the interpreter along with the number of references to them. 
         
        With a templatename the list is restricted to objects of that class. 
         
        With an object variable, nothing is printed but the reference count 
        is returned. The count is too large by one if the argument was of the 
        form templatename[index] since a temporary reference is created while 
        the object is on the stack during the call. 

    Example:

        .. code-block::
            python

            >>> v = h.Vector()
            >>> foo = h.List()
            >>> h.allobjects()
            List[0] with 1 refs
            Vector[0] with 1 refs
            0.0
            >>> h.allobjects('Vector')
            Vector[0] with 1 refs
            0.0
            >>> h.allobjects(foo)
            2.0

----

.. function:: object_push

    Syntax:
        ``h.object_push(objref)``

    Description:
        Enter the context of the object referenced by objref. In this context you 
        can directly access any variables or call any functions, even those not 
        declared as :ref:`public <keyword_public>`. Do not attempt to create any new symbol names! 
        This function is generally used by the object itself to save its state 
        in a session. 


----

.. function:: object_pop

    Syntax:
        ``h.object_pop()``

    Description:
        Pop the last object from an :func:`object_push` . 

----

Miscellaneous
~~~~~~~~~~~~~

.. function:: hoc_pointer_

    Syntax:
        ``h.hoc_pointer_(&variable)``

    Description:
        A function used by c and c++ implementations to request a pointer to 
        the variable from its interpreter name. Not needed by or useful for the user; returns 1.0 on
        success.