<< max_recursion_depth | Interpreter functions | parsefile >> |
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.
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]
double, single, int8, int16, int32, int64, uint8, uint16, uint32, uint64.
Version | Description |
---|---|
1.0.0 | initial version |
Allan CORNET