インテル® C++ コンパイラー XE 13.1 ユーザー・リファレンス・ガイド
自動パラレライザーを有効にするには、-parallel (Linux* および OS X*) または /Qparallel (Windows*) オプションを使用します。このオプションは、安全に並列実行できる並列ループを検出して、これらのループのマルチスレッド・コードを自動的に生成します。
このオプションを使用して、並列化を有効にするには、KMP_STACKSIZE 環境変数に十分なサイズを設定する必要があります。-parallel (Linux*) オプションまたは /Qparallel (Windows*) オプションを使用すると、インテル製マイクロプロセッサーおよび互換マイクロプロセッサーにおいて並列化が有効になります。実行ファイルでは、互換マイクロプロセッサーよりもインテル製マイクロプロセッサーにおいてより優れたパフォーマンスが得られる可能性があります。また、並列化は、/arch や /Qx (Windows*) または -m や -x (Linux* および OS X*) などの特定のオプションによる影響を受けます。
自動並列化を使用するコマンド例は、次のとおりです。
自動並列化では、2 つの特定のプラグマ #pragma parallel と #pragma noparallel が使用されます。
自動並列化コンパイラープラグマは次のとおりです。
#pragma
<prefix> の後には、プラグマがきます。次に例を示します。
#pragma parallel プラグマ は、すぐ後のループで存在していると想定され、正常な自動並列化を妨げる依存を無視するようにコンパイラーに指示します。しかし、依存性が証明されると無視されません。さらに、parallel [always] は、ループの並列化がパフォーマンスを向上させる可能性を推定するコンパイラー・ヒューリスティックを無効にします。 これにより、コンパイラーによって、並列化がパフォーマンスを向上しないと推定された場合でも、ループが並列化されます。 #pragma parallel [always [assert]] など、ASSERT キーワードが追加されると、コンパイラーは、コンパイラーの解析とコストモデルはループが並列化できないことを示している旨のエラーレベルのアサーション・メッセージを生成します。
#pragma noparallel プラグマは自動並列化を無効にします。