First Steps

Overview

SLI is the simulation language interface of NEST. It is a stack language where each command expects to find its arguments on the stack.

A stack is a place where data can be stored. The stack is organized into levels and the data can be thought of being on top of each other. As new data is entered, it is placed on the top of the stack. If a piece of data is removed or manipulated, this is usually done to the top level of the stack. The levels of the stack are numbered from zero onwards. Level zero corresponds to the top of the stack.

Initially the stack is empty. In general, you enter data onto the stack and then execute commands to manipulate the data.

Each command expects to find its arguments on the stack. When a SLI command is executed, it usually removes all arguments from the stack and pushes one or more results back on the stack. The basic concepts of stack operation are:

  • Commands that require arguments take their arguments from the stack. Thus, this data must be present before you execute the command.

  • The arguments are then removed by the command as it is executed.

  • Any results which are produced by the command are returned to the stack, so you can use them in other operations.

Commands with one argument

Commands which need one argument take their argument from the top of the stack. If the command produces a result, it is placed on top of the stack, after the argument has been removed. Thus, the argument is replaced by the result:

Example

SLI ] 10 log =
1

Here, the command log is used to compute the decadic logarithm of 10. Then, the command = is used to display the result of this computation.

Commands with more arguments

Commands which need more than one argument, take their arguments from level 0, 1, 2, and so forth and return their result to level 0, the top of the stack. Examples are the arithmetic functions add, sub, mul, and div, which take two arguments and return one result.

SLI ] 1 2 add =
3
SLI ] 1 2. div =
0.5

So far, we have used the command = to display the top object on the stack. In addition, this command removes the object. You can also list the contents of the stack without changing it.

SLI ] 1 2
SLI [2] stack
2
1
SLI [2] add
SLI [1] stack
3
SLI [1]

Using previous results

Chain calculations are calculations which involve more than one operation. A stack is particularly useful for chaining operations,because it retains intermediate results.

This example shows, how the stack can be used for chain calculations. Calculate (10+13) \(cdot\) (8-12)

SLI [1] 10 13 add 8 12 sub
SLI [2] stack
-4
23
SLI [2] mul =
-92                                                                              

Notice that the results of the fist two operations remain on the stack, until they are used in the multiplication.

Exchanging the first two stack levels

The command exch exchanges the contents of the levels 0 and 1. This is useful, if the order of objects on the stack does not match the order required by the desired command.

Example 1

Calculate 1/ln(2).

SLI ] 2 ln
SLI [1] 1
SLI [2] exch div
SLI [1] =
1.4427

Removing stack elements

The command pop removes the top object (level 0) of the stack. The remaining items move up on the stack, so that the object which was at level 1 is now at level 0.

The command clear clears the entire stack.

Duplicating the top element

The command dup duplicates the contents of the object at level 0 and pushes the other element down one level. This command is useful if the result of an operation is needed more than once in a chain calculation.

Example 2

Calculate (1+4/2) + exp(1+4/2)

SLI ] 1 4 2.0 div add
SLI [1] dup
SLI [2] exp
SLI [2] add
SLI [1] =
23.0855

Important stack commands

Command Description = Print the object at level 0. == Print the object at level 0 in syntax form. count Count the number of objects on the stack. patsck Display the stack in syntax form. stack Display the stack. pop, ; Pop object from stack. npop Pop n objects from stack. dup Duplicate top object of stack. copy Copy the first n objects of the stack. index Copy the n'th object of the stack. roll Roll a portion of n stack levels k times. exec Execute the top element on the stack.