std::experimental::rebind_simd, std::experimental::resize_simd

出自cppreference.com
 
 
實驗性
技術規範
文件系統庫 (文件系統 TS)
庫基礎 (庫基礎 TS)
庫基礎 2 (庫基礎 TS v2)
庫基礎 3 (庫基礎 TS v3)
並行擴展 (並行 TS)
並行擴展 2 (並行 TS v2)
並發擴展 (並發 TS)
並發擴展 2 (並發 TS v2)
概念 (概念 TS)
範圍 (範圍 TS)
反射 (反射 TS)
數學特殊函數 (特殊函數 TR)
實驗性非 TS 功能特性
模式匹配
線性代數
std::execution
契約
2D 圖形
 
 
 
在標頭 <experimental/simd> 定義
template< class T, class V >
struct rebind_simd;
(1) (並行 TS v2)
template< int N, class V >
struct resize_simd;
(2) (並行 TS v2)

創建擁有不同元素類型或大小的 simdsimd_mask 類型。新類型可能使用異於 V::abi_type 的 ABI 標籤類型。

1) 更改元素類型為 T 並保持大小不變。
2) 更改大小為 N 並保持元素類型不變。

模板形參

T - 新元素類型;bool 以外的算術類型
N - 新的元素數
V - simdsimd_mask 類型

成員類型

名稱 定義
type 擁有不同元素類型 (1) 或大小 (2)simdsimd_mask 類型

輔助類型

template< class T, class V >
using rebind_simd_t = typename rebind_simd<T, V>::type;
(並行 TS v2)
template< int N, class V >
using resize_simd_t = typename resize_simd<N, V>::type;
(並行 TS v2)

示例

#include <experimental/simd>
#include <iostream>

namespace stdx = std::experimental;
using floatv = stdx::native_simd<float>;
 
// 内部使用双精度
floatv dp(floatv x)
{
    using doublev = stdx::rebind_simd_t<double, floatv>;
    return stdx::static_simd_cast<floatv>(stdx::simd_cast<doublev>(x) - 1.234);
}
 
template<class T>
stdx::resize_simd_t<T::size() / 2, T> partial_reduction(T x)
{
    auto [lo, hi] = stdx::split<stdx::resize_simd_t<T::size() / 2, T>>(x);
    return lo + hi;
}
 
int main() 
{
    floatv x([](auto i) { return 1.234f + std::numeric_limits<float>::epsilon() * i; });
    x = dp(x);
    const auto y = partial_reduction(x);
    for (unsigned i = 0; i < y.size(); ++i)
        std::cout << y[i] << ' ';
    std::cout << '\n';
}

可能的輸出:

1.73569e-07 4.11987e-07

參閱

(並行 TS v2)
獲得給定的元素類型及元素數的 ABI 類型
(類模板) [編輯]