Table of Contents
GEL stands for Genius Extension Language. It is the language you use to write programs in Genius. A program in GEL is simply an expression that evaluates to a number, a matrix, or another object in GEL. Genius Mathematics Tool can be used as a simple calculator, or as a powerful theoretical research tool. The syntax is meant to have as shallow of a learning curve as possible, especially for use as a calculator.
Values in GEL can be numbers, Booleans, or strings. GEL also treats matrices as values. Values can be used in calculations, assigned to variables and returned from functions, among other uses.
Integers are the first type of number in GEL. Integers are written in the normal way.
1234
Hexadecimal and octal numbers can be written using C notation. For example:
0x123ABC 01234
Or you can type numbers in an arbitrary base using <base>\<number>
. Digits higher than 10 use letters in a similar way to hexadecimal. For example, a number in base 23 could be written:
23\1234ABCD
The second type of GEL number is rationals. Rationals are simply achieved by dividing two integers. So one could write:
3/4
to get three quarters. Rationals also accept mixed fraction notation. So in order to get one and three tenths you could write:
1 3/10
The next type of number is floating point. These are entered in a similar fashion to C notation. You can use E
, e
or @
as the exponent delimiter. Note that using the exponent delimiter gives a float even if there is no decimal point in the number. Examples:
1.315 7.887e77 7.887e-77 .3 0.3 77e5
When Genius prints a floating point number it will always append a
.0
even if the number is whole. This is to indicate that
floating point numbers are taken as imprecise quantities. When a number is written in the
scientific notation, it is always a floating point number and thus Genius does not
print the .0
.
The final type of number in GEL is the complex numbers. You can enter a complex number as a sum of real and imaginary parts. To add an imaginary part, append an i
. Here are examples of entering complex numbers:
1+2i 8.01i 77*e^(1.3i)
When entering imaginary numbers, a number must be in front of the i
. If you use i
by itself, Genius will interpret this as referring to the variable i
. If you need to refer to i
by itself, use 1i
instead.
In order to use mixed fraction notation with imaginary numbers you must have the mixed fraction in parentheses. (i.e., (1 2/5)i
)
Genius also supports native Boolean values. The two Boolean constants are
defined as true
and false
; these
identifiers can be used like any other variable. You can also use the
identifiers True
, TRUE
,
False
and FALSE
as aliases for the
above.
At any place where a Boolean expression is expected, you can use a Boolean
value or any expression that produces either a number or a Boolean. If
Genius needs to evaluate a number as a Boolean it will interpret
0 as false
and any other number as
true
.
In addition, you can do arithmetic with Boolean values. For example:
( (1 + true) - false ) * true
is the same as:
( (true or true) or not false ) and true
Only addition, subtraction and multiplication are supported. If you mix numbers with Booleans in an expression then the numbers are converted to Booleans as described above. This means that, for example:
1 == true
always evaluates to true
since 1 will be converted to true
before being compared to true
.
Like numbers and Booleans, strings in GEL can be stored as values inside variables and passed to functions. You can also concatenate a string with another value using the plus operator. For example:
a=2+3;"The result is: "+a
will create the string:
The result is: 5
You can also use C-like escape sequences such as \n
,\t
,\b
,\a
and \r
. To get a \
or "
into the string you can quote it with a \
. For example:
"Slash: \\ Quotes: \" Tabs: \t1\t2\t3"
will make a string:
Slash: \ Quotes: " Tabs: 1 2 3
Do note however that when a string is returned from a function, escapes are
quoted, so that the output can be used as input. If you wish to print the
string as it is (without escapes), use the
print
or
printn
functions.
In addition, you can use the library function string
to convert anything to a string. For example:
string(22)
will return
"22"
Strings can also be compared with ==
(equal), !=
(not equal) and <=>
(comparison) operators
There is a special value called
null
. No operations can be performed on
it, and nothing is printed when it is returned. Therefore,
null
is useful when you do not want output from an
expression. The value null
can be obtained as an expression when you
type .
, the constant null
or nothing.
By nothing we mean that if you end an expression with
a separator ;
, it is equivalent to ending it with a
separator followed by a null
.
Example:
x=5;. x=5;
Some functions return null
when no value can be returned
or an error happened. Also null
is used as an empty vector
or matrix, or an empty reference.