インテル® C++ コンパイラー 18.0 デベロッパー・ガイドおよびリファレンス

インテルの valarray の使用

インテルの valarray を使用すると、並列処理に大きな配列を宣言することができます。強化された valarray の実装は、インテル® インテグレーテッド・パフォーマンス・プリミティブ (インテル® IPP) の IPP ライブラリーを呼び出します。

ソースコードでの valarray の使用

valarray をソースコードで使用するには、valarray ヘッダーファイル <valarray> をインクルードします。<valarray> ヘッダーファイルは <installdir>/perf_header のパスにあります。

次のコードは、インテルの valarray を使った valarray 加算 (+) の例を示しています。

#include <valarray>
void test( )
{
	std::valarray<float> vi(N), va(N);
	…
	vi = vi + va;  // 配列の加算
	…
}

すべてのプロセッサー固有のライブラリー・コードを含むスタティック・マージ・ライブラリーを使用するには、インテル® IPP 呼び出しの前に、ippStaticInit 関数を呼び出す必要があります。これにより、ランタイム時にインテル® プロセッサーでは正しいバージョンのライブラリー・コードへ、互換プロセッサーでは汎用バージョンのライブラリー・コードへ自動的にディスパッチされます。最初に ippStaticInit を呼び出さないと、マージ・ライブラリーは標準のライブラリー・コードを使用します。ダイナミック・ライブラリーを使用する場合、ippStaticInit を呼び出す必要はありません。

valarray ソースコードのコンパイル

valarray を含むソースコードをコンパイルする場合、コンパイラー・オプション /Quse-intel-optimized-headers (Windows*) または -use-intel-optimized-headers (Linux* および macOS*) を使用して、必要な valarray ヘッダーファイルと必要なすべて IPP ライブラリー・ファイルをインクルードします。

次の例は、インテルの valarray 代替ヘッダーファイルをインクルードし、インテル® IPP とリンクするための、プログラムのコンパイルとリンク方法を示します。詳細は、インテル® IPP のドキュメントを参照してください。

次の例の "マージ" ライブラリーでは、すべてのプロセッサー固有のライブラリー・コードを含むスタティック・ライブラリーを使用しています。

Windows* の例

次のコマンドラインは、IA-32 アーキテクチャー・ベースの Windows* システムで、1 回のコンパイルを実行します。

icl /Quse-intel-optimized-headers source.cpp

次のコマンドラインは、IA-32 アーキテクチャー・ベースの Windows* システムで、コンパイルとリンクを別々に実行します。

DLL (ダイナミック):

icl /Quse-intel-optimized-headers /c source.cpp
icl source.obj /Quse-intel-optimized-headers

マージ (スタティック):

icl /Quse-intel-optimized-headers /Qipp-link:static /c source.cpp
icl source.obj /Quse-intel-optimized-headers /Qipp-link:static 

Linux* の例

次のコマンドラインは、インテル® 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 -shared-intel

マージ (スタティック):

icpc -use-intel-optimized-headers -c source.cpp
icpc source.o -use-intel-optimized-headers

最適化に関する注意事項

インテル® コンパイラーでは、インテル® マイクロプロセッサーに限定されない最適化に関して、他社製マイクロプロセッサー用に同等の最適化を行えないことがあります。これには、インテル® ストリーミング SIMD 拡張命令 2、インテル® ストリーミング SIMD 拡張命令 3、インテル® ストリーミング SIMD 拡張命令 3 補足命令などの最適化が該当します。インテルは、他社製マイクロプロセッサーに関して、いかなる最適化の利用、機能、または効果も保証いたしません。本製品のマイクロプロセッサー依存の最適化は、インテル® マイクロプロセッサーでの使用を前提としています。インテル® マイクロアーキテクチャーに限定されない最適化のなかにも、インテル® マイクロプロセッサー用のものがあります。 この注意事項で言及した命令セットの詳細については、該当する製品のユーザー・リファレンス・ガイドを参照してください。

注意事項の改訂 #20110804