Using Functions

Syntax:

FunctionName(argument1, argument2, ...)

Example:

Factorial(5)
cos(2*pi)
gcd(921,317)

To evaluate a function, enter the name of the function, followed by the arguments (if any) to the function in parentheses. This will return the result of applying the function to its arguments. The number of arguments to the function is, of course, different for each function.

There are many built-in functions, such as sin, cos and tan. You can use the help built-in command to get a list of available functions, or see Chapter 11, List of GEL functions for a full listing.

Using Tab completion

You can use Tab completion to get Genius to complete function names for you. Try typing the first few letters of the name and pressing Tab.

Function names are case sensitive

The names of functions are case sensitive. That means that functions named dosomething, DOSOMETHING and DoSomething are all different functions.

Defining Functions

Syntax:

function <identifier>(<comma separated arguments>) = <function body>
<identifier> = (`() = <function body>)

The ` is the backquote character, and signifies an anonymous function. By setting it to a variable name you effectively define a function.

A function takes zero or more comma separated arguments, and returns the result of the function body. Defining your own functions is primarily a matter of convenience; one possible use is to have sets of functions defined in GEL files that Genius can load in order to make them available. Example:

function addup(a,b,c) = a+b+c

then addup(1,4,9) yields 14

Variable Argument Lists

If you include ... after the last argument name in the function declaration, then Genius will allow any number of arguments to be passed in place of that argument. If no arguments were passed then that argument will be set to null. Otherwise, it will be a horizontal vector containing all the arguments. For example:

function f(a,b...) = b

Then f(1,2,3) yields [2,3], while f(1) yields a null.

Passing Functions to Functions

In Genius, it is possible to pass a function as an argument to another function. This can be done using either ‘function nodes’ or anonymous functions.

If you do not enter the parentheses after a function name, instead of being evaluated, the function will instead be returned as a ‘function node’. The function node can then be passed to another function. Example:

function f(a,b) = a(b)+1;
function b(x) = x*x;
f(b,2)

To pass functions that are not defined, you can use an anonymous function (see the section called “Defining Functions”). That is, you want to pass a function without giving it a name. Syntax:

function(<comma separated arguments>) = <function body>
`(<comma separated arguments>) = <function body>

Example:

function f(a,b) = a(b)+1;
f(`(x) = x*x,2)

This will return 5.

Operations on Functions

Some functions allow arithmetic operations, and some single argument functions such as exp or ln, to operate on the function. For example,

exp(sin*cos+4)

will return a function that takes x and returns exp(sin(x)*cos(x)+4). It is functionally equivalent to typing

`(x) = exp(sin(x)*cos(x)+4)

This operation can be useful when quickly defining functions. For example to create a function called f to perform the above operation, you can just type:

f = exp(sin*cos+4)

It can also be used in plotting. For example, to plot sin squared you can enter:

LinePlot(sin^2)

Warning

Not all functions can be used in this way. For example, when you use a binary operation the functions must take the same number of arguments.