<< max_recursion_depth Interpreter functions parsefile >>

numeric types


About integer and floating-point data.


Description


In Nelson you can specify the data type of a numeric literal by using a suffix or a type specifier.

Here are some common suffixes for specifying the data type of numeric literals:

literal number suffix Nelson type
f32 single (float single precision)
f64 double (float double precision)
i8 int8 (8-bit signed integer)
i16 int16 (16-bit signed integer)
i32 int32 (32-bit signed integer)
i64 int64 (64-bit signed integer)
u8 uint8 (8-bit unsigned integer)
u16 uint16 (16-bit unsigned integer)
u32 uint32 (32-bit unsigned integer)
u64 uint64 (64-bit unsigned integer)

i64: To specify a 64-bit signed integer, you can use the i64 suffix. example: A = 42i64

f32: To specify a 32-bit floating-point number (single precision), you can use the f64 suffix. example: 3.14f32

These suffixes help the Nelson infer the correct data type for the literal.

Nelson automatically infer data type by default as double and you don't need to specify this suffixe explicitly. example: A = 3.14

Unless you have specific requirements or need to disambiguate between data types, you often don't need to explicitly specify the type of numeric literals.

But when you create a numeric array of large integers in Nelson, especially when they exceed the maximum precision representable by double (larger than flintmax), Nelson initially stores these values as double-precision floating-point numbers by default.

Examples


explicit single number

single(3.1415)
3.1415f32

implicit-explicit double number

3.1415
3.1415f64

values exceed maximum precision representable by double

R1 = uint64([72057594035891654 81997179153022975])
R2 = [72057594035891654u64 81997179153022975u64]

See also


double, single, int8, int16, int32, int64, uint8, uint16, uint32, uint64.

History


Version Description
1.0.0 initial version

Author


Allan CORNET

<< max_recursion_depth Interpreter functions parsefile >>