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