インテル® C++ コンパイラー 18.0 デベロッパー・ガイドおよびリファレンス
例 3 は、前方依存性を扱う配列構造体 (SoA) を宣言します。
#include <stdio.h>
#include <sdlt/primitive.h>
#include <sdlt/soa1d_container.h>
#define N 1024
typedef struct RGBs {
float r;
float g;
float b;
} RGBTy;
SDLT_PRIMITIVE(RGBTy, r, g, b)
void main()
{
// RGBTy a[N]; // AOS データレイアウト
sdlt::soa1d_container<RGBTy> aContainer(N);
auto a = aContainer.access(); // SOA データレイアウト
// SDLT のアクセスメソッドを利用して構造体メンバー r、g、b にアクセス
// ベクトル化の後にユニット・ストライド・アクセス
#pragma omp simd
for (int k = 0; k<N; k++) {
a[k].r() = k*1.5;
a[k].g() = k*2.5;
a[k].b() = k*3.5;
}
// SOA メモリーアクセスの前方依存性をチェック
#pragma omp simd
for (int i = 0; i<N - 1; i++) {
sdlt::linear_index k(i);
a[k].r() = a[k + 1].r() + k*1.5;
a[k].g() = a[k + 1].g() + k*2.5;
a[k].b() = a[k + 1].b() + k*3.5;
}
std::cout << "k =" << 10 <<
", a[k].r =" << a[10].r() <<
", a[k].g =" << a[10].g() <<
", a[k].b =" << a[10].b() << std::endl;
}