| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2006 The Android Open Source Project | 3 * Copyright 2006 The Android Open Source Project |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 | 8 |
| 9 | 9 |
| 10 #ifndef SkFloatingPoint_DEFINED | 10 #ifndef SkFloatingPoint_DEFINED |
| 11 #define SkFloatingPoint_DEFINED | 11 #define SkFloatingPoint_DEFINED |
| 12 | 12 |
| 13 #include "SkTypes.h" | 13 #include "SkTypes.h" |
| 14 | 14 |
| 15 #include <math.h> | 15 #include <math.h> |
| 16 #include <float.h> | 16 #include <float.h> |
| 17 |
| 18 // For _POSIX_VERSION |
| 19 #if defined(__unix__) || (defined(__APPLE__) && defined(__MACH__)) |
| 20 #include <unistd.h> |
| 21 #endif |
| 22 |
| 17 #include "SkFloatBits.h" | 23 #include "SkFloatBits.h" |
| 18 | 24 |
| 19 // C++98 cmath std::pow seems to be the earliest portable way to get float pow. | 25 // C++98 cmath std::pow seems to be the earliest portable way to get float pow. |
| 20 // However, on Linux including cmath undefines isfinite. | 26 // However, on Linux including cmath undefines isfinite. |
| 21 // http://gcc.gnu.org/bugzilla/show_bug.cgi?id=14608 | 27 // http://gcc.gnu.org/bugzilla/show_bug.cgi?id=14608 |
| 22 static inline float sk_float_pow(float base, float exp) { | 28 static inline float sk_float_pow(float base, float exp) { |
| 23 return powf(base, exp); | 29 return powf(base, exp); |
| 24 } | 30 } |
| 25 | 31 |
| 26 static inline float sk_float_copysign(float x, float y) { | 32 static inline float sk_float_copysign(float x, float y) { |
| 33 // c++11 contains a 'float copysign(float, float)' function in <cmath>. |
| 34 #if __cplusplus >= 201103L || (defined(_MSC_VER) && _MSC_VER >= 1800) |
| 35 return copysign(x, y); |
| 36 |
| 37 // Posix has demanded 'float copysignf(float, float)' (from C99) since Issue 6. |
| 38 #elif defined(_POSIX_VERSION) && _POSIX_VERSION >= 200112L |
| 39 return copysignf(x, y); |
| 40 |
| 41 // Visual studio prior to 13 only has 'double _copysign(double, double)'. |
| 42 #elif defined(_MSC_VER) |
| 43 return _copysign(x, y); |
| 44 |
| 45 // Otherwise convert to bits and extract sign. |
| 46 #else |
| 27 int32_t xbits = SkFloat2Bits(x); | 47 int32_t xbits = SkFloat2Bits(x); |
| 28 int32_t ybits = SkFloat2Bits(y); | 48 int32_t ybits = SkFloat2Bits(y); |
| 29 return SkBits2Float((xbits & 0x7FFFFFFF) | (ybits & 0x80000000)); | 49 return SkBits2Float((xbits & 0x7FFFFFFF) | (ybits & 0x80000000)); |
| 50 #endif |
| 30 } | 51 } |
| 31 | 52 |
| 32 #ifdef SK_BUILD_FOR_WINCE | 53 #ifdef SK_BUILD_FOR_WINCE |
| 33 #define sk_float_sqrt(x) (float)::sqrt(x) | 54 #define sk_float_sqrt(x) (float)::sqrt(x) |
| 34 #define sk_float_sin(x) (float)::sin(x) | 55 #define sk_float_sin(x) (float)::sin(x) |
| 35 #define sk_float_cos(x) (float)::cos(x) | 56 #define sk_float_cos(x) (float)::cos(x) |
| 36 #define sk_float_tan(x) (float)::tan(x) | 57 #define sk_float_tan(x) (float)::tan(x) |
| 37 #define sk_float_acos(x) (float)::acos(x) | 58 #define sk_float_acos(x) (float)::acos(x) |
| 38 #define sk_float_asin(x) (float)::asin(x) | 59 #define sk_float_asin(x) (float)::asin(x) |
| 39 #define sk_float_atan2(y,x) (float)::atan2(y,x) | 60 #define sk_float_atan2(y,x) (float)::atan2(y,x) |
| (...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 131 float estimate = *SkTCast<float*>(&i); | 152 float estimate = *SkTCast<float*>(&i); |
| 132 | 153 |
| 133 // One step of Newton's method to refine. | 154 // One step of Newton's method to refine. |
| 134 const float estimate_sq = estimate*estimate; | 155 const float estimate_sq = estimate*estimate; |
| 135 estimate *= (1.5f-0.5f*x*estimate_sq); | 156 estimate *= (1.5f-0.5f*x*estimate_sq); |
| 136 return estimate; | 157 return estimate; |
| 137 #endif | 158 #endif |
| 138 } | 159 } |
| 139 | 160 |
| 140 #endif | 161 #endif |
| OLD | NEW |