4a89776a52e193690d6c6b2f5cf7be2792b18468
[blender.git] / source / blender / blenlib / BLI_math_base.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
19  * All rights reserved.
20  *
21  * The Original Code is: some of this file.
22  *
23  * ***** END GPL LICENSE BLOCK *****
24  * */
25
26 #ifndef __BLI_MATH_BASE_H__
27 #define __BLI_MATH_BASE_H__
28
29 /** \file BLI_math_base.h
30  *  \ingroup bli
31  */
32
33 #ifdef WIN32
34 #define _USE_MATH_DEFINES
35 #endif
36
37 #include <math.h>
38 #include "BLI_math_inline.h"
39
40 #ifdef __sun__
41 #include <ieeefp.h> /* for finite() */
42 #endif
43
44 #ifndef M_PI
45 #define M_PI        3.14159265358979323846
46 #endif
47 #ifndef M_PI_2
48 #define M_PI_2      1.57079632679489661923
49 #endif
50 #ifndef M_SQRT2
51 #define M_SQRT2     1.41421356237309504880
52 #endif
53 #ifndef M_SQRT1_2
54 #define M_SQRT1_2   0.70710678118654752440
55 #endif
56 #ifndef M_SQRT3
57 #define M_SQRT3   1.7320508075688772
58 #endif
59 #ifndef M_1_PI
60 #define M_1_PI      0.318309886183790671538
61 #endif
62 #ifndef M_E
63 #define M_E             2.7182818284590452354
64 #endif
65 #ifndef M_LOG2E
66 #define M_LOG2E         1.4426950408889634074
67 #endif
68 #ifndef M_LOG10E
69 #define M_LOG10E        0.43429448190325182765
70 #endif
71 #ifndef M_LN2
72 #define M_LN2           0.69314718055994530942
73 #endif
74 #ifndef M_LN10
75 #define M_LN10          2.30258509299404568402
76 #endif
77
78 /* non-standard defines, used in some places */
79 #ifndef MAXFLOAT
80 #define MAXFLOAT  ((float)3.40282347e+38)
81 #endif
82
83 #ifndef sqrtf
84 #define sqrtf(a) ((float)sqrt(a))
85 #endif
86 #ifndef powf
87 #define powf(a, b) ((float)pow(a, b))
88 #endif
89 #ifndef cosf
90 #define cosf(a) ((float)cos(a))
91 #endif
92 #ifndef sinf
93 #define sinf(a) ((float)sin(a))
94 #endif
95 #ifndef acosf
96 #define acosf(a) ((float)acos(a))
97 #endif
98 #ifndef asinf
99 #define asinf(a) ((float)asin(a))
100 #endif
101 #ifndef atan2f
102 #define atan2f(a, b) ((float)atan2(a, b))
103 #endif
104 #ifndef tanf
105 #define tanf(a) ((float)tan(a))
106 #endif
107 #ifndef atanf
108 #define atanf(a) ((float)atan(a))
109 #endif
110 #ifndef floorf
111 #define floorf(a) ((float)floor(a))
112 #endif
113 #ifndef ceilf
114 #define ceilf(a) ((float)ceil(a))
115 #endif
116 #ifndef fabsf
117 #define fabsf(a) ((float)fabs(a))
118 #endif
119 #ifndef logf
120 #define logf(a) ((float)log(a))
121 #endif
122 #ifndef expf
123 #define expf(a) ((float)exp(a))
124 #endif
125 #ifndef fmodf
126 #define fmodf(a, b) ((float)fmod(a, b))
127 #endif
128 #ifndef hypotf
129 #define hypotf(a, b) ((float)hypot(a, b))
130 #endif
131
132 #ifdef WIN32
133 #  ifndef FREE_WINDOWS
134 #    define isnan(n) _isnan(n)
135 #    define finite _finite
136 #    define hypot _hypot
137 #  endif
138 #endif
139
140 /* Causes warning:
141  * incompatible types when assigning to type 'Foo' from type 'Bar'
142  * ... the compiler optimizes away the temp var */
143 #ifndef CHECK_TYPE
144 #ifdef __GNUC__
145 #define CHECK_TYPE(var, type)  {  \
146         __typeof(var) *__tmp;         \
147         __tmp = (type *)NULL;         \
148         (void)__tmp;                  \
149 } (void)0
150 #else
151 #define CHECK_TYPE(var, type)
152 #endif
153 #endif
154
155 #ifndef SWAP
156 #  define SWAP(type, a, b)  {  \
157         type sw_ap;                \
158         CHECK_TYPE(a, type);       \
159         CHECK_TYPE(b, type);       \
160         sw_ap = (a);               \
161         (a) = (b);                 \
162         (b) = sw_ap;               \
163 } (void)0
164 #endif
165
166 #ifndef CLAMP
167 #  define CLAMP(a, b, c)  if ((a) < (b)) (a) = (b); else if ((a) > (c)) (a) = (c)
168 #endif
169
170 #ifdef __BLI_MATH_INLINE_H__
171 #include "intern/math_base_inline.c"
172 #endif
173
174 /******************************* Float ******************************/
175
176 MINLINE float sqrt3f(float f);
177 MINLINE double sqrt3d(double d);
178
179 MINLINE float saacosf(float f);
180 MINLINE float saasinf(float f);
181 MINLINE float sasqrtf(float f);
182 MINLINE float saacos(float fac);
183 MINLINE float saasin(float fac);
184 MINLINE float sasqrt(float fac);
185
186 MINLINE float interpf(float a, float b, float t);
187
188 MINLINE float minf(float a, float b);
189 MINLINE float maxf(float a, float b);
190
191 MINLINE float signf(float f);
192
193 MINLINE float power_of_2(float f);
194
195 /* these don't really fit anywhere but were being copied about a lot */
196 MINLINE int is_power_of_2_i(int n);
197 MINLINE int power_of_2_max_i(int n);
198 MINLINE int power_of_2_min_i(int n);
199
200 MINLINE float shell_angle_to_dist(float angle);
201
202 #if (defined(WIN32) || defined(WIN64)) && !defined(FREE_WINDOWS)
203 extern double copysign(double x, double y);
204 extern double round(double x);
205 #endif
206
207 double double_round(double x, int ndigits);
208
209 #endif /* __BLI_MATH_BASE_H__ */
210