| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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 General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: some of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #ifndef __BLI_MATH_BASE_H__
 | 
					
						
							|  |  |  | #define __BLI_MATH_BASE_H__
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup bli | 
					
						
							| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-18 11:23:56 -06:00
										 |  |  | #if defined(_MSC_VER) && !defined(_USE_MATH_DEFINES)
 | 
					
						
							| 
									
										
										
										
											2012-09-20 01:02:39 +00:00
										 |  |  | #  define _USE_MATH_DEFINES
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 06:03:29 +11:00
										 |  |  | #include "BLI_assert.h"
 | 
					
						
							| 
									
										
										
										
											2010-01-22 11:10:24 +00:00
										 |  |  | #include "BLI_math_inline.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include <math.h>
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef M_PI
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_PI 3.14159265358979323846 /* pi */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_PI_2
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_PI_2 1.57079632679489661923 /* pi/2 */
 | 
					
						
							| 
									
										
										
										
											2015-01-31 17:17:12 +11:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_PI_4
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_PI_4 0.78539816339744830962 /* pi/4 */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_SQRT2
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_SQRT2 1.41421356237309504880 /* sqrt(2) */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_SQRT1_2
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_SQRT1_2 0.70710678118654752440 /* 1/sqrt(2) */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-05-31 11:57:09 +00:00
										 |  |  | #ifndef M_SQRT3
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_SQRT3 1.73205080756887729352 /* sqrt(3) */
 | 
					
						
							| 
									
										
										
										
											2014-11-22 18:11:46 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_SQRT1_3
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_SQRT1_3 0.57735026918962576450 /* 1/sqrt(3) */
 | 
					
						
							| 
									
										
										
										
											2012-05-31 11:57:09 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #ifndef M_1_PI
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_1_PI 0.318309886183790671538 /* 1/pi */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_E
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_E 2.7182818284590452354 /* e */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_LOG2E
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_LOG2E 1.4426950408889634074 /* log_2 e */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_LOG10E
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_LOG10E 0.43429448190325182765 /* log_10 e */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_LN2
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_LN2 0.69314718055994530942 /* log_e 2 */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifndef M_LN10
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define M_LN10 2.30258509299404568402 /* log_e 10 */
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-13 10:40:23 +00:00
										 |  |  | #if defined(__GNUC__)
 | 
					
						
							|  |  |  | #  define NAN_FLT __builtin_nanf("")
 | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2013-08-13 10:09:27 +00:00
										 |  |  | /* evil quiet NaN definition */ | 
					
						
							|  |  |  | static const int NAN_INT = 0x7FC00000; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define NAN_FLT (*((float *)(&NAN_INT)))
 | 
					
						
							| 
									
										
										
										
											2013-08-13 10:40:23 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-08-13 10:09:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-23 15:12:13 +00:00
										 |  |  | #if BLI_MATH_DO_INLINE
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  include "intern/math_base_inline.c"
 | 
					
						
							| 
									
										
										
										
											2010-01-22 11:10:24 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-13 15:41:14 +00:00
										 |  |  | #ifdef BLI_MATH_GCC_WARN_PRAGMA
 | 
					
						
							| 
									
										
										
										
											2013-03-11 20:27:38 +00:00
										 |  |  | #  pragma GCC diagnostic push
 | 
					
						
							|  |  |  | #  pragma GCC diagnostic ignored "-Wredundant-decls"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | /******************************* Float ******************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-11 18:16:20 +01:00
										 |  |  | MINLINE float pow2f(float x); | 
					
						
							|  |  |  | MINLINE float pow3f(float x); | 
					
						
							|  |  |  | MINLINE float pow4f(float x); | 
					
						
							|  |  |  | MINLINE float pow7f(float x); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-22 11:10:24 +00:00
										 |  |  | MINLINE float sqrt3f(float f); | 
					
						
							|  |  |  | MINLINE double sqrt3d(double d); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-26 20:53:26 +11:00
										 |  |  | MINLINE float sqrtf_signed(float f); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-22 11:10:24 +00:00
										 |  |  | MINLINE float saacosf(float f); | 
					
						
							|  |  |  | MINLINE float saasinf(float f); | 
					
						
							|  |  |  | MINLINE float sasqrtf(float f); | 
					
						
							|  |  |  | MINLINE float saacos(float fac); | 
					
						
							|  |  |  | MINLINE float saasin(float fac); | 
					
						
							|  |  |  | MINLINE float sasqrt(float fac); | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-22 11:10:24 +00:00
										 |  |  | MINLINE float interpf(float a, float b, float t); | 
					
						
							| 
									
										
										
										
											2019-08-20 21:09:55 +08:00
										 |  |  | MINLINE double interpd(double a, double b, double t); | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 17:18:10 +01:00
										 |  |  | /* NOTE: Compilers will upcast all types smaller than int to int when performing arithmetic
 | 
					
						
							|  |  |  |  * operation. */ | 
					
						
							|  |  |  | MINLINE int square_s(short a); | 
					
						
							|  |  |  | MINLINE int square_uchar(unsigned char a); | 
					
						
							|  |  |  | MINLINE int cube_s(short a); | 
					
						
							|  |  |  | MINLINE int cube_uchar(unsigned char a); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MINLINE int square_i(int a); | 
					
						
							|  |  |  | MINLINE unsigned int square_uint(unsigned int a); | 
					
						
							|  |  |  | MINLINE float square_f(float a); | 
					
						
							|  |  |  | MINLINE double square_d(double a); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MINLINE int cube_i(int a); | 
					
						
							|  |  |  | MINLINE unsigned int cube_uint(unsigned int a); | 
					
						
							|  |  |  | MINLINE float cube_f(float a); | 
					
						
							|  |  |  | MINLINE double cube_d(double a); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-23 13:28:22 +00:00
										 |  |  | MINLINE float min_ff(float a, float b); | 
					
						
							|  |  |  | MINLINE float max_ff(float a, float b); | 
					
						
							| 
									
										
										
										
											2013-12-06 03:46:27 +11:00
										 |  |  | MINLINE float min_fff(float a, float b, float c); | 
					
						
							|  |  |  | MINLINE float max_fff(float a, float b, float c); | 
					
						
							|  |  |  | MINLINE float min_ffff(float a, float b, float c, float d); | 
					
						
							|  |  |  | MINLINE float max_ffff(float a, float b, float c, float d); | 
					
						
							| 
									
										
										
										
											2012-10-23 13:28:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-28 18:33:24 -06:00
										 |  |  | MINLINE double min_dd(double a, double b); | 
					
						
							|  |  |  | MINLINE double max_dd(double a, double b); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-23 13:28:22 +00:00
										 |  |  | MINLINE int min_ii(int a, int b); | 
					
						
							|  |  |  | MINLINE int max_ii(int a, int b); | 
					
						
							| 
									
										
										
										
											2013-12-06 03:46:27 +11:00
										 |  |  | MINLINE int min_iii(int a, int b, int c); | 
					
						
							|  |  |  | MINLINE int max_iii(int a, int b, int c); | 
					
						
							|  |  |  | MINLINE int min_iiii(int a, int b, int c, int d); | 
					
						
							|  |  |  | MINLINE int max_iiii(int a, int b, int c, int d); | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-21 10:39:15 +01:00
										 |  |  | MINLINE size_t min_zz(size_t a, size_t b); | 
					
						
							|  |  |  | MINLINE size_t max_zz(size_t a, size_t b); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-14 11:29:10 +02:00
										 |  |  | MINLINE char min_cc(char a, char b); | 
					
						
							|  |  |  | MINLINE char max_cc(char a, char b); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-14 11:21:27 +01:00
										 |  |  | MINLINE int clamp_i(int value, int min, int max); | 
					
						
							|  |  |  | MINLINE float clamp_f(float value, float min, float max); | 
					
						
							|  |  |  | MINLINE size_t clamp_z(size_t value, size_t min, size_t max); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-10 14:32:35 +02:00
										 |  |  | MINLINE int compare_ff(float a, float b, const float max_diff); | 
					
						
							|  |  |  | MINLINE int compare_ff_relative(float a, float b, const float max_diff, const int max_ulps); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-25 11:30:46 +00:00
										 |  |  | MINLINE float signf(float f); | 
					
						
							| 
									
										
										
										
											2014-12-27 16:47:42 +11:00
										 |  |  | MINLINE int signum_i_ex(float a, float eps); | 
					
						
							|  |  |  | MINLINE int signum_i(float a); | 
					
						
							| 
									
										
										
										
											2010-09-25 11:30:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-22 11:10:24 +00:00
										 |  |  | MINLINE float power_of_2(float f); | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-01 16:34:02 +02:00
										 |  |  | MINLINE int integer_digits_f(const float f); | 
					
						
							|  |  |  | MINLINE int integer_digits_d(const double d); | 
					
						
							| 
									
										
										
										
											2018-01-19 17:04:19 -02:00
										 |  |  | MINLINE int integer_digits_i(const int i); | 
					
						
							| 
									
										
										
										
											2017-08-01 16:34:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | /* these don't really fit anywhere but were being copied about a lot */ | 
					
						
							| 
									
										
										
										
											2011-12-16 09:25:07 +00:00
										 |  |  | MINLINE int is_power_of_2_i(int n); | 
					
						
							|  |  |  | MINLINE int power_of_2_max_i(int n); | 
					
						
							|  |  |  | MINLINE int power_of_2_min_i(int n); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-05 21:39:46 +11:00
										 |  |  | MINLINE unsigned int power_of_2_max_u(unsigned int x); | 
					
						
							|  |  |  | MINLINE unsigned int power_of_2_min_u(unsigned int x); | 
					
						
							| 
									
										
										
										
											2019-09-13 10:06:02 +02:00
										 |  |  | MINLINE unsigned int log2_floor_u(unsigned int x); | 
					
						
							|  |  |  | MINLINE unsigned int log2_ceil_u(unsigned int x); | 
					
						
							| 
									
										
										
										
											2014-04-05 21:39:46 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-25 14:16:22 +00:00
										 |  |  | MINLINE int divide_round_i(int a, int b); | 
					
						
							| 
									
										
										
										
											2013-09-05 20:54:32 +00:00
										 |  |  | MINLINE int mod_i(int i, int n); | 
					
						
							| 
									
										
										
										
											2013-04-25 14:16:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE signed char round_fl_to_char(float a); | 
					
						
							|  |  |  | MINLINE unsigned char round_fl_to_uchar(float a); | 
					
						
							|  |  |  | MINLINE short round_fl_to_short(float a); | 
					
						
							| 
									
										
										
										
											2017-09-27 11:13:03 +10:00
										 |  |  | MINLINE unsigned short round_fl_to_ushort(float a); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE int round_fl_to_int(float a); | 
					
						
							|  |  |  | MINLINE unsigned int round_fl_to_uint(float a); | 
					
						
							| 
									
										
										
										
											2017-09-27 11:13:03 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE signed char round_db_to_char(double a); | 
					
						
							|  |  |  | MINLINE unsigned char round_db_to_uchar(double a); | 
					
						
							|  |  |  | MINLINE short round_db_to_short(double a); | 
					
						
							| 
									
										
										
										
											2017-09-27 11:13:03 +10:00
										 |  |  | MINLINE unsigned short round_db_to_ushort(double a); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE int round_db_to_int(double a); | 
					
						
							|  |  |  | MINLINE unsigned int round_db_to_uint(double a); | 
					
						
							| 
									
										
										
										
											2017-09-27 11:13:03 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE signed char round_fl_to_char_clamp(float a); | 
					
						
							|  |  |  | MINLINE unsigned char round_fl_to_uchar_clamp(float a); | 
					
						
							|  |  |  | MINLINE short round_fl_to_short_clamp(float a); | 
					
						
							| 
									
										
										
										
											2017-09-18 21:03:10 +10:00
										 |  |  | MINLINE unsigned short round_fl_to_ushort_clamp(float a); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE int round_fl_to_int_clamp(float a); | 
					
						
							|  |  |  | MINLINE unsigned int round_fl_to_uint_clamp(float a); | 
					
						
							| 
									
										
										
										
											2017-09-18 21:03:10 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE signed char round_db_to_char_clamp(double a); | 
					
						
							|  |  |  | MINLINE unsigned char round_db_to_uchar_clamp(double a); | 
					
						
							|  |  |  | MINLINE short round_db_to_short_clamp(double a); | 
					
						
							| 
									
										
										
										
											2017-09-18 21:03:10 +10:00
										 |  |  | MINLINE unsigned short round_db_to_ushort_clamp(double a); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | MINLINE int round_db_to_int_clamp(double a); | 
					
						
							|  |  |  | MINLINE unsigned int round_db_to_uint_clamp(double a); | 
					
						
							| 
									
										
										
										
											2017-09-18 21:03:10 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-24 11:37:48 +10:00
										 |  |  | int pow_i(int base, int exp); | 
					
						
							| 
									
										
										
										
											2009-11-29 22:42:33 +00:00
										 |  |  | double double_round(double x, int ndigits); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-13 15:41:14 +00:00
										 |  |  | #ifdef BLI_MATH_GCC_WARN_PRAGMA
 | 
					
						
							| 
									
										
										
										
											2013-03-11 20:27:38 +00:00
										 |  |  | #  pragma GCC diagnostic pop
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-19 13:15:34 +00:00
										 |  |  | /* asserts, some math functions expect normalized inputs
 | 
					
						
							|  |  |  |  * check the vector is unit length, or zero length (which can't be helped in some cases). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-05-13 19:50:55 +02:00
										 |  |  | #ifndef NDEBUG
 | 
					
						
							| 
									
										
										
										
											2019-08-01 13:53:25 +10:00
										 |  |  | /** \note 0.0001 is too small because normals may be converted from short's: see T34322. */ | 
					
						
							| 
									
										
										
										
											2013-02-19 14:14:37 +00:00
										 |  |  | #  define BLI_ASSERT_UNIT_EPSILON 0.0002f
 | 
					
						
							| 
									
										
										
										
											2018-06-06 19:49:27 +02:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2019-04-22 00:54:27 +10:00
										 |  |  |  * \note Checks are flipped so NAN doesn't assert. | 
					
						
							|  |  |  |  * This is done because we're making sure the value was normalized and in the case we | 
					
						
							|  |  |  |  * don't want NAN to be raising asserts since there is nothing to be done in that case. | 
					
						
							| 
									
										
										
										
											2018-06-06 19:49:27 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define BLI_ASSERT_UNIT_V3(v) \
 | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |       const float _test_unit = len_squared_v3(v); \ | 
					
						
							|  |  |  |       BLI_assert(!(fabsf(_test_unit - 1.0f) >= BLI_ASSERT_UNIT_EPSILON) || \ | 
					
						
							|  |  |  |                  !(fabsf(_test_unit) >= BLI_ASSERT_UNIT_EPSILON)); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |     (void)0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #  define BLI_ASSERT_UNIT_V2(v) \
 | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |       const float _test_unit = len_squared_v2(v); \ | 
					
						
							|  |  |  |       BLI_assert(!(fabsf(_test_unit - 1.0f) >= BLI_ASSERT_UNIT_EPSILON) || \ | 
					
						
							|  |  |  |                  !(fabsf(_test_unit) >= BLI_ASSERT_UNIT_EPSILON)); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |     (void)0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #  define BLI_ASSERT_UNIT_QUAT(q) \
 | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |       const float _test_unit = dot_qtqt(q, q); \ | 
					
						
							|  |  |  |       BLI_assert(!(fabsf(_test_unit - 1.0f) >= BLI_ASSERT_UNIT_EPSILON * 10) || \ | 
					
						
							|  |  |  |                  !(fabsf(_test_unit) >= BLI_ASSERT_UNIT_EPSILON * 10)); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |     (void)0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #  define BLI_ASSERT_ZERO_M3(m) \
 | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |       BLI_assert(dot_vn_vn((const float *)m, (const float *)m, 9) != 0.0); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |     (void)0 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #  define BLI_ASSERT_ZERO_M4(m) \
 | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |       BLI_assert(dot_vn_vn((const float *)m, (const float *)m, 16) != 0.0); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |     (void)0 | 
					
						
							|  |  |  | #  define BLI_ASSERT_UNIT_M3(m) \
 | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |       BLI_ASSERT_UNIT_V3((m)[0]); \ | 
					
						
							|  |  |  |       BLI_ASSERT_UNIT_V3((m)[1]); \ | 
					
						
							|  |  |  |       BLI_ASSERT_UNIT_V3((m)[2]); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |     (void)0 | 
					
						
							| 
									
										
										
										
											2013-02-19 13:15:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2013-05-08 13:00:52 +00:00
										 |  |  | #  define BLI_ASSERT_UNIT_V2(v) (void)(v)
 | 
					
						
							|  |  |  | #  define BLI_ASSERT_UNIT_V3(v) (void)(v)
 | 
					
						
							| 
									
										
										
										
											2014-03-20 14:39:32 +11:00
										 |  |  | #  define BLI_ASSERT_UNIT_QUAT(v) (void)(v)
 | 
					
						
							| 
									
										
										
										
											2013-05-08 13:00:52 +00:00
										 |  |  | #  define BLI_ASSERT_ZERO_M3(m) (void)(m)
 | 
					
						
							|  |  |  | #  define BLI_ASSERT_ZERO_M4(m) (void)(m)
 | 
					
						
							| 
									
										
										
										
											2014-04-19 15:36:47 +10:00
										 |  |  | #  define BLI_ASSERT_UNIT_M3(m) (void)(m)
 | 
					
						
							| 
									
										
										
										
											2013-02-19 13:15:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-11-09 22:42:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-19 13:15:34 +00:00
										 |  |  | #endif /* __BLI_MATH_BASE_H__ */
 |