OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #ifndef SkNx_DEFINED | 8 #ifndef SkNx_DEFINED |
9 #define SkNx_DEFINED | 9 #define SkNx_DEFINED |
10 | 10 |
(...skipping 248 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
259 static double Sqrt(double val) { return ::sqrt ( val); } | 259 static double Sqrt(double val) { return ::sqrt ( val); } |
260 | 260 |
261 I pun() const { | 261 I pun() const { |
262 union { T f; I i; } pun = { fVal }; | 262 union { T f; I i; } pun = { fVal }; |
263 return pun.i; | 263 return pun.i; |
264 } | 264 } |
265 | 265 |
266 T fVal; | 266 T fVal; |
267 }; | 267 }; |
268 | 268 |
269 // This default implementation can be specialized by ../opts/SkNx_foo.h | |
270 // if there's a better platform-specific shuffle strategy. | |
271 template <typename SkNx, int... Ix> | |
272 inline SkNx SkNx_shuffle_impl(const SkNx& src) { return SkNx( src.template kth<I x>()... ); } | |
273 | |
274 // This generic shuffle can be called on either SkNi or SkNf with either 1 or N indices: | |
275 // Sk4f(1,2,3,4) f; | |
reed1
2015/09/01 15:45:03
do you mean Sk4f f(1,2,3,4); ?
Actually, I think
mtklein_C
2015/09/01 16:00:03
Yep, done.
| |
276 // SkNx_shuffle<0>(f); // ~~~> Sk4f(1,1,1,1) | |
277 // SkNx_shuffle<2,1,0,3>(f); // ~~~> Sk4f(3,2,1,4) | |
278 template <int... Ix, typename SkNx> | |
279 inline SkNx SkNx_shuffle(const SkNx& src) { return SkNx_shuffle_impl<SkNx, Ix... >(src); } | |
280 | |
269 } // namespace | 281 } // namespace |
270 | 282 |
283 | |
284 | |
285 | |
271 // Include platform specific specializations if available. | 286 // Include platform specific specializations if available. |
272 #ifndef SKNX_NO_SIMD | 287 #ifndef SKNX_NO_SIMD |
273 #if SK_CPU_SSE_LEVEL >= SK_CPU_SSE_LEVEL_SSE2 | 288 #if SK_CPU_SSE_LEVEL >= SK_CPU_SSE_LEVEL_SSE2 |
274 #include "../opts/SkNx_sse.h" | 289 #include "../opts/SkNx_sse.h" |
275 #elif defined(SK_ARM_HAS_NEON) | 290 #elif defined(SK_ARM_HAS_NEON) |
276 #include "../opts/SkNx_neon.h" | 291 #include "../opts/SkNx_neon.h" |
277 #endif | 292 #endif |
278 #endif | 293 #endif |
279 | 294 |
280 #undef REQUIRE | 295 #undef REQUIRE |
281 | 296 |
282 typedef SkNf<2, float> Sk2f; | 297 typedef SkNf<2, float> Sk2f; |
283 typedef SkNf<2, double> Sk2d; | 298 typedef SkNf<2, double> Sk2d; |
284 typedef SkNf<2, SkScalar> Sk2s; | 299 typedef SkNf<2, SkScalar> Sk2s; |
285 | 300 |
286 typedef SkNf<4, float> Sk4f; | 301 typedef SkNf<4, float> Sk4f; |
287 typedef SkNf<4, double> Sk4d; | 302 typedef SkNf<4, double> Sk4d; |
288 typedef SkNf<4, SkScalar> Sk4s; | 303 typedef SkNf<4, SkScalar> Sk4s; |
289 | 304 |
290 typedef SkNi<4, uint16_t> Sk4h; | 305 typedef SkNi<4, uint16_t> Sk4h; |
291 typedef SkNi<8, uint16_t> Sk8h; | 306 typedef SkNi<8, uint16_t> Sk8h; |
292 typedef SkNi<16, uint16_t> Sk16h; | 307 typedef SkNi<16, uint16_t> Sk16h; |
293 | 308 |
294 typedef SkNi<16, uint8_t> Sk16b; | 309 typedef SkNi<16, uint8_t> Sk16b; |
295 | 310 |
296 typedef SkNi<4, int32_t> Sk4i; | 311 typedef SkNi<4, int32_t> Sk4i; |
297 typedef SkNi<4, uint32_t> Sk4u; | 312 typedef SkNi<4, uint32_t> Sk4u; |
298 | 313 |
299 #endif//SkNx_DEFINED | 314 #endif//SkNx_DEFINED |
OLD | NEW |