aboutsummaryrefslogtreecommitdiffstats
path: root/include/rin/float.h
blob: 8bf9f4a320e57a6e1e5cb12c6fc1dd64dc38b697 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 * The Rin Library – floating point module
 *
 * Copyright (C) 2015 Gediminas Jakutis
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; version 2.1
 * of the License.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
 */

#ifndef LIBRIN_FLOAT_INCLUDED
#define LIBRIN_FLOAT_INCLUDED

#include <stdint.h>
#include <rin/float_types.h>

/*
 * TODO:
 * · more modes
 */

static const unsigned int RIN_HEXSTRING_DEFAULT =	0x00000000u;
static const unsigned int RIN_HEXSTRING_NOPREFIX =	0x00000001u;

/*
 * All following the functions assume IEEE 754 floating point numbers
 * and thus are only expected to work only on systems which use IEEE 754.
 *
 * The versions suffixed with "d" / double versions are otherwise
 * identical to the float counterparts.
 */

uint32_t rin_signbitf(const float num);
uint64_t rin_signbitd(const double num);

char *rin_float_to_hexstring(const float num, char *str, unsigned int mode);
char *rin_double_to_hexstring(const double num, char *str, unsigned int mode);

unsigned int rin_compare_float(const float a, const float b, uint32_t max_ulps);
unsigned int rin_compare_vec2(const struct rin_vec2 a, const struct rin_vec2 b, uint32_t max_ulps);
unsigned int rin_compare_vec3(const struct rin_vec3 a, const struct rin_vec3 b, uint32_t max_ulps);
unsigned int rin_compare_vec4(const struct rin_vec4 a, const struct rin_vec4 b, uint32_t max_ulps);

unsigned int rin_compare_double(const double a, const double b, uint64_t max_ulps);
unsigned int rin_compare_vec2d(const struct rin_vec2d a, const struct rin_vec2d b, uint64_t max_ulps);
unsigned int rin_compare_vec3d(const struct rin_vec3d a, const struct rin_vec3d b, uint64_t max_ulps);
unsigned int rin_compare_vec4d(const struct rin_vec4d a, const struct rin_vec4d b, uint64_t max_ulps);

uint32_t rin_float_to_uint(const float num);
int32_t rin_float_to_int(const float num);
float rin_uint_to_float(const uint32_t num);
float rin_int_to_float(const int32_t num);

uint64_t rin_double_to_ulong(const double num);
int64_t rin_double_to_long(const double num);
double rin_ulong_to_double(const uint64_t num);
double rin_long_to_double(const int64_t num);

#endif /* LIBRIN_FLOAT_INCLUDED */