インテル® C++ コンパイラー XE 13.1 ユーザー・リファレンス・ガイド
インテルの valarray を使用すると、並列処理に大きな配列を宣言することができます。強化された valarray の実装は、インテル® インテグレーテッド・パフォーマンス・プリミティブ (インテル® IPP) の IPP ライブラリーを呼び出します。インテル® IPP は に含まれています。
valarray をソースコードで使用するには、valarray ヘッダーファイル <valarray> をインクルードします。 <valarray> ヘッダーファイルは <installdir>/perf_header のパスにあります。
次のコードは、インテルの valarray を使った valarray 加算 (+) の例を示しています。
#include <valarray>
void test( )
{
std::valarray<float> vi(N), va(N);
…
vi = vi + va; //array addition
…
}
すべてのプロセッサー固有のライブラリー・コードを含むスタティック・マージ・ライブラリーを使用するには、インテル® IPP 呼び出しの前に、ippStaticInit 関数を呼び出す必要があります。 これにより、ランタイム時にインテル® プロセッサーでは正しいバージョンのライブラリー・コードへ、互換プロセッサーでは汎用バージョンのライブラリー・コードへ自動的にディスパッチされます。最初に ippStaticInit を呼び出さないと、ライブラリーは標準のライブラリー・コードを使用します。 ダイナミック・ライブラリーを使用する場合、ippStaticInit を呼び出す必要はありません。
valarray を含むソースコードをコンパイルする場合、コンパイラー・オプション /Quse-intel-optimized-headers (Windows*) または -use-intel-optimized-headers (Linux* および OS X*) を使用して、必要な valarray ヘッダーファイルと必要なすべて IPP ライブラリー・ファイルをインクルードします。
次の 2 つの例は、インテルの valarray 代替ヘッダーファイルをインクルードし、インテル® IPP とリンクするための、プログラムのコンパイルとリンク方法を示します。詳細は、インテル® IPP のドキュメントを参照してください。
次の例の "マージ" ライブラリーでは、すべてのプロセッサー固有のライブラリー・コードを含むスタティック・ライブラリーを使用しています。
次のコマンドラインは、インテル® 64 アーキテクチャー・ベースの Linux* システムで、1 回のコンパイルを実行します。
icpc -use-intel-optimized-headers source.cpp
次のコマンドラインは、インテル® 64 アーキテクチャー・ベースの Linux* システムで、コンパイルとリンクを別々に実行します。
so (ダイナミック):
icpc -use-intel-optimized-headers -c source.cpp
icpc source.o -use-intel-optimized-headers
マージ (スタティック):
icpc -use-intel-optimized-headers -c source.cpp
icpc source.o -use-intel-optimized-headers
インテル® コンパイラーは、互換マイクロプロセッサー向けには、インテル製マイクロプロセッサー向けと同等レベルの最適化が行われない可能性があります。これには、インテル® ストリーミング SIMD 拡張命令 2 (インテル® SSE2)、インテル® ストリーミング SIMD 拡張命令 3 (インテル® SSE3)、ストリーミング SIMD 拡張命令 3 補足命令 (SSSE3) 命令セットに関連する最適化およびその他の最適化が含まれます。インテルでは、インテル製ではないマイクロプロセッサーに対して、最適化の提供、機能、効果を保証していません。本製品のマイクロプロセッサー固有の最適化は、インテル製マイクロプロセッサーでの使用を目的としています。インテル® マイクロアーキテクチャーに非固有の特定の最適化は、インテル製マイクロプロセッサー向けに予約されています。この注意事項の適用対象である特定の命令セットの詳細は、該当する製品のユーザー・リファレンス・ガイドを参照してください。 改訂 #20110804 |