インテル® マス・カーネル・ライブラリー (インテル® MKL) には、インテル® メニー・インテグレーテッド・コア (インテル® MIC) アーキテクチャーをサポートする 2 セットのライブラリーが用意されています。
インテル® MKL がインテル® Xeon Phi™ コプロセッサーに計算をオフロードする方法を制御することができます。オフロード計算を自動的に行うか、コンパイラーによるオフロード支援を使用します。
インテル® 64 (または互換) アーキテクチャー・システムで Linux* OS を実行している場合、インテル® MIC アーキテクチャー・ベースのコプロセッサーの存在を自動的に検出して、別途計算リソースを利用するメリットがあるオフロード計算を自動的に行います。このモデルは、プログラムに最小限の変更を加えるだけで、インテル® MKL ルーチンを呼び出すことができます。自動オフロードを有効にするための変更は、環境変数を設定するか、あるいは関数を 1 つ呼び出すだけです。詳細は、「自動オフロード」を参照してください。
このモデルは、インテル® コンパイラーと offload プラグマを利用して、コプロセッサーにオフロードされる関数とデータを管理します。オフロード領域内では、オフロードされるインテル® MKL 関数の入力データと出力データの両方を指定します。インテル® MIC アーキテクチャー・コプロセッサー用のインテル® MKL ライブラリーをリンクした後、コンパイラーが提供するランライム・ライブラリーにより、関数とデータをコプロセッサーに転送して、計算を実行します。詳細は、「コンパイラーによるオフロード支援」 を参照してください。
コプロセッサーへの計算のオフロードに加えて、コプロセッサー上でネイティブに実行するアプリケーションからインテル® MKL 関数を呼び出すことができます。アプリケーション全体をインテル® MIC アーキテクチャー上で実行している状態をネイティブモードと呼びます。ネイティブモードは、ソースコードに最小限の変更を加えるだけで、インテル® MIC アーキテクチャー上で既存のアプリケーションを実行する最も速い方法です。詳細は、「インテル® Xeon Phi™ コプロセッサー上でネイティブモードでインテル® MKL を実行する」を参照してください。
インテル® MKL のインテル® MIC アーキテクチャーに対するサポートレベルは、以下のように異なります。
最適化 - 次のコンポーネントは、インテル® MIC アーキテクチャー用にチューニングされています。
詳細は、『リリースノート』を参照してください。
未サポート - ポアソン・ライブラリー、反復法スパースソルバー、Trust-Region ソルバー
サポート - ほかのすべての機能は、インテル® Xeon Phi™ コプロセッサーで動作します。
| インテル® コンパイラーは、互換マイクロプロセッサー向けには、インテル製マイクロプロセッサー向けと同等レベルの最適化が行われない可能性があります。これには、インテル® ストリーミング SIMD 拡張命令 2 (インテル® SSE2)、インテル® ストリーミング SIMD 拡張命令 3 (インテル® SSE3)、ストリーミング SIMD 拡張命令 3 補足命令 (SSSE3) 命令セットに関連する最適化およびその他の最適化が含まれます。インテルでは、インテル製ではないマイクロプロセッサーに対して、最適化の提供、機能、効果を保証していません。本製品のマイクロプロセッサー固有の最適化は、インテル製マイクロプロセッサーでの使用を目的としています。インテル® マイクロアーキテクチャーに非固有の特定の最適化は、インテル製マイクロプロセッサー向けに予約されています。この注意事項の適用対象である特定の命令セットの詳細は、該当する製品のユーザー・リファレンス・ガイドを参照してください。
改訂 #20110804 |