Number Type - num
The num
type is a special type that represents a number (both floating point and
integer) in the Kipper language. This datatype may always be used with the standard mathematical
expressions.
Order or evaluation
When working with numbers watch out for the order of evaluations of arithmetic expressions. Kipper will interpret mathematical calculations as defined in the standard math conventions i.e. multiplications, divisions and power-to operations have a higher priority than additions and subtractions.
Simple example:
These are also defined in the table of operator precedence.
Octal, Hex and Binary numbers
Besides the regular Base-10 numbers, you may also use Hex, Octal and Binary numbers, as long as they are prefixed with the correct identifier:
- Binary numbers are prefixed with
0b
:
- Hexadecimal numbers are prefixed with
0x
:
- Octal numbers are prefixed with
0o
:
Note that the numbers stored in the variables are always stored as Base-10 numbers, so converting them to a string will always result in a Base-10 number.
This also means that you may mix different number types together, as long as they are prefixed with the correct identifier:
Safe Number Range
Due to the fact that Kipper only compiles to TypeScript or JavaScript, the underlying number type
will almost always be a 64-bit floating point number. This means that the maximum safe number range
is the same as in JavaScript, which is
Number.MAX_SAFE_INTEGER
.
Over this limit, the numbers will start to lose precision, as shown in the following example:
Performing equality checks now causes the following problem:
This is due to the fact that the numbers are stored as floating point numbers, which are not able to represent the number with full precision.
Note
Kipper is at the stage of writing with the current version still under heavy development. This
means that the implementation of types such as
BigInt
may take some time.
This also includes global functions to check whether a number is within the safe range or not.
Examples
Simple integer variable definitions
Simple floating point variable definitions
Calculations using floating point and integer numbers
Arithmetic Expressions
The following arithmetic expressions are supported (as also shown in arithmetical expressions):
- Addition:
- Subtraction:
- Multiplication:
- Division:
- Power to:
- Rest of Divide (Modulo):