data:image/s3,"s3://crabby-images/775cb/775cb25c45b41c1da7a4f97eb3c612f628d7c4ec" alt="license"
data:image/s3,"s3://crabby-images/c0131/c0131d82b93f3575539d410fbb46394bca3bec61" alt="MSVC Support"
data:image/s3,"s3://crabby-images/81cbd/81cbdd5325709379871d7c250db3a4df5704d6a1" alt="DOI"
Vc is an open source library to ease explicit vectorization of C++ code. It has an intuitive API and provides portability between different compilers and compiler versions as well as portability between different vector instruction sets.
Vc 1.4.0 is a minor feature release with subtle changes in the interface and the start of an upgrade path to std::experimental::simd
.
User Changelog
|
description |
data:image/s3,"s3://crabby-images/a438c/a438c01c66dcf032a7a2e215d6a23848ffd8ccd2" alt="API break" |
Dropped all Intel MIC code. This was not AVX512, but the old KNC implementation. ICC 18 dropped support for the -mmic compile flag. Consequently, I removed the maintenance burden. |
data:image/s3,"s3://crabby-images/a438c/a438c01c66dcf032a7a2e215d6a23848ffd8ccd2" alt="API break" |
Vc::simdize<T, N> (with arithmetic T and suitable N ) can now be an alias for Vc::Vector<T, Sse> , while AVX(2) is available. In Vc 1.3, this would use Vc::SimdArray<T, N> instead. |
data:image/s3,"s3://crabby-images/a438c/a438c01c66dcf032a7a2e215d6a23848ffd8ccd2" alt="API break" |
Fixed conversions from Vc::Vector<T> to Vc::SimdArray<U, Vc::Vector<T>::size()> to be implicit (as the documentation always said). |
data:image/s3,"s3://crabby-images/55e4f/55e4f289f9da2c9b7a86c65feb69a1c1b16dfaad" alt="API addition" |
Added Vc::simd<T, Abi> alias that resolves to the corresponding Vc::Vector or Vc::SimdArray type. Most importantly Vc::simd<T, Vc::simd_abi::fixed_size<N>> (alias: Vc::fixed_size_simd<T, N> ) will give you (almost) Vc::SimdArray<T, N> . Note that this simd type does not implement the exact same interface as defined in the Parallelism TS v2. Most SimdArray operations return fixed_size_simd now, thus potentially breaking existing code (e.g. by breaking template argument deduction). |
data:image/s3,"s3://crabby-images/55e4f/55e4f289f9da2c9b7a86c65feb69a1c1b16dfaad" alt="API addition" |
Added load_interleaved and store_interleaved to be used with Vc::simdize<T> objects. This enables optimized loads from / stores to an AoS (array of structure) layout into/from struct s of Vc vectors. This is currently only optimized for structures T where all data members have equal sizeof . |
data:image/s3,"s3://crabby-images/55e4f/55e4f289f9da2c9b7a86c65feb69a1c1b16dfaad" alt="API addition" |
Added a new constructor to simdized types: Vc::simdize<T>([](size_t n) { ... }) expects the lambda to return objects of type T , which will be placed at the corresponding index n in the resulting object. |
data:image/s3,"s3://crabby-images/55e4f/55e4f289f9da2c9b7a86c65feb69a1c1b16dfaad" alt="API addition" |
Vc::simd_for_each and Vc::simd_for_each_n will now vectorize any value_type via Vc::simdize . In Vc 1.3, only arithmetic types were vectorized, everything else used a fall-back to std::for_each . This fallback is removed in Vc 1.4. Consequently, the value_type must work with Vc::simdize . |
data:image/s3,"s3://crabby-images/03db2/03db28fafec656fa7764544f4ef28bc2f27cf14f" alt="bug fixed" |
The sin , cos , and sincos functions now have increased precision at the cost of lower performance (with AVX2, you still get a speedup of ~8 over std::sin and std::cos ). There's an option to use libmvec for Vc::sin and Vc::cos , which gives even higher performance for SSE4 and AVX2, but less performance for targets without SSE4 or just AVX. |
data:image/s3,"s3://crabby-images/55bca/55bcaced414708f774dca9b71bb782ae93d94251" alt="CMake feature" |
Modernize CMake to simplify usage of Vc in external projects via exported target. |
data:image/s3,"s3://crabby-images/03db2/03db28fafec656fa7764544f4ef28bc2f27cf14f" alt="bug fixed" |
Binary operators are now stricter in the implicit conversions they allow. E.g. simd<int>(0) == 0l is now ill-formed. Because it would require a silent (potentially) narrowing conversion of the right hand side. |