### Multi-Line Dfns

The single expression which provides the result of the dfn may be preceded by any number of assignment statements. Each such statement introduces a name which is local to the function.

For example in the following, the expressions sum← and num← create local variables sum and num.

```      mean←{          ⍝ Arithmetic mean
sum←+/⍵     ⍝ Sum of elements
num←⍴       ⍝ Number of elements
sum÷num     ⍝ Mean
}```

Note that dfns may be commented in the usual way using .

When the interpreter encounters a local definition, a new local name is created. The name is shadowed dynamically exactly as if the assignment had been preceded by: ⎕shadow name .

It is important to note the distinction between the two types of statement above. There can be many assignment statements, each introducing a new local variable, but only a single expression where the result is not assigned. As soon as the interpreter encounters such an expression, it is evaluated and the result returned immediately as the result of the function.

For example, in the following,

```      mean←{          ⍝ Arithmetic mean
sum←+/⍵     ⍝ Sum of elements
num←⍴       ⍝ Number of elements
sum,num     ⍝ Attempt to show sum,num (wrong)!
sum÷num     ⍝ ... and return result.
}
```

... as soon as the interpreter encounters the expression sum,num, the function terminates with the two element result (sum,num) and the following line is not evaluated.

To display arrays to the session from within a dfn, you can use the explicit display forms ⎕← or ⍞← as in:

```      mean←{          ⍝ Arithmetic mean
sum←+/⍵     ⍝ Sum of elements
num←⍴       ⍝ Number of elements
⎕←sum,num   ⍝ show sum,num.
sum÷num     ⍝ ... and return result.
}```

Note that local definitions can be used to specify local nested dfns:

```      rms←{                ⍝ Root Mean Square
root←{⍵*0.5}      ⍝ ∇ Square root
mean←{(+/⍵)÷⍴⍵    ⍝ ∇ Mean
square←{⍵×⍵       ⍝ ∇ Square
root mean square
}```