OpenMP* 機能を認識して、並列化機能が OpenMP* ディレクティブに基づいてマルチスレッド・コードを生成できるようにします。
Linux*: | -qopenmp -qno-openmp |
macOS*: | -qopenmp -qno-openmp |
Windows*: | /Qopenmp /Qopenmp- |
なし
-qno-openmp または /Qopenmp- |
コンパイラーは OpenMP* マルチスレッド・コードを生成しません。 |
このオプションは、OpenMP* 機能を認識して、並列化機能が OpenMP* ディレクティブに基づいてマルチスレッド・コードを生成できるようにします。このコードは、単一プロセッサー・システムとマルチプロセッサー・システムのいずれでも並列実行が可能です。
このオプションを使用すると、マルチスレッド・ライブラリーが使用されますが、fpp オプションは自動的には実行されません。
このオプションは automatic オプションを設定します。
このオプションは、任意の最適化レベルで動作します。最適化なし (-O0 (Linux*) または /Od (Windows*)) を指定すると、OpenMP* アプリケーションのデバッグに役立ちます。
確実にスレッドセーフ/再入可能なランタイム・ライブラリーがリンクされ、正しく初期化されるように、リンク段階およびメインルーチンのコンパイルで [q または Q]openmp オプションを使用すべきです。
オフロードする場合は、-fiopenmp オプションを指定します。このシンボルは ifx でのみ利用できます。
特定の GPU ターゲットへのオフロードを有効にするには、-fopenmp-targets (Linux*) または /Qopenmp-targets (Windows*) も指定する必要があります。このシンボルは ifx でのみ利用できます。
OpenMP* API を使用するオプションは、インテル製マイクロプロセッサーおよび互換マイクロプロセッサーの両方で利用可能ですが、両者では結果が異なります。両者の結果が異なる可能性のある OpenMP* 構造および機能の主なリストは次のとおりです: ロック (内部的なものおよびユーザーが利用可能なもの)、SINGLE 構造、バリア (暗黙的および明示的)、並列ループ・スケジュール、リダクション、メモリーの割り当て、スレッド・アフィニティー、バインド。
Visual Studio*: [Language] > [Process OpenMP Directives]
[Language] > [OpenMP Support] (ifx の /Qiopenmp)
Linux* および macOS*: -fopenmp (非推奨の古いオプション)、-fiopenmp (ifx のみ)
Windows*: /openmp (非推奨の古いオプション)、/Qiopenmp (ifx のみ)
製品および性能に関する情報 |
---|
性能は、使用状況、構成、その他の要因によって異なります。詳細については、http://www.intel.com/PerformanceIndex/ (英語) を参照してください。 注意事項の改訂 #20201201 |