Floating point numbers data type management. More...
Macros | |
#define | EINA_F32P32_PI 0x00000003243f6a89 |
Yields the 32-bit PI constant. | |
#define | eina_fp32p32_llabs(a) ((a < 0) ? -(a) : (a)) |
Gets the absolute value of an Eina_F32p32 floating point number. More... | |
#define | EINA_F16P16_ONE (1 << 16) |
Yields the maximum 16-bit unsigned integer size (= 65536) | |
#define | EINA_F16P16_HALF (1 << 15) |
Yields the maximum 16-bit signed integer size (= 32768) | |
Functions | |
static Eina_F32p32 | eina_f32p32_int_from (int32_t v) |
Creates a new Eina_F32p32 floating point number from standard 32-bit integer. More... | |
static int32_t | eina_f32p32_int_to (Eina_F32p32 v) |
Creates a new standard 32-bit integer from Eina_F32p32 floating point number. More... | |
static Eina_F32p32 | eina_f32p32_double_from (double v) |
Creates a new Eina_F32p32 floating point number from standard double. More... | |
static double | eina_f32p32_double_to (Eina_F32p32 v) |
Creates a new standard double from Eina_F32p32 floating point number. More... | |
static Eina_F32p32 | eina_f32p32_add (Eina_F32p32 a, Eina_F32p32 b) |
Calculates the sum of two Eina_F32p32 floating point numbers. More... | |
static Eina_F32p32 | eina_f32p32_sub (Eina_F32p32 a, Eina_F32p32 b) |
Calculates the subtraction of two Eina_F32p32 floating point numbers. More... | |
static Eina_F32p32 | eina_f32p32_mul (Eina_F32p32 a, Eina_F32p32 b) |
Calculates the multiplication of two Eina_F32p32 floating point numbers. More... | |
static Eina_F32p32 | eina_f32p32_scale (Eina_F32p32 a, int b) |
Calculates the scale multiplication of one Eina_F32p32 floating point number with an integer. More... | |
static Eina_F32p32 | eina_f32p32_div (Eina_F32p32 a, Eina_F32p32 b) |
Calculates the division of two Eina_F32p32 floating point numbers. More... | |
static Eina_F32p32 | eina_f32p32_sqrt (Eina_F32p32 a) |
Calculates the square root of an Eina_F32p32 floating point number. More... | |
static unsigned int | eina_f32p32_fracc_get (Eina_F32p32 v) |
Gets the absolute value of the integer part of and Eina_F32p32 floating point number. More... | |
EINA_API Eina_F32p32 | eina_f32p32_cos (Eina_F32p32 a) |
Calculates the cosine of a floating point number. More... | |
EINA_API Eina_F32p32 | eina_f32p32_sin (Eina_F32p32 a) |
Calculates the sine of a floating point number. More... | |
static Eina_F16p16 | eina_f16p16_int_from (int32_t v) |
Creates a new Eina_F16p316 floating point number from standard 32-bit integer. More... | |
static int32_t | eina_f16p16_int_to (Eina_F16p16 v) |
Creates a new standard 32-bit integer from Eina_F16p16 floating point number. More... | |
static Eina_F16p16 | eina_f16p16_double_from (double v) |
Creates a new Eina_F16p16 floating point number from standard double. More... | |
static double | eina_f16p16_double_to (Eina_F16p16 v) |
Creates a new standard double from Eina_F16p16 floating point number. More... | |
static Eina_F16p16 | eina_f16p16_float_from (float v) |
Creates a new Eina_F16p16 floating point number from standard float. More... | |
static float | eina_f16p16_float_to (Eina_F16p16 v) |
Creates a new standard float from Eina_F16p16 floating point number. More... | |
static Eina_F16p16 | eina_f16p16_add (Eina_F16p16 a, Eina_F16p16 b) |
Calculates the sum of two Eina_F16p16 floating point numbers. More... | |
static Eina_F16p16 | eina_f16p16_sub (Eina_F16p16 a, Eina_F16p16 b) |
Calculates the subtraction of two Eina_F16p16 floating point numbers. More... | |
static Eina_F16p16 | eina_f16p16_mul (Eina_F16p16 a, Eina_F16p16 b) |
Calculates the multiplication of two Eina_F16p16 floating point numbers. More... | |
static Eina_F16p16 | eina_f16p16_scale (Eina_F16p16 a, int b) |
Calculates the scale multiplication of one Eina_F16p16 floating point number with an integer. More... | |
static Eina_F16p16 | eina_f16p16_div (Eina_F16p16 a, Eina_F16p16 b) |
Calculates the division of two Eina_F16p16 floating point numbers. More... | |
static Eina_F16p16 | eina_f16p16_sqrt (Eina_F16p16 a) |
Calculates the square root of an Eina_F16p16 floating point number. More... | |
static unsigned int | eina_f16p16_fracc_get (Eina_F16p16 v) |
Gets the absolute value of the integer part of and Eina_F16p16 floating point number. More... | |
static Eina_F8p24 | eina_f8p24_int_from (int32_t v) |
Creates a new Eina_F16p316 floating point number from standard 32-bit integer. More... | |
static int32_t | eina_f8p24_int_to (Eina_F8p24 v) |
Creates a new standard 32-bit integer from Eina_F8p24 floating point number. More... | |
static Eina_F8p24 | eina_f8p24_float_from (float v) |
Creates a new Eina_F8p24 floating point number from standard float. More... | |
static float | eina_f8p24_float_to (Eina_F8p24 v) |
Create a new standard float from Eina_F8p24 floating point number. More... | |
static Eina_F8p24 | eina_f8p24_add (Eina_F8p24 a, Eina_F8p24 b) |
Calculates the sum of two Eina_F8p24 floating point numbers. More... | |
static Eina_F8p24 | eina_f8p24_sub (Eina_F8p24 a, Eina_F8p24 b) |
Calculates the subtraction of two Eina_F8p24 floating point numbers. More... | |
static Eina_F8p24 | eina_f8p24_mul (Eina_F8p24 a, Eina_F8p24 b) |
Calculates the multiplication of two Eina_F8p24 floating point numbers. More... | |
static Eina_F8p24 | eina_f8p24_scale (Eina_F8p24 a, int b) |
Calculates the scale multiplication of one Eina_F8p24 floating point number with an integer. More... | |
static Eina_F8p24 | eina_f8p24_div (Eina_F8p24 a, Eina_F8p24 b) |
Calculates the division of two Eina_F8p24 floating point numbers. More... | |
static Eina_F8p24 | eina_f8p24_sqrt (Eina_F8p24 a) |
Calculates the square root of an Eina_F8p24 floating point number. More... | |
static unsigned int | eina_f8p24_fracc_get (Eina_F8p24 v) |
Gets the absolute value of the integer part of and Eina_F8p24 floating point number. More... | |
static Eina_F32p32 | eina_f16p16_to_f32p32 (Eina_F16p16 a) |
Converts an Eina_F16p16 floating point number into Eina_F32p32 format. More... | |
static Eina_F32p32 | eina_f8p24_to_f32p32 (Eina_F8p24 a) |
Converts an Eina_F8p24 floating point number into Eina_F32p32 format. More... | |
static Eina_F16p16 | eina_f32p32_to_f16p16 (Eina_F32p32 a) |
Converts an Eina_F32p32 floating point number into Eina_F16p16 format. More... | |
static Eina_F16p16 | eina_f8p24_to_f16p16 (Eina_F8p24 a) |
Converts an Eina_F8p24 floating point number into Eina_F16p16 format. More... | |
static Eina_F8p24 | eina_f32p32_to_f8p24 (Eina_F32p32 a) |
Converts an Eina_F32p32 floating point number into Eina_F8p24 format. More... | |
static Eina_F8p24 | eina_f16p16_to_f8p24 (Eina_F16p16 a) |
Converts an Eina_F16p16 floating point number into Eina_F8p16 format. More... | |
Floating point numbers data type management.
#define eina_fp32p32_llabs | ( | a | ) | ((a < 0) ? -(a) : (a)) |
Gets the absolute value of an Eina_F32p32 floating point number.
[in] | a | The floating point number |
a
|
inlinestatic |
Creates a new Eina_F32p32 floating point number from standard 32-bit integer.
[in] | v | 32-bit integer value to convert |
|
inlinestatic |
Creates a new standard 32-bit integer from Eina_F32p32 floating point number.
[in] | v | Eina_F32p32 value to convert |
Referenced by eina_f32p32_cos().
|
inlinestatic |
Creates a new Eina_F32p32 floating point number from standard double.
[in] | v | Double value to convert |
Referenced by eina_quaternion_f16p16_slerp().
|
inlinestatic |
Creates a new standard double from Eina_F32p32 floating point number.
[in] | v | Eina_F32p32 value to convert |
|
inlinestatic |
Calculates the sum of two Eina_F32p32 floating point numbers.
[in] | a | The first number |
[in] | b | The second number |
a
+ b
Referenced by eina_f32p32_cos().
|
inlinestatic |
Calculates the subtraction of two Eina_F32p32 floating point numbers.
[in] | a | The first number |
[in] | b | The subtracted number |
a
- b
Referenced by eina_f32p32_cos(), and eina_f32p32_sin().
|
inlinestatic |
Calculates the multiplication of two Eina_F32p32 floating point numbers.
[in] | a | The first number |
[in] | b | The second number |
a
* b
To prevent overflow during multiplication we need to reduce the precision of the fraction part Shift both values to only contain 16 bit of the fraction part (rounded). After multiplication we again have a value with a 32-bit fraction part.
Referenced by eina_f32p32_cos(), and eina_quaternion_f16p16_slerp().
|
inlinestatic |
Calculates the scale multiplication of one Eina_F32p32 floating point number with an integer.
[in] | a | The Eina_F32p32 number |
[in] | b | The integer value |
a
* b
Referenced by eina_f32p32_cos().
|
inlinestatic |
Calculates the division of two Eina_F32p32 floating point numbers.
[in] | a | The numerator number |
[in] | b | The denominator number |
a
/ b
Referenced by eina_f32p32_cos(), and eina_quaternion_f16p16_slerp().
|
inlinestatic |
Calculates the square root of an Eina_F32p32 floating point number.
[in] | a | The number to calculate the square root from |
a
|
inlinestatic |
Gets the absolute value of the integer part of and Eina_F32p32 floating point number.
[in] | v | The floating point number |
v
Referenced by eina_f32p32_cos().
EINA_API Eina_F32p32 eina_f32p32_cos | ( | Eina_F32p32 | a | ) |
Calculates the cosine of a floating point number.
[in] | a | The angle in radians to calculate the cosine from. |
a
References eina_f32p32_add(), eina_f32p32_div(), eina_f32p32_fracc_get(), eina_f32p32_int_to(), eina_f32p32_mul(), EINA_F32P32_PI, eina_f32p32_scale(), eina_f32p32_sub(), and eina_fp32p32_llabs.
Referenced by eina_f32p32_sin().
EINA_API Eina_F32p32 eina_f32p32_sin | ( | Eina_F32p32 | a | ) |
Calculates the sine of a floating point number.
[in] | a | The angle in radians to calculate the sine from. |
a
References eina_f32p32_cos(), EINA_F32P32_PI, and eina_f32p32_sub().
Referenced by eina_quaternion_f16p16_slerp().
|
inlinestatic |
Creates a new Eina_F16p316 floating point number from standard 32-bit integer.
[in] | v | 32-bit integer value to convert |
Referenced by eina_quaternion_f16p16_lerp(), eina_quaternion_f16p16_nlerp(), and eina_quaternion_f16p16_slerp().
|
inlinestatic |
Creates a new standard 32-bit integer from Eina_F16p16 floating point number.
[in] | v | Eina_F16p16 value to convert |
Referenced by eina_quaternion_f16p16_rotation_matrix3_get().
|
inlinestatic |
Creates a new Eina_F16p16 floating point number from standard double.
[in] | v | Double value to convert |
Referenced by eina_matrix3_fixed_values_get().
|
inlinestatic |
Creates a new standard double from Eina_F16p16 floating point number.
[in] | v | Eina_F16p16 value to convert |
Referenced by eina_quaternion_f16p16_slerp().
|
inlinestatic |
Creates a new Eina_F16p16 floating point number from standard float.
[in] | v | Float value to convert |
Referenced by eina_quaternion_f16p16_slerp().
|
inlinestatic |
Creates a new standard float from Eina_F16p16 floating point number.
[in] | v | Eina_F16p16 value to convert |
|
inlinestatic |
Calculates the sum of two Eina_F16p16 floating point numbers.
[in] | a | The first number |
[in] | b | The second number |
a
+ b
Referenced by eina_quaternion_f16p16_add(), eina_quaternion_f16p16_dot(), eina_quaternion_f16p16_lerp(), eina_quaternion_f16p16_mul(), eina_quaternion_f16p16_norm(), eina_quaternion_f16p16_rotate(), and eina_quaternion_f16p16_rotation_matrix3_get().
|
inlinestatic |
Calculates the subtraction of two Eina_F16p16 floating point numbers.
[in] | a | The first number |
[in] | b | The subtracted number |
a
- b
Referenced by eina_quaternion_f16p16_conjugate(), eina_quaternion_f16p16_lerp(), eina_quaternion_f16p16_mul(), eina_quaternion_f16p16_negative(), eina_quaternion_f16p16_nlerp(), eina_quaternion_f16p16_rotate(), eina_quaternion_f16p16_rotation_matrix3_get(), and eina_quaternion_f16p16_slerp().
|
inlinestatic |
Calculates the multiplication of two Eina_F16p16 floating point numbers.
[in] | a | The first number |
[in] | b | The second number |
a
* b
Referenced by eina_matrix3_f16p16_compose(), eina_quaternion_f16p16_dot(), eina_quaternion_f16p16_lerp(), eina_quaternion_f16p16_mul(), eina_quaternion_f16p16_norm(), eina_quaternion_f16p16_rotate(), and eina_quaternion_f16p16_rotation_matrix3_get().
|
inlinestatic |
Calculates the scale multiplication of one Eina_F16p16 floating point number with an integer.
[in] | a | The Eina_F16p16 number |
[in] | b | The integer value |
a
* b
Referenced by eina_quaternion_f16p16_rotate(), eina_quaternion_f16p16_rotation_matrix3_get(), and eina_quaternion_f16p16_scale().
|
inlinestatic |
Calculates the division of two Eina_F16p16 floating point numbers.
[in] | a | The numerator number |
[in] | b | The denominator number |
a
/ b
|
inlinestatic |
Calculates the square root of an Eina_F16p16 floating point number.
[in] | a | The number to calculate the square root from |
a
Referenced by eina_quaternion_f16p16_norm().
|
inlinestatic |
Gets the absolute value of the integer part of and Eina_F16p16 floating point number.
[in] | v | The floating point number |
v
|
inlinestatic |
Creates a new Eina_F16p316 floating point number from standard 32-bit integer.
[in] | v | 32-bit integer value to convert |
|
inlinestatic |
Creates a new standard 32-bit integer from Eina_F8p24 floating point number.
[in] | v | Eina_F8p24 value to convert |
|
inlinestatic |
Creates a new Eina_F8p24 floating point number from standard float.
[in] | v | Float value to convert |
|
inlinestatic |
Create a new standard float from Eina_F8p24 floating point number.
[in] | v | Eina_F8p24 value to convert |
|
inlinestatic |
Calculates the sum of two Eina_F8p24 floating point numbers.
[in] | a | The first number |
[in] | b | The second number |
a
+ b
|
inlinestatic |
Calculates the subtraction of two Eina_F8p24 floating point numbers.
[in] | a | The first number |
[in] | b | The subtracted number |
a
- b
|
inlinestatic |
Calculates the multiplication of two Eina_F8p24 floating point numbers.
[in] | a | The first number |
[in] | b | The second number |
a
* b
|
inlinestatic |
Calculates the scale multiplication of one Eina_F8p24 floating point number with an integer.
[in] | a | The Eina_F16p16 number |
[in] | b | The integer value |
a
* b
|
inlinestatic |
Calculates the division of two Eina_F8p24 floating point numbers.
[in] | a | The numerator number |
[in] | b | The denominator number |
a
/ b
|
inlinestatic |
Calculates the square root of an Eina_F8p24 floating point number.
[in] | a | The number to calculate the square root from |
a
|
inlinestatic |
Gets the absolute value of the integer part of and Eina_F8p24 floating point number.
[in] | v | The floating point number |
v
|
inlinestatic |
Converts an Eina_F16p16 floating point number into Eina_F32p32 format.
[in] | a | The Eina_F16p16 floating point number |
Referenced by eina_quaternion_f16p16_slerp().
|
inlinestatic |
Converts an Eina_F8p24 floating point number into Eina_F32p32 format.
[in] | a | The Eina_F8p24 floating point number |
|
inlinestatic |
Converts an Eina_F32p32 floating point number into Eina_F16p16 format.
[in] | a | The Eina_F32p32 floating point number |
Referenced by eina_quaternion_f16p16_slerp().
|
inlinestatic |
Converts an Eina_F8p24 floating point number into Eina_F16p16 format.
[in] | a | The Eina_F8p24 floating point number |
|
inlinestatic |
Converts an Eina_F32p32 floating point number into Eina_F8p24 format.
[in] | a | The Eina_F32p32 floating point number |
|
inlinestatic |
Converts an Eina_F16p16 floating point number into Eina_F8p16 format.
[in] | a | The Eina_F16p16 floating point number |