IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ 日本電信電話株式会社の特許一覧

特開2024-63183オフロードサーバ、および、オフロード制御方法
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2024063183
(43)【公開日】2024-05-10
(54)【発明の名称】オフロードサーバ、および、オフロード制御方法
(51)【国際特許分類】
   G06F 8/41 20180101AFI20240501BHJP
   G06F 8/60 20180101ALI20240501BHJP
   G06F 8/77 20180101ALI20240501BHJP
【FI】
G06F8/41 130
G06F8/60
G06F8/77
【審査請求】有
【請求項の数】4
【出願形態】OL
(21)【出願番号】P 2024033327
(22)【出願日】2024-03-05
(62)【分割の表示】P 2022557221の分割
【原出願日】2020-10-12
【公序良俗違反の表示】
(特許庁注:以下のものは登録商標)
1.MySQL
(71)【出願人】
【識別番号】000004226
【氏名又は名称】日本電信電話株式会社
(74)【代理人】
【識別番号】110001807
【氏名又は名称】弁理士法人磯野国際特許商標事務所
(72)【発明者】
【氏名】山登 庸次
(57)【要約】
【課題】複数種類のアクセラレータが混在する環境が移行先であっても、自動で高性能化すること。
【解決手段】オフロードサーバ1は、ソフトウェアプログラムのソースコードが、GPUまたはメニーコアCPUによる実行が可能なループ文を含むか否かを分析するコード分析部と、前記ループ文を前記GPUまたは前記メニーコアCPUにオフロードするパターンを作成する処理パターン作成部と、各前記ループ文を遺伝子パターンにマッピングし、各前記ループ文をオフロードする各前記パターンを検証環境にデプロイして性能を測定する性能測定部と、処理時間が短いパターンほど高い適合度に設定して、遺伝的アルゴリズムのエリート選択によりパターンを選択し、交叉,突然変異の処理により次世代のパターンを作成することを繰り返す実行ファイル作成部とを備える。
【選択図】図7
【特許請求の範囲】
【請求項1】
ソフトウェアプログラムのソースコードが、GPU、FPGAまたはメニーコアCPUによる実行が可能なループ文を含むか否かを分析するコード分析部と、
前記ループ文を前記GPU、前記FPGA、および前記メニーコアCPUのうち何れかにオフロードするパターンを作成する処理パターン作成部と、
各前記ループ文を遺伝子パターンにマッピングし、各前記ループ文をオフロードする各前記パターンを検証環境にデプロイして性能を測定する性能測定部と、
処理時間が短いパターンほど高い適合度に設定して、遺伝的アルゴリズムのエリート選択によりパターンを選択し、交叉,突然変異の処理により次世代のパターンを作成することを繰り返す実行ファイル作成部と、
を備え、
前記性能測定部は、前記検証環境での性能の測定において、前記GPU、前記FPGAおよび前記メニーコアCPUのうち何れかが処理した場合の計算結果と、元の処理の計算結果を比較し、前記GPU、前記FPGA、および前記メニーコアCPUのうち何れかが処理した場合の計算結果の誤差が許容閾値を超える場合、遺伝子パターンの適合度を低く設定する、
ことを特徴とするオフロードサーバ。
【請求項2】
前記実行ファイル作成部は、遺伝的アルゴリズムのエリート選択において、遺伝子パターンの適合度に応じたルーレット選択を行う、
ことを特徴とする請求項1に記載のオフロードサーバ。
【請求項3】
前記実行ファイル作成部は、指定世代数の処理終了後、最高性能のパターンを解として選択する、
ことを特徴とする請求項1に記載のオフロードサーバ。
【請求項4】
コード分析部が、ソフトウェアプログラムのソースコードがGPU、FPGAまたはメニーコアCPUによる実行が可能なループ文を含むか否かを分析するステップと、
処理パターン作成部が、前記ループ文を前記GPU、前記FPGA、および前記メニーコアCPUのうち何れかにオフロードするパターンを作成するステップと、
性能測定部が、各前記ループ文を遺伝子パターンにマッピングし、各前記ループ文をオフロードする各前記パターンを検証環境にデプロイして性能を測定するステップと、
実行ファイル作成部が、処理時間が短いパターンほど高い適合度に設定して、遺伝的アルゴリズムのエリート選択によりパターンを選択し、交叉,突然変異の処理により次世代のパターンを作成することを繰り返すステップと、を実行し、
前記性能測定部は更に、前記検証環境での性能の測定において、前記GPU、前記FPGAおよび前記メニーコアCPUのうち何れかが処理した場合の計算結果と、元の処理の計算結果を比較し、前記GPU、前記FPGA、および前記メニーコアCPUのうち何れかが処理した場合の計算結果の誤差が許容閾値を超える場合、遺伝子パターンの適合度を低く設定するステップを実行する、
ことを特徴とするオフロード制御方法。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、通常のCPU(Central Processing Unit)で処理するソフトウェア処理プログラムを、GPU(Graphics Processing Unit)、FPGA(Field Programmable Gate Array)、メニーコアCPU等のアクセラレータが混在する環境で高速に処理するようにオフロードするオフロードサーバ、および、オフロード制御方法に関する。
【背景技術】
【0002】
近年、CPUの半導体集積度が1.5年で2倍になるというムーアの法則が減速するのではないかと言われている。そのような状況から、少コアのCPUだけでなく、FPGAやGPU等のデバイスの活用が増えている。例えば、マイクロソフト社はFPGAを使って検索エンジンの効率を高める取り組みをしている。アマゾン社は、FPGAやGPU等をクラウドのインスタンスとして提供している。
【0003】
しかし、少コアの通常のCPU以外のデバイスをシステムで適切に活用するためには、デバイス特性を意識した設定やプログラム作成が必要である。つまり、OpenMP(登録商標)(Open Multi-Processing)、OpenCL(登録商標)(Open Computing Language)、CUDA(登録商標)(Compute Unified Device Architecture)といった知識が必要になってくるため、大半のプログラマにとっては、スキルの壁が高い。なお、OpenMP(登録商標)、OpenCL(登録商標)、CUDA(登録商標)につき、これ以降は(登録商標)の記載を省略する。
【0004】
少コアのCPU以外のGPUやFPGA、メニーコアCPU等のアクセラレータを活用するシステムは今後ますます増えていくと予想されるが、それらを最大限活用するには、プログラマにとっての技術的な壁が高い。そこで、そのような壁を取り払い、少コアのCPU以外のアクセラレータを十分に利用できるようにするため、プログラマが処理ロジックを記述したソフトウェアを、配置先の環境(FPGA、GPU、メニーコアCPU等)にあわせて、適応的に変換して設定し、環境に適合した動作をさせるプラットフォームが求められている。
【0005】
そこで発明者は、一度記述したコードを、配置先の環境に存在するGPUやFPGA、メニーコアCPU等が利用できるように、変換、リソース設定等を自動で行い、アプリケーションを高性能に動作させることを目的とした環境適応ソフトウェアを非特許文献1に提案した。
発明者は、環境適応ソフトウェアの要素として、ソースコードのループ文及び機能ブロックを、FPGA、GPUに自動オフロードする方式を非特許文献2,3,4にて提案している。
【先行技術文献】
【非特許文献】
【0006】
【非特許文献1】Y. Yamato, H. Noguchi, M. Kataoka and T. Isoda, “Proposal of Environment Adaptive Software,” The 2nd International Conference on Control and Computer Vision (ICCCV 2019), pp.102-108, Jeju, June 2019.
【非特許文献2】Y. Yamato, “Study of parallel processing area extraction and data transfer number reduction for automatic GPU offloading of IoT applications,” Journal of Intelligent Information Systems, Springer, DOI: 10.1007/s10844-019-00575-8, Aug. 2019.
【非特許文献3】Y. Yamato, “Proposal of Automatic FPGA Offloading for Applications Loop Statements,” The 7th Annual Conference on Engineering and Information Technology (ACEAIT 2020), pp.111-123, 2020.
【非特許文献4】Y. Yamato, “Proposal of Automatic Offloading for Function Blocks of Applications,” The 8th IIAE International Conference on Industrial Application Engineering 2020 (ICIAE 2020), pp.4-11, Mar. 2020.
【発明の概要】
【発明が解決しようとする課題】
【0007】
近年、GPUの並列計算パワーを画像処理でないものにも使うGPGPU(General Purpose GPU)を行うための環境としてCUDAが普及している。CUDAは、NVIDIA社が開発したGPGPU向け環境である。
【0008】
更にFPGA、メニーコアCPU、GPU等のヘテロなデバイスを同じように扱うための仕様としてOpenCLが出ており、その開発環境も出てきている。CUDA、OpenCLは、FPGA等のカーネルとCPUのホストとの間のメモリデータのコピーや解放の記述を明示的に行う等、C言語の拡張によりプログラムを行うものであり、プログラムの難度は高い。
【0009】
CUDAやOpenCLに比べて、より簡易にヘテロなデバイスを利用するため、指示行で並列処理等を行う箇所を指定し、指示行に従ってコンパイラが、GPU、メニーコアCPU等に向けて実行ファイルを作成する技術がある。仕様としては、OpenACC(登録商標)(OpenACCelerators)やOpenMP等、コンパイラとしてPGIコンパイラやgcc等がある。なお、OpenACC(登録商標)につき、これ以降は(登録商標)の記載を省略する。
【0010】
CUDA、OpenCL、OpenACC、OpenMP等の技術仕様を用いることで、FPGAやGPUやメニーコアCPUへオフロードすることは可能である。しかしアクセラレータ処理自体は行えるようになっても、高速化することには課題がある。
【0011】
例えば、マルチコアCPU向けに自動並列化機能を持つコンパイラとして、Intelコンパイラ等がある。これらは、自動並列化時に、コードの中のループ文中で並列処理可能な部分を抽出して、並列化している。しかし、メモリ処理等の影響で、単に並列化可能ループ文を並列化しても性能が出ないことも多い。なお、ここでループ文とは、C/C++ソースコードにおいてはfor/while/do-whileである。
【0012】
具体的にいうと、FPGAやGPU等で高速化する際、OpenCLやCUDAの技術者は、チューニングを繰り返したり、OpenACCコンパイラ等を用いて適切な並列処理範囲を探索して試行している。このため、技術スキルが乏しいプログラマが、FPGAやGPU、メニーコアCPUを活用してアプリケーションを高速化することは難しい。また、自動並列化技術等を使う場合、並列処理箇所探索の試行錯誤等の稼働が必要であった。
【0013】
現状、ヘテロなデバイスに対するオフロードは手作業での取組みが主流である。発明者は、環境適応ソフトウェアのコンセプトを提案し、自動オフロードを検討している。しかし、GPU単体へのオフロードである等、GPUやFPGAやメニーコアCPU等の多様なアクセラレータが混在している移行先環境は想定されていない。
【0014】
そこで、本発明は、オフロードサーバ、および、オフロード制御方法において、複数種類のアクセラレータが混在する環境が移行先であっても、自動で高性能化できることを課題とする。
【課題を解決するための手段】
【0015】
前記した課題を解決するため、本発明のオフロードサーバは、ソフトウェアプログラムのソースコードが、GPU、FPGAまたはメニーコアCPUによる実行が可能なループ文を含むか否かを分析するコード分析部と、前記ループ文を前記GPU、前記FPGA、および前記メニーコアCPUのうち何れかにオフロードするパターンを作成する処理パターン作成部と、各前記ループ文を遺伝子パターンにマッピングし、各前記ループ文をオフロードする各前記パターンを検証環境にデプロイして性能を測定する性能測定部と、処理時間が短いパターンほど高い適合度に設定して、遺伝的アルゴリズムのエリート選択によりパターンを選択し、交叉,突然変異の処理により次世代のパターンを作成することを繰り返す実行ファイル作成部と、を備えることを特徴とする。
その他の手段については、発明を実施するための形態のなかで説明する。
【発明の効果】
【0016】
本発明によれば、複数種類のアクセラレータが混在する環境が移行先であっても、自動で高性能化できる。更に移行先が同一ノードに複数種類のアクセラレータを持つ場合は、複数種類のアクセラレータに対して同時にオフロードすることで、単一アクセラレータの利用の場合よりも高速なオフロードを実現する。
【図面の簡単な説明】
【0017】
図1】オフロードサーバの構成例を示す機能ブロック図である。
図2】オフロードサーバの機能を実現するコンピュータの一例を示すハードウェア構成図である。
図3A】アクセラレータにオフロードするパターンの選択処理のフローチャートである。
図3B】アクセラレータにオフロードするパターンの選択処理のフローチャートである。
図3C】アクセラレータにオフロードするパターンの選択処理のフローチャートである。
図4A】機能ブロックを1ノードにオフロードする処理のフローチャートである。
図4B】ループ文を1ノードにオフロードする処理のフローチャートである。
図5A】機能ブロックをアクセラレータへオフロードするパターンの選択処理のフローチャートである。
図5B】機能ブロックをアクセラレータへオフロードするパターンの選択処理のフローチャートである。
図6】オフロードサーバの自動オフロード処理を示す図である。
図7】オフロードサーバの単純遺伝的アルゴリズムによる制御部の探索イメージを示す図である。
図8】ループ文のメニーコアCPUへの遺伝子配列マッピングを示す図である。
図9A】ループ文をメニーコアCPUへオフロードするパターンの選択処理のフローチャートである。
図9B】ループ文をメニーコアCPUへオフロードするパターンの選択処理のフローチャートである。
図10】ループ文のGPUへの遺伝子配列マッピングを示す図である。
図11A】ループ文をGPUへオフロードするパターンの選択処理のフローチャートである。
図11B】ループ文をGPUへオフロードするパターンの選択処理のフローチャートである。
図12A】ループ文をFPGAへオフロードするパターンの選択処理のフローチャートである。
図12B】ループ文をFPGAへオフロードするパターンの選択処理のフローチャートである。
【発明を実施するための形態】
【0018】
以降、本発明を実施するための形態を、各図を参照して詳細に説明する。
発明者は、環境適応ソフトウェアのコンセプトを具体化するために、これまでに、プログラムのループ文のGPU自動オフロード、FPGA自動オフロード、プログラムの機能ブロックの自動オフロードの方式を提案してきた。これらの要素技術検討も踏まえて、移行先環境について対象を定義し、対象が多様化した場合でも踏襲する基本的考えを記述する、更に、個々の移行先環境への自動オフロードと、移行先環境が多様化した際の自動オフロード方式について提案する。
【0019】
《多様移行先環境時の基本的考え》
本実施形態で対象とする多様な移行先環境としては、GPU、FPGA、メニーコアCPUの3つとする。GPU、FPGAについてはCPUとは異なるヘテロジニアスなハードウェアとして歴史も深く、CUDAやOpenCLを用いた手動でのオフロードによる高速化事例も多く、市場も大きい。また、メニーコアCPUに関しては、近年16コア以上の多数のコアを搭載したCPUが千ドルから数千ドルの低価格でも市場に出るようになり、OpenMP等の技術仕様を用いて並列化を行い、手作業でチューニングすることで、高速化する事例が出てきている。
【0020】
移行先環境が単なるCPUだけでない場合で、自動で高速にオフロードするため、検証環境の実機で性能測定し、進化計算手法等の手法と組み合わせて、徐々に高速なオフロードパターンを見つけるアプローチをとる。
【0021】
これは、今まで発明者が提案したGPUオフロード等の場合と同様である。理由として、性能に関しては、コード構造だけでなく、処理するハードウェアのスペック、データサイズ、ループ回数等の実際に処理する内容によって大きく変わるため、静的に予測する事が困難であり、動的な測定が必要だからと考えるからである。市中には、ループ文を見つけコンパイル段階で並列化する自動並列化コンパイラがあるが、並列化可能ループ文の並列化だけでは性能を測定すると低速になる場合も多いため、性能測定は必要と考える。
【0022】
また、オフロードする対象については、プログラムのループ文と機能ブロックとする。これは、今まで検討したGPUやFPGAオフロード等の場合と同様である。ループ文については、処理時間がかかるプログラムの処理の大半はループで費やされているという現状から、オフロードのターゲットとしてループ文が考えられる。
【0023】
一方、機能ブロックについては、特定処理を高速化する際に、処理内容や処理ハードウェアに適したアルゴリズムを用いることが多いため、個々のループ文の並列処理等に比べ、大きく高速化できる場合がある。本実施形態では、行列積算やフーリエ変換等の頻繁に使われる機能ブロック単位で、メニーコアCPUやFPGAやGPU等のアクセラレータに応じたアルゴリズムで実装された処理(IPコアやCUDAライブラリ等)に置換することで高速化する。
【0024】
図1は、オフロードサーバ1の構成例を示す機能ブロック図である。
オフロードサーバ1は、アプリケーションの特定処理を、GPUやFPGAやメニーコアCPU等のアクセラレータに自動的にオフロードする装置である。
図1に示すように、オフロードサーバ1は、制御部11と、入出力部12と、記憶部13と、検証用マシン14(アクセラレータ検証用装置)と、を含んで構成される。
【0025】
入出力部12は、クラウドレイヤ2、ネットワークレイヤ3およびデバイスレイヤ4に属する各デバイス等との間で情報の送受信を行うための通信インタフェース950(図2参照)と、タッチパネルやキーボード等の入力装置や、モニタ等の出力装置との間で情報の送受信を行うための入出力インタフェース960(図2参照)とから構成される。
【0026】
記憶部13は、ハードディスクやフラッシュメモリ、RAM(Random Access Memory)等により構成される。この記憶部13には、テストケースデータベース131とコードパターンデータベース133が記憶されるとともに、制御部11の各機能を実行させるためのプログラム(オフロードプログラム)や、制御部11の処理に必要な情報、例えば、中間言語ファイル132などが一時的に記憶される。
【0027】
テストケースデータベース131には、検証対象ソフトに対応した試験項目のデータを格納する。例えば、MySQL等のデータベースシステムなら、TPC-C等のトランザクション試験等である。コードパターンデータベース133は、ライブラリ名に対応した、置換可能なアクセラレータライブラリまたはアクセラレータ用IPコアを格納する。
検証用マシン14は、環境適応ソフトウェアシステムの検証用環境として、GPUやFPGAやメニーコアCPU等のアクセラレータを備える。
【0028】
制御部11は、オフロードサーバ1の全体の制御を司る自動オフロード機能部である。制御部11は、例えば、記憶部13に格納されたプログラム(オフロードプログラム)を図2のCPU910が、実行することにより実現される。
【0029】
制御部11は、コード指定部111と、コード分析部112と、処理指定部114と、処理パターン作成部115と、性能測定部116と、実行ファイル作成部117と、本番環境配置部118と、性能測定テスト抽出実行部119と、ユーザ提供部120とを備える。
【0030】
《コード指定部111》
コード指定部111は、入力されたソースコードの指定を行う。具体的には、コード指定部111は、受信したファイルに記載されたソースコードを、コード分析部112に渡す。
【0031】
《コード分析部112》
コード分析部112は、ソフトウェアプログラムのソースコードを分析し、for/do-while/whileなどのループ文や、FFTライブラリや行列演算や乱数生成等の機能ブロックを把握する。これらループ文や機能ブロックは、アクセラレータによる実行が可能なものである。
【0032】
《処理指定部114》
処理指定部114は、各機能ブロックに対して、アクセラレータへオフロードする処理に置換してコンパイルし、各ループ文に対して、アクセラレータにオフロードする並列処理指定文を指定してコンパイルする。処理指定部114は、オフロード範囲抽出部114aと中間言語ファイル出力部114bとを含んでいる。
【0033】
オフロード範囲抽出部114aは、for/do-while/whileなどのループ文や、FFTや行列演算や乱数生成等の機能ブロックのように、メニーコアCPUやGPUやFPGAにオフロード可能な処理を特定して、オフロード範囲を抽出する。中間言語ファイル出力部114bは、抽出したオフロード可能処理の中間言語ファイル132を出力する。中間言語抽出は、一度で終わりでなく、適切なオフロード領域探索のため、実行を試行して最適化するため反復される。
【0034】
《処理パターン作成部115》
処理パターン作成部115は、抽出したオフロード範囲に基づき、機能ブロックやループ文をアクセラレータにオフロードするパターンを作成する。
【0035】
ループ文に対してGPUをアクセラレータとする場合、処理パターン作成部115は、コンパイルエラーが出るループ文(繰り返し文)に対して、オフロード対象外とするとともに、コンパイルエラーが出ないループ文に対して、並列処理するか否かの指定を行う並列処理パターンを作成する。
【0036】
《性能測定部116》
性能測定部116は、処理パターンのソースコードをコンパイルして、検証用マシン14に配置し、アクセラレータにオフロードした際の性能測定用処理を実行する。
性能測定部116は、バイナリファイル配置部116aを備える。バイナリファイル配置部116aは、メニーコアCPUとGPUとFPGAを備えた検証用マシン14に、中間言語から導かれる実行ファイルをデプロイ(配置)する。
【0037】
性能測定部116は、配置したバイナリファイルを実行し、オフロードした際の性能を測定するとともに、性能測定結果を、処理パターン作成部115に戻す。この場合、処理パターン作成部115は、別のオフロードパターンを作成する。性能測定部116は、作成された別のオフロードパターンの性能測定を試行する。
【0038】
《実行ファイル作成部117》
実行ファイル作成部117は、所定回数繰り返された性能測定結果をもとに、複数のオフロードパターンから最高処理性能のオフロードパターンを選択し、最高処理性能のオフロードパターンをコンパイルして実行ファイルを作成する。
【0039】
《本番環境配置部118》
本番環境配置部118は、作成した実行ファイルを、ユーザ向けの本番環境に配置する(「最終バイナリファイルの本番環境への配置」)。本番環境配置部118は、最終的なオフロード領域を指定したパターンを決定し、ユーザ向けの本番環境にデプロイする。
【0040】
《性能測定テスト抽出実行部119》
性能測定テスト抽出実行部119は、実行ファイル配置後、テストケースデータベース131から性能試験項目を抽出し、性能試験を実行する(「最終バイナリファイルの本番環境への配置」)。
性能測定テスト抽出実行部119は、実行ファイル配置後、ユーザに性能を示すため、性能試験項目をテストケースデータベース131から抽出し、抽出した性能試験を自動実行する。
【0041】
《ユーザ提供部120》
ユーザ提供部120は、性能試験結果を踏まえた、価格・性能等の情報をユーザに提示する(「価格・性能等の情報のユーザへの提供」)。テストケースデータベース131には、検証対象ソフトに対応した試験項目のデータが格納されている。ユーザ提供部120は、テストケースデータベース131に格納された試験項目を実施して得られた性能等のデータと、ユーザソフトを配置するリソース(仮想マシンやGPU等)の価格情報等のデータを、ユーザに提示する。ユーザは、提示された価格・性能等の情報をもとに、サービスの課金利用開始を判断する。
【0042】
[遺伝的アルゴリズムの適用]
オフロードサーバ1は、オフロードの最適化に遺伝的アルゴリズムを用いることができる。遺伝的アルゴリズムを用いた場合のオフロードサーバ1の構成は下記の通りである。
すなわち、処理指定部114は、遺伝的アルゴリズムに基づき、ループ文(繰り返し文)の数を遺伝子長とする。処理パターン作成部115は、アクセラレータ処理をする場合を1または0のいずれか一方、しない場合を他方の0または1として、アクセラレータ処理可否を遺伝子パターンにマッピングする。
【0043】
処理パターン作成部115は、遺伝的アルゴリズムを用いる場合、遺伝子の各値を1か0にランダムに作成した指定個体数の遺伝子パターンを準備する。性能測定部116は、各個体に応じて、アクセラレータにおける並列処理指定文を指定したソースコードをコンパイルして、検証用マシン14に配置する。性能測定部116は、検証用マシン14において性能測定用処理を実行する。
【0044】
ここで、性能測定部116は、遺伝的アルゴリズムを用いる場合、途中世代で、以前と同じ並列処理パターンの遺伝子が生じた場合は、当該並列処理パターンに該当するソースコードのコンパイル、および、性能測定はせずに、性能測定値としては同じ値を使う。また、性能測定部116は、コンパイルエラーが生じるソースコード、および、性能測定が所定時間で終了しないソースコードについては、タイムアウトの扱いとして、性能測定値を所定の時間(長時間)に設定する。
【0045】
実行ファイル作成部117は、全個体に対して、性能測定を行い、処理時間の短い個体ほど適合度が高くなるように評価する。実行ファイル作成部117は、全個体から、適合度が所定値(例えば、全個数の上位n%、または全個数の上位m個:n,mは自然数)より高いものを性能の高い個体として選択し、選択された個体に対して、交叉、突然変異の処理を行い、次世代の個体を作成する。実行ファイル作成部117は、指定世代数の処理終了後、最高性能の並列処理パターンを解として選択する。
【0046】
図3は、オフロードサーバの機能を実現するコンピュータの一例を示すハードウェア構成図である。
コンピュータ900は、CPU910、RAM920、ROM930、HDD940、通信インタフェース950、入出力インタフェース960、およびメディアインタフェース970を有する。
【0047】
CPU910は、ROM930またはHDD940に格納されたプログラムに基づいて動作し、各部の制御を行う。ROM930は、コンピュータ900の起動時にCPU910によって実行されるブートプログラムや、コンピュータ900のハードウェアに依存するプログラム等を格納する。
【0048】
HDD940は、CPU910によって実行されるプログラム、および、かかるプログラムによって使用されるデータ等を格納する。通信インタフェース950は、通信網80を介して他の機器からデータを受信してCPU910へ送り、CPU910が生成したデータを通信網80を介して他の機器へ送信する。
【0049】
CPU910は、入出力インタフェース960を介して、ディスプレイやプリンタ等の出力装置、および、キーボードやマウス等の入力装置を制御する。CPU910は、入出力インタフェース960を介して、入力装置からデータを取得する。また、CPU910は、生成したデータを入出力インタフェース960を介して出力装置へ出力する。
【0050】
メディアインタフェース970は、記録媒体980に格納されたプログラムまたはデータを読み取り、RAM920を介してCPU910に提供する。CPU910は、かかるプログラムを、メディアインタフェース970を介して記録媒体980からRAM920上にロードし、ロードしたプログラムを実行する。記録媒体980は、例えばDVD(Digital Versatile Disc)等の光学記録媒体、MO(Magneto Optical disk)等の光磁気記録媒体、テープ媒体、磁気記録媒体、または半導体メモリ等である。
【0051】
例えば、コンピュータ900が本実施形態に係るオフロードサーバ1として機能する場合、コンピュータ900のCPU910は、RAM920上にロードされたプログラムを実行することにより、オフロードサーバ1の各部の機能を実現する。また、HDD940には、オフロードサーバ1の各部内のデータが格納される。コンピュータ900のCPU910は、これらのプログラムを記録媒体980から読み取って実行するが、他の例として、他の装置から通信網80を介してこれらのプログラムを取得してもよい。
【0052】
図3A図3B図3Cは、アクセラレータにオフロードするパターンの選択処理のフローチャートである。
オフロードサーバ1は、GPU、FPGA、メニーコアCPUの3つの移行先環境に対して、機能ブロックとループ文の2つの方法で、自動オフロードを検討する。
【0053】
制御部11は、C/C++ソースコードが入力されると(S200)、一連のオフロードパターンの選択処理を実行する。制御部11は、図5A図5Bの選択処理を呼び出して、メニーコアCPUへの機能ブロックのオフロードをチェックし(S201)、所望の性能が得られたか否かを判定する(S202)。制御部11は、所望の性能が得られたならば(Yes)、全測定から最高性能パターンを選択して(S208)、この図の処理を終了する。制御部11は、所望の性能が得られていないならば(No)、ステップS203に進む。
【0054】
ステップS203において、制御部11は、図5A図5Bの選択処理を呼び出して、GPUへの機能ブロックのオフロードをチェックする。そして制御部11は、所望の性能が得られたか否かを判定する(S204)。制御部11は、所望の性能が得られたならば(Yes)、全測定から最高性能パターンを選択して(S208)、この図の処理を終了する。制御部11は、所望の性能が得られていないならば(No)、ステップS205に進む。
【0055】
ステップS205において、制御部11は、図5A図5Bの選択処理を呼び出して、FPGAへの機能ブロックのオフロードをチェックする。そして制御部11は、所望の性能が得られたか否かを判定する(S206)。制御部11は、所望の性能が得られたならば(Yes)、全測定から最高性能パターンを選択して(S208)、この図の処理を終了する。制御部11は、所望の性能が得られていないならば(No)、コードから機能ブロックをオフロードできた部分を取り除き、図3BのステップS209に進む。
これらステップS201~S208の処理により、複数種類のアクセラレータが混在する環境が移行先であっても、機能ブロックを自動で高性能化できる。更に、制御部11は、メニーコアCPU、GPU、FPGAの順に試行することにより、効率的に高速化可能なパターンを探索できる。
【0056】
ステップS209において、制御部11は、図9A図9Bの選択処理を呼び出して、メニーコアCPUへのループ文のオフロードをチェックする。そして制御部11は、所望の性能が得られたか否かを判定する(S210)。制御部11は、所望の性能が得られたならば(Yes)、全測定から最高性能パターンを選択して(S208)、この図の処理を終了する。制御部11は、所望の性能が得られていないならば(No)、ステップS211に進む。
【0057】
ステップS211において、制御部11は、図11A図11Bの選択処理を呼び出して、GPUへのループ文のオフロードをチェックする。そして制御部11は、所望の性能が得られたか否かを判定する(S212)。制御部11は、所望の性能が得られたならば(Yes)、全測定から最高性能パターンを選択して(S208)、この図の処理を終了する。制御部11は、所望の性能が得られていないならば(No)、ステップS213に進む。
【0058】
ステップS213において、制御部11は、図12A図12Bの選択処理を呼び出して、FPGAへのループ文のオフロードをチェックする。そして制御部11は、所望の性能が得られたか否かを判定する(S214)。制御部11は、所望の性能が得られたならば(Yes)、全測定から最高性能パターンを選択して(S208)、この図の処理を終了する。制御部11は、所望の性能が得られていないならば(No)、個々の移行先に対する6つの検証の中から最高性能のパターンを選択する(S215)。
【0059】
これらステップS209~S215の処理により、複数種類のアクセラレータが混在する環境が移行先であっても、ループ文を自動で高性能化できる。更に、制御部11は、メニーコアCPU、GPU、FPGAの順に試行することにより、効率的に高速化可能なパターンを探索できる。制御部は、アクセラレータへのオフロード対象として機能ブロックの試行の次にループ文を試行することより、効率的に高速化可能なパターンを探索できる。
【0060】
そして制御部11は、1ノードへの複数のオフロードが可能な候補があるか否かを判定する(S216)。
制御部11は、1ノードへの複数のオフロードが可能な候補が無ければ(No)、この図の処理を終了する。制御部11は、1ノードへの複数のオフロードが可能な候補があれば(Yes)、図3CのステップS217に進む。
【0061】
図3CのステップS217において、制御部11は、複数の機能ブロックをオフロード可能な候補が有るか否かを判定する。制御部11は、複数の機能ブロックをオフロード可能な候補が有れば(Yes)、ステップS218に進み。複数の機能ブロックをオフロード可能な候補が無ければ(No)、ステップS223に進む。
【0062】
ステップS218において、制御部11は、複数の機能ブロックのオフロードの組み合わせパターンを作成する。制御部11は、この組み合わせパターンの性能を測定する(S219)。そして制御部11は、機能ブロックのオフロードの組み合わせで高速化できたか否かを判定する(S220)。
【0063】
ステップS220において、制御部11は、機能ブロックのオフロードを組み合わせた方が高速ならば、組み合わせた機能ブロックをソースコードから除去し(S221)、ステップS223の処理に進む。制御部11は、機能ブロックのオフロードを組み合わせない方が高速ならば、より高速化できる一つの機能ブロックをソースコードのオフロード対象から除去し(S222)、ステップS223の処理に進む。
【0064】
ステップS223において、制御部11は、高速化できるループ文オフロードパターンが有るか否かと、それが単数のアクセラレータと複数のアクセラレータの何れであるかを判定する。制御部11は、高速化できるループ文オフロードパターンが無いならば、ステップS227に進み、全測定から最高性能のパターンを選択すると、この選択処理を終了する。ここで、ループ文オフロードパターンBはGPUに30個のfor文をオフロード、ループ文オフロードパターンCはメニーコアCPUに50個のfor文をオフロードといった例の際に、Bだけ高速化できる場合を単数のアクセラレータ、B、Cの両方が高速化できる場合を複数のアクセラレータと記載する。
【0065】
制御部11は、ステップS223の判定結果が高速化できる単数のアクセラレータのループ文のオフロードパターンならば、除去した機能ブロックのオフロードと単数のアクセラレータのループ文のオフロードの組み合わせを作成する(S224)。そして制御部11は、組み合わせパターンの性能を測定し(S226)、全測定から最高性能のパターンを選択すると(S227)、この選択処理を終了する。
【0066】
制御部11は、ステップS223の判定結果が高速化できる複数のアクセラレータのループ文のオフロードパターンならば、除去した機能ブロックのオフロードと複数のアクセラレータのループ文のオフロードの組み合わせを作成する(S225)。例えば、GPUへの機能ブロックオフロードA、GPUへのループ文オフロードパターンB、メニーコアCPUへのループ文オフロードパターンCが高速化できる場合は、A+B+C、A+B、A+C、B+Cの4種類の組み合わせが考えられる。
そして制御部11は、組み合わせパターンの性能を測定し(S226)、全測定から最高性能のパターンを選択すると(S227)、この選択処理を終了する。
これらステップS217~S227の処理により、移行先が同一ノードに複数種類のアクセラレータを持つ場合は、複数種類のアクセラレータに対して同時にオフロードすることで、単一アクセラレータの利用の場合よりも高速なオフロードを実現する。
【0067】
《オフロード試行の検証順番》
多様な移行先での自動オフロードについて検討する。
性能については、行う処理は同じでも、処理ハードウェアのスペック、処理内容(データサイズ、ループ回数等)により大きく変わるため、検証環境の実機で測定する事が必要である。移行先環境GPU、FPGA、メニーコアCPUの3つに対して、ループ文、機能ブロックの2つの方法でのオフロードがあるため、合計3×2の6つオフロードが考えられる。
【0068】
まず、機能ブロックのオフロードとループ文のオフロードを比較すると、アルゴリズムを含めて処理内容に合わせてオフロードする機能ブロックのオフロードの方が高速化できる。
【0069】
次に、仮想化等を行わない場合、GPUとFPGAとメニーコアCPUで、中心価格帯はGPUよりもメニーコアCPUが高価で、FPGAはそれらより更に高価である。また、1パターンの検証時間は、メニーコアCPUとGPUが略同等で、FPGAがそれらよりも長くなる。FPGAは、回路設定に数時間必要で、性能測定には時間がかかるのが現状である。
【0070】
これらの現況を踏まえ、6つのオフロードで検証する順番として、メニーコアCPU向けの機能ブロックのオフロード、GPU向けの機能ブロックのオフロード、FPGA向けの機能ブロックのオフロード、メニーコアCPU向けのループ文のオフロード、GPU向けのループ文のオフロード、FPGA向けのループ文のオフロードとすることを提案する。この順番でオフロードを試行し、高性能となるパターンを探索していく。
【0071】
前半の3つと後半の3つは、対象とするコードが変わってもよいとする。具体的には、前半の3つで機能ブロックのオフロードが可能であった場合、後半の3つのループ文オフロードはオフロード可能だった機能ブロック部分を抜いたコードに対して試行する。
【0072】
なお、オフロード試行ではユーザが目標性能や価格を指定でき、ユーザが指定する範囲で十分に高速で低価格なオフロードパターンが6つ試行の前方側で見つかっていれば、以降の試行はしなくてもよい。このようにする理由として、機能ブロックオフロードの方がループ文オフロードに比べ、オフロードできる対象は少ないが、オフロードできる場合には、より高速化ができるためである。
【0073】
また、自動オフロードする際は、できるだけ安価で短時間に高速なパターンを探索できることが望ましい。そこで、検証時間がかかるFPGAは最後とし、それよりも前の段階で十分にユーザ要件を満足するパターンが見つかっていれば、FPGA向けのオフロードパターンは検証しない事とする。
【0074】
GPUとメニーコアCPUに関しては、価格的にも検証時間的にも大きな差はないが、メモリも別空間となりデバイス自体が異なるGPUに比して、メニーコアCPUの方が、通常CPUとの差は小さい。そのため検証順は、メニーコアCPUを先とし、メニーコアCPUで十分にユーザ要件を満足するパターンが見つかっていれば、GPU向けのオフロードパターンは検証しない事とする。
CPUとGPUではデバイスが異なるため、丸め誤差の違い等で、正しくオフロードできても計算結果が異なる場合がある。
【0075】
《複数オフロードの組み合わせによる高性能パターンの作成》
解となるパターンを作る際も試行錯誤が必要となる。6つのオフロード試行で、通常CPUよりも高速になるのが1つだけの場合は、そのパターンの実行ファイルを商用環境に配置すればよい。
【0076】
なお、実行ファイル配置時は、最高性能のパターン選択だけでなく、利用するデバイスの価格に応じて、コストパフォーマンスが高いパターンを選択してもよい。なお、検証で複数が高速化できた場合には、解となるパターンは検討が必要である。
【0077】
オフロードする際に、同一ノードのGPU、FPGA、メニーコアCPUにオフロードは高速化が容易だが、別ノードにオフロードする場合は、MPI等の技術仕様が必要となり、また、通信オーバヘッドのため高速化は難しい。またサーバは、メニーコアCPUとGPUを備えた構成、メニーコアCPUとFPGAを備えた構成が一般的だが、メニーコアCPUとGPUとFPGAを備えた構成は稀である。
【0078】
複数アクセラレータでの高速化が可能な場合は、同一ノードにオフロードできることは最初の条件とする。同一ノードのメニーコアCPUとGPUは候補になり得るが、別ノードのGPUとFPGAは候補にならない。
【0079】
まず、機能ブロックオフロードに関して検討する。機能ブロックオフロードでは以下のルールとする。
(a) 同じ機能ブロックを複数種類のアクセラレータにオフロード可能な場合にはより高性能化効果が高いオフロード先を選択する。
(b) 異なる機能ブロックが異なる種類のアクセラレータにオフロード可能で、かつ同一ノードにオフロードできない場合は、より高性能化効果が高い機能ブロックをオフロード対象にする。
(c) 異なる機能ブロックが異なる種類のアクセラレータにオフロード可能で、かつ同一ノードにオフロードできる場合は、それら機能ブロックをオフロード対象にする。
【0080】
ルール(a)の例として、シングルコアCPUで10秒を要するFFT処理を、GPUにオフロードすると2秒を要し、FPGAにオフロードすると1秒を要し、メニーコアCPUにオフロードすると5秒を要する場合を考える。この場合、オフロード先のアクセラレータとしてFPGAを選択するとよい。
【0081】
ルール(b)の例として、シングルコアCPUで20秒を要する乱数処理をGPUにオフロードすると2秒を要し、シングルコアCPUで100秒を要するFFT処理をFPGAにオフロードすると1秒を要し、シングルコアCPUで50秒を要する行列計算をメニーコアCPUにオフロードすると10秒を要する場合を考える。この場合は、最も効果の高いFFT処理をFPGAにオフロードするパターンを選択するとよい。
【0082】
ルール(c)については、同一ノードの複数アクセラレータに異なる機能ブロックをオフロードして性能検証し、単体オフロードよりも高速の場合は解とする。
ルール(c)の例として、シングルコアCPUで20秒を要する乱数処理をGPUにオフロードすると20秒を要し、シングルコアCPUで10秒を要するFFT処理をFPGAにオフロードすると1秒を要し、シングルコアCPUで50秒を要する行列計算をメニーコアCPUにオフロードすると10秒を要する場合を考える。更に、GPUとメニーコアCPUの両方を搭載したノードがあるとする。この場合は、同一ノード上で、乱数処理はGPUに、行列計算はメニーコアCPUにオフロードするパターンを選択するとよい。
【0083】
同一ノード上の複数種類のアクセラレータにオフロードする場合は、複数種類のアクセラレータに同時にオフロードすることで確実に高速化されるとも限らない。よって、オフロードサーバ1は、複数種類のアクセラレータに同時にオフロードして性能検証し、単体でオフロードするよりも高速化されていることを確認する。
このようにすることで、複数種類のアクセラレータが混在する環境に対して、機能ブロックを効率的に高速化可能なパターンを探索できる。
【0084】
なお、利用頻度が高い処理である機能ブロックを、高い優先度でオフロードするようにしてもよい。その場合は、先行して行う6つのオフロード検証にて、性能測定するサンプルテストで、優先度が高い処理を中心的に行うサンプルテストとすればよい。
【0085】
図4Aは、機能ブロックを1ノードにオフロードする処理のフローチャートである。
オフロードサーバ1の制御部11は、同じ機能ブロックを複数種類のアクセラレータにオフロード可能か否かを判定する(S50)。制御部11は、同じ機能ブロックを複数種類のアクセラレータにオフロード可能ならば(Yes)、より高性能化効果が高いオフロード先を選択し(S51)、図4Aの処理を終了する。制御部11は、同じ機能ブロックを複数種類のアクセラレータにオフロードできないならば(No)、ステップS52に進む。
【0086】
ステップS52において、制御部11は、異なる機能ブロックが異なる種類のアクセラレータにオフロード可能か否かを判定する。制御部11は、異なる機能ブロックが異なる種類のアクセラレータにオフロード可能ならば(Yes)、これら機能ブロックをオフロード対象にすると(S55)、図4Aの処理を終了する。
制御部11は、異なる機能ブロックが異なる種類のアクセラレータにオフロードできないならば(No)、より高性能化効果が高い機能ブロックをオフロード対象にして(S54)、図4Aの処理を終了する。
【0087】
次に、ループ文のオフロードに関して検討する。
ループ文のオフロードは、機能ブロックオフロードが可能な場合、オフロード可能な機能ブロック部分を除いたコードに対して行われる。ループ文オフロードでの高速化が、機能ブロックオフロードでのオフロード先と別ノードに対してのオフロードとなり、高性能化効果も小さい場合は、ループ文オフロードは行わない。
【0088】
例として、シングルコアCPUで100秒を要するFFT処理をオフロードしてFPGAで1秒に処理できている場合、残りのループ文をGPUにオフロードしたときに20秒が5秒に高速化できることが分かったとしても、高性能化効果が小さいので、別ノードのGPUに対してはオフロードは行わない。
【0089】
ループ文のオフロードは、以下のルールとする。
(d) 同じループ文が複数種類のアクセラレータにオフロードできる場合は、より高性能化効果が高いオフロード先を選択する。
【0090】
(e) 異なるループ文が異なる種類のアクセラレータにオフロード可能で、かつ同一ノードにオフロードできない場合は、より高性能化効果が高いループ文群をオフロード対象にする。
【0091】
(f) 異なるループ文が異なる種類のアクセラレータにオフロード可能で、かつ同一ノードにオフロードできる場合は、高性能化効果が高いループ文を優先してオフロードし、オフロードされていない残りのループ文群は高性能化効果が低いオフロード先にオフロードする。
【0092】
ルール(d)の例として、シングルコアCPUで20秒を要するABCDEのループ文をGPUにオフロードすると2秒を要し、FPGAにオフロードすると1秒を要し、メニーコアCPUにオフロードすると5秒を要する場合を考える。この場合、ABCDEのループ文をFPGAにオフロードするパターンを選択するとよい。
【0093】
ルール(e)の例として、シングルコアCPUで50秒を要するABCのループ文をGPUにオフロードすると2秒を要し、シングルコアCPUで100秒を要するBCDのループをFPGAにオフロードすると1秒を要し、シングルコアCPUで50秒を要するCDEのループ文をメニーコアCPUにオフロードすると10秒を要する場合を考える。この場合は、BCDのループ文をFPGAにオフロードするパターンを選択するとよい。
【0094】
ルール(f)については、同一ノードの複数種類のアクセラレータに異なるループをオフロードして性能検証し、単体よりも高速の場合はそのパターンを解として選択する。ただし、同一ファイルで定義された複数のループ文については別のアクセラレータに処理が分かれないように制限を行う。これは、関連が深い同一ファイル上の複数のループ文については、アクセラレータが分かれることでの複雑度向上を避けるためである。
【0095】
ルール(f)の例として、シングルコアCPUで50秒を要するABCのループ文をGPUにオフロードすると2秒を要し、シングルコアCPUで10秒を要するBCDのループ文をFPGAにオフロードすると1秒を要し、シングルコアCPUで50秒を要するCDEのループ文をメニーコアCPUにオフロードすると10秒を要したと仮定し、かつGPUとメニーコアCPUの両方を搭載したノードがある場合を考える。この場合は、同一ノード上で、ABCのループ文はGPUにオフロードし、DEのループ文はメニーコアCPUにオフロードすることを試行する。
【0096】
図4Bは、ループ文を1ノードにオフロードする処理のフローチャートである。
オフロードサーバ1の制御部11は、同じループ文を複数種類のアクセラレータにオフロード可能か否かを判定する(S60)。制御部11は、同じループ文を複数種類のアクセラレータにオフロード可能ならば(Yes)、より高性能化効果が高いオフロード先を選択し(S61)、図4Bの処理を終了する。制御部11は、同じループ文を複数種類のアクセラレータにオフロードできないならば(No)、ステップS62に進む。
【0097】
ステップS62において、制御部11は、異なるループ文が異なる種類のアクセラレータにオフロード可能か否かを判定する。制御部11は、異なるループ文が異なる種類のアクセラレータにオフロード可能ならば(Yes)、これらループ文をオフロード対象にすると(S65)、図4Bの処理を終了する。
制御部11は、異なるループ文が異なる種類のアクセラレータにオフロードできないならば(No)、より高性能化効果が高いループ文をオフロード対象にして(S64)、図4Bの処理を終了する。
【0098】
同一ノード上の複数種類のアクセラレータにオフロードする場合は、確実に高速化されるとも限らないので、実際にオフロードして性能検証を行い、単体でオフロードするよりも高速化されていることを確認するとよい。
このようにすることで、複数種類のアクセラレータが混在する環境に対して、ループ文を効率的に高速化可能なパターンを探索できる。
【0099】
このように、6つの性能測定の中で、高速化できているパターンを元に、最高性能となるパターンを作成する。同一ノードに対しては複数のアクセラレータにオフロードすることも可能であるが、複数のオフロードパターンを組み合わせる際は、その組み合わせで単体の場合よりも高性能化できているかを性能測定して確認することを通じて、最高性能のパターンを作成するため、複数回の測定が必要である。
【0100】
図5A図5Bは、機能ブロックをアクセラレータへオフロードするパターンの選択処理のフローチャートである。この選択処理は、非特許文献4の手法を用いている。
最初、コード分析部112は、C/C++ソースコードのオフロード分析を行う(S30)。具体的には、コード分析部112は、Clang等の構文解析ツールを用いて、コードに含まれるライブラリ呼び出しや、機能処理を分析する。
【0101】
オフロード範囲抽出部114aは、このソースコードの外部ライブラリ呼び出しを検出し(S31)、コードパターンデータベース133から、ライブラリ名をキーに、置換可能なアクセラレータライブラリまたはアクセラレータ用IPコアを取得する(S32)。ここでアクセラレータとは、メニーコアCPUやGPUやFPGAのうち何れかである。具体的にいうと、オフロード範囲抽出部114aは、呼び出されているライブラリをキーに、コードパターンデータベース133に登録されているレコードから、高速化可能な実行ファイルやOpenCL等を取得する。
【0102】
ここでオフロード範囲抽出部114aは、把握した外部ライブラリ呼び出しについて、呼び出されているライブラリ名をキーとしてコードパターンデータベース133と照合することで、置換可能なアクセラレータライブラリまたはアクセラレータ用IPコアを取得する。ここでアクセラレータライブラリとは、メニーコアCPUやGPU向けの実行ファイルである。アクセラレータ用IPコアとは、OpenCL等である。
【0103】
なお、機能ブロックに対して、高速化するライブラリやIPコアがあるかの探索は、ライブラリ等の名前一致に加えて類似性検出ツールでの検出も行う。類似性検出ツールとは、Deckard等の、コピーコードやコピー後に変更したコードを検出するための、ソフト工学で利用されるツールである。類似性検出ツールは、abstract syntax tree類似性等を見て、コードの類似性を判定し、CPUで計算する場合は記述が同様になる処理や、他者の参照コードをコピーして変更した場合等を検出できる。
【0104】
処理パターン作成部115は、ソースコードの置換元の処理記述を、置換先のアクセラレータに合わせて、メニーコアCPUやGPU向けライブラリ、またはFPGA向けのIPコアの処理記述に置換する(S33)。更に処理パターン作成部115は、置換したアクセラレータライブラリまたはアクセラレータIPコアの処理記述を、オフロード対象の機能ブロックとして、アクセラレータにオフロードする(S34)。この際に、オフロードできる処理が実際に高速化につながるか、コスト効果が十分かは分からないので、検証環境での性能測定を通じて、オフロードするしないを試行することで、より高速となるオフロードパターンを自動抽出する。
【0105】
処理パターン作成部115は、アクセラレータライブラリやアクセラレータIPコア呼び出しのためのインタフェース処理を記述する(S35)。このインタフェース処理は、例えばFPGAに対するOpenCL API等である。
次に実行ファイル作成部117は、作成したパターンをコンパイルする(S36)。性能測定部116は、作成したパターンを検証環境で性能測定する(S37)。これは、1回目の性能測定である。
【0106】
1回目の性能測定後、実行ファイル作成部117は、1回目測定時に高速化できたパターンについて組み合わせパターンを作成し(S38)、作成した組み合わせパターンをコンパイルする(S39)。そして、性能測定部116は、作成した組み合わせパターンを検証環境で性能測定する(S40)。これは、2回目の性能測定である。
【0107】
2回目の性能測定後、本番環境配置部118は、1回目と2回目の測定の中で最高性能のパターンを選択して(S41)、本フローの処理を終了する。
【0108】
非特許文献4で評価の通り、個々のループ文のオフロードに比べ、複数のループ文を含む機能ブロック単位で処理するアクセラレータに向けて、チューンした機能ブロックのオフロードは、高速化の度合いが高い。
【0109】
《実装》
オフロードサーバ1は、コード解析にて、呼び出されているライブラリや定義されているクラス、構造体等のプログラム構造を把握する。
【0110】
次にオフロードサーバ1は、呼び出されているライブラリを高速化できるGPU用ライブラリ、FPGA用IPコア等の検出を行う。
オフロードサーバ1は、呼び出されているライブラリをキーに、コードパターンデータベース133に登録されているレコードから、高速化可能な実行ファイルやOpenCL等を取得する。高速化できる置換用機能が検出されたら、オフロードサーバ1は、その実行用ファイルを作成する。
【0111】
メニーコアCPUやGPU用ライブラリの場合は、置換用ライブラリ(CUDAライブラリ等)を呼び出すよう、元の部分は削除して置換記述する。FPGA用IPコアの場合は、取得したOpenCLコードを、元の部分をホストコードから削除してから、カーネルコードに置換記述する。それぞれ、置換記述が終わったら、メニーコアCPU向けにはgcc、GPU向けにはPGIコンパイラ、FPGA向けにはIntel Acceleration Stackでコンパイルする。
【0112】
ライブラリ呼び出しの場合について記載したが、類似性検知を用いる場合も並行して処理がされる。Deckardを用いて、検出されたクラス、構造体等の部分コードとDBに登録された比較用コードの類似性検知を行い、類似性が閾値越えの機能ブロックと該当するGPU用ライブラリやFPGA用IPコア等を発見する。特に置換元のコードと置換するライブラリやIPコアの引数や戻り値、型等のインタフェースが異なる場合、オフロードサーバ1は、オフロードを依頼したユーザに対して、置換先ライブラリやIPコアに合わせて、インタフェースを変更してよいか確認し、確認後に実行用ファイルを作成する。
【0113】
ここで、オフロードサーバ1は、検証環境のGPUやFPGAで性能測定できる実行用ファイルを作成する。
機能ブロックオフロードにおいて、オフロードサーバ1は、置換機能ブロック一つずつに対してオフロードするしないを性能測定して高速化できるか確認する。6つのオフロード試行で、通常CPUより高速のパターンが、1つだけの場合はそのパターンを選択するが、複数の際には解となるパターンを、以下のロジックで作成する。
【0114】
[自動オフロード動作]
本実施形態のオフロードサーバ1は、環境適応ソフトウェアシステムの要素技術として、ユーザアプリケーションロジックをアクセラレータに自動オフロードする技術に適用した例である。
【0115】
図6は、オフロードサーバ1の自動オフロード処理を示す図である。
図6に示すように、オフロードサーバ1は、環境適応ソフトウェアシステムの要素技術に適用される。オフロードサーバ1は、制御部11と、テストケースデータベース131と、中間言語ファイル132と、検証用マシン14と、を有している。
オフロードサーバ1は、ユーザが利用するソースコード130を取得する。
【0116】
ユーザは、リソース15を利用する。リソース15は、例えば、装置151、CPUとGPUを有する装置152、CPUとFPGAを有する装置153、CPUを有する装置154である。オフロードサーバ1は、機能処理をCPUとGPUを有する装置152や、CPUとFPGAを有する装置153のアクセラレータに自動オフロードする。
【0117】
以下、図6のステップ番号を参照して各部の動作を説明する。
《ステップS11:ソースコードの指定》
ステップS11において、コード指定部111(図1参照)は、ユーザに提供しているサービスの処理機能(画像分析等)を特定する。具体的には、コード指定部111は、入力されたソースコードを指定する。
【0118】
《ステップS12:ソースコードの分析》
ステップS12において、コード分析部112(図1参照)は、処理機能のソースコードを分析し、ループ文やFFTライブラリ呼び出し等の構造を把握する。
【0119】
《ステップS13:オフロード範囲の抽出》
ステップS13において、処理指定部114(図1参照)は、アプリケーションのソースコードに含まれるループ文を特定し、各ループ文に対して、アクセラレータにおける並列処理指定文を指定してコンパイルする。具体的には、オフロード範囲抽出部114a(図1参照)は、ループ文やFFT等、GPU・FPGAにオフロード可能な範囲を抽出する。
【0120】
《ステップS14:中間言語ファイルの出力》
ステップS14において、処理指定部114(図1参照)は、中間言語ファイル出力部114bにより、中間言語ファイル132を出力する。中間言語の出力は、一度で終わりでなく、適切なオフロード領域探索のため、実行を試行して最適化するため反復される。
【0121】
《ステップS15:コンパイルエラー時の処理》
ステップS15において、処理パターン作成部115(図1参照)は、コンパイルエラーが出るループ文に対して、オフロード対象外とするとともに、コンパイルエラーが出ないループ文に対して、並列処理するかしないかの指定を行う並列処理パターンを作成する。
【0122】
《ステップS21:実行ファイルの配置》
ステップS21において、実行ファイル配置部116a(図1参照)は、メニーコアCPUとGPUとFPGAを備えた検証用マシン14に、中間言語から導かれる実行ファイルをデプロイする。
【0123】
《ステップS22:性能の測定》
ステップS22において、性能測定部116(図1参照)は、配置したファイルを実行し、オフロードした際の性能を測定する。
オフロードする領域をより適切にするため、この性能測定結果は、処理パターン作成部115に戻され、処理パターン作成部115が、別のオフロードパターンを作成する。そして、性能測定部116は、別のオフロードパターンの性能を測定する(図6の符号e参照)。
【0124】
図6の矢印eに示すように、制御部11は、ステップS12からステップS22の処理を繰り返し実行する。
【0125】
制御部11の自動オフロード機能をまとめると、下記である。
すなわち、処理指定部114は、ソースコードのループ文を特定し、各ループ文に対して、並列処理指定文を指定して、コンパイルする。そして、処理パターン作成部115は、コンパイルエラーが出るループ文を、オフロード対象外とし、コンパイルエラーが出ないループ文に対して、並列処理するか否かの指定を行う並列処理パターンを作成する。そして、性能測定部116は、該当並列処理パターンのソースコードをコンパイルして、検証用マシン14に配置し、検証用マシン14で性能測定用処理を実行する。実行ファイル作成部117は、所定回数繰り返された、性能測定結果をもとに、複数の並列処理パターンから最高処理性能のパターンを選択し、選択パターンをコンパイルして実行ファイルを作成する。
【0126】
《ステップS23:本番環境への配置》
ステップS23において、本番環境配置部118は、最終的なオフロード領域を指定したパターンを決定し、ユーザ向けの本番環境にデプロイする。
【0127】
《ステップS24:性能測定テストと実行》
ステップS24において、性能測定テスト抽出実行部119は、実行ファイル配置後、ユーザに性能を示すため、性能試験項目をテストケースデータベース131から抽出し、抽出した性能試験を自動実行する。
【0128】
《ステップS25:ユーザへの価格と性能等の提供》
ステップS25において、ユーザ提供部120は、性能試験結果を踏まえた、価格・性能等の情報をユーザに提示する。ユーザは、提示された価格・性能等の情報をもとに、サービスの課金利用開始を判断する。
【0129】
上記ステップS11~ステップS25は、ユーザのサービス利用のバックグラウンドで行われ、例えば、仮利用の初日の間に行う等を想定している。
【0130】
上記したように、オフロードサーバ1の制御部11は、環境適応ソフトウェアシステムの要素技術に適用した場合、機能処理のオフロードのため、ユーザが利用するアプリケーションのソースコードから、オフロードする領域を抽出して中間言語を出力する(S11~S15)。制御部11は、中間言語から導かれる実行ファイルを、検証用マシン14に配置実行し、オフロード効果を検証する(S21~S22)。検証を繰り返し、適切なオフロード領域を定めたのち、制御部11は、実際にユーザに提供する本番環境に、実行ファイルをデプロイし、サービスとして提供する(S23~S25)。
【0131】
[遺伝的アルゴリズムを用いたループ文自動オフロード]
GPUやメニーコアCPUへのループ文自動オフロードは、図6のステップS12~ステップS22を繰り返し、最終的にステップS23でデプロイするオフロードコードを得るための処理である。
【0132】
GPUは、一般的にレイテンシーは保証しないが、並列処理によりスループットを高めることに向いたデバイスである。GPUに向いたアプリケーションは、多種多様である。データの暗号化処理や、カメラ映像分析のための画像処理、大量センサデータ分析のための機械学習処理等が代表的であり、それらは、繰り返し処理が多い。そこで、オフロードサーバ1は、アプリケーションのソースコードに含まれるループ文をGPUに自動でオフロードすることでの高速化を狙う。
【0133】
しかし、従来技術で記載の通り、高速化には適切な並列処理が必要である。特に、GPUを使う場合は、CPUとGPU間のメモリ転送のため、データサイズやループ回数が多くないと性能が出ないことが多い。また、メモリデータ転送のタイミング等により、並列高速化できる個々のループ文(繰り返し文)の組み合わせが、最速とならない場合等がある。例えば、10個のループ文(繰り返し文)で、1番、5番、10番の3つがCPUに比べて高速化できる場合に、1番、5番、10番の3つの組み合わせが最速になるとは限らない等である。
【0134】
適切な並列領域の指定のため、PGIコンパイラを用いて、ループ文の並列可否を試行錯誤して最適化する試みがある。しかし、試行錯誤には多くの稼働がかかり、サービスとして提供する際に、ユーザの利用開始が遅くなり、コストも上がってしまう問題がある。
【0135】
そこで、本実施形態では、並列化を想定していない汎用プログラムから、自動で適切なオフロード領域を抽出する。このため、オフロードサーバ1は、機能ブロックのオフロードをメニーコアCPU→GPU→FPGAの順でチェックしたのち、ループ文のオフロードをメニーコアCPU→GPU→FPGAの順でチェックする。オフロード効果の高い機能ブロックをループ文よりも先にチェックすることと、検証コストが低い順であるメニーコアCPU→GPU→FPGAの順でチェックすることにより、効率的に高速化可能なパターンを探索できる。
【0136】
[単純遺伝的アルゴリズムによる制御部11の探索イメージ]
図7は、オフロードサーバの単純遺伝的アルゴリズムによる制御部11の探索イメージを示す図である。
遺伝的アルゴリズムは、生物の進化過程を模倣した組み合わせ最適化手法の一つである。遺伝的アルゴリズムのフローチャートは、初期化→評価→選択→交叉→突然変異→終了判定となっている。
【0137】
本実施形態では、遺伝的アルゴリズムの中で、処理を単純にした単純遺伝的アルゴリズムを用いる。単純遺伝的アルゴリズムは、遺伝子は1と0のみとし、ルーレット選択、一点交叉、突然変異は1箇所の遺伝子の値を逆にする等、単純化された遺伝的アルゴリズムである。
【0138】
《初期化》
初期化では、ソースコードの全ループ文の並列可否をチェック後、並列可能ループ文を遺伝子配列にマッピングする。GPU処理する場合は1、GPU処理しない場合は0とする。遺伝子は、指定の個体数Mを準備し、1つのループ文にランダムに1と0を割り当てる。
【0139】
具体的には、制御部11(図1参照)は、ユーザが利用するソースコード130(図6参照)を取得し、ソースコード130のコードパターン141からループ文の並列可否をチェックする。図8に示すように、コードパターン141dから3つのループ文が検出された場合、各ループ文に対して1桁、ここでは3つのループ文に対し3桁の1または0をランダムに割り当てる。例えば、シングルコアCPUで処理する場合には0、メニーコアCPUに出す場合には1とする。ただし、この段階では1または0をランダムに割り当てる。
遺伝子長に該当するコードが3桁であり、3桁の遺伝子長のコードは2=8パターン、例えば100、110、…となる。なお、図7では、コードパターン141中の丸印(○印)をコードのイメージとして示している。
【0140】
《評価》
ステップS300の評価では、デプロイとパフォーマンスの測定を行う。すなわち、性能測定部116(図1参照)は、遺伝子に該当するコードをコンパイルして検証用マシン14にデプロイして実行する。性能測定部116は、ベンチマーク性能測定を行う。性能が良いパターン(並列処理パターン)の遺伝子の適合度を高くする。
【0141】
《選択》
ステップS301の選択では、適合度に基づいて、高性能コードパターンを選択する。性能測定部116(図1参照)は、適合度に基づいて、高適合度の遺伝子を、指定の個体数だけ選択する。本実施形態では、適合度に応じたルーレット選択および最高適合度遺伝子のエリート選択を行う。
図7では、選択されたコードパターン142の中の丸印(○印)が、3つに減ったことを探索イメージとして示している。
【0142】
《交叉》
交叉では、一定の交叉率Pcで、選択された個体間で一部の遺伝子をある一点で交換し、子の個体を作成する。
ルーレット選択された、あるパターン(並列処理パターン)と他のパターンとの遺伝子を交叉させる。一点交叉の位置は任意であり、例えば上記3桁のコードのうち2桁目で交叉させる。
【0143】
《突然変異》
突然変異では、一定の突然変異率Pmで、個体の遺伝子の各値を0から1または1から0に変更する。
また、局所解を避けるため、突然変異を導入する。なお、演算量を削減するために突然変異を行わない態様でもよい。そして、ステップS302で示すように、これら交叉や突然変異を施した各コードを次世代のコードとする。
【0144】
《終了判定》
クロスオーバーと突然変異後の次世代コードパターンを生成する。
終了判定では、指定の世代数T回、繰り返しを行った後に処理を終了し、最高適合度の遺伝子を解とする。
例えば、性能測定して、処理速度が速い個体を3つ、例えば遺伝子110,010,001の個体を選ぶ。この3つを遺伝的アルゴリズムにより、次の世代は、組み換えをして、例えば新しいパターン(並列処理パターン)011(一例)を作っていく。このとき、組み換えをしたパターンに、勝手に0を1にするなどの突然変異を入れる。上記を繰り返して、一番処理速度が速いパターンを見付ける。指定世代(例えば、20世代)などを決めて、最終世代で残ったパターンを、最後の解とする。
【0145】
《デプロイ(配置)》
最高適合度の遺伝子に該当する、最高処理性能の並列処理パターンで、本番環境に改めてデプロイして、ユーザに提供する。
【0146】
《補足説明》
GPUにオフロードできないループ文(ループ文;繰り返し文)が相当数存在する場合について説明する。例えば、ループ文が200個あっても、GPUにオフロードできるものは30個くらいである。ここでは、エラーになるものを除外し、この30個について、遺伝的アルゴリズムを行う。
【0147】
OpenACCには、ディレクティブ“#pragma acc kernels”で指定して、GPU向けバイトコードを抽出し、実行によりGPUオフロードを可能とするコンパイラがある。この“#pragma”に、ループ文のコマンドを書くことにより、そのループ文がGPUで動くか否かを判定することができる。
【0148】
例えばC/C++を使った場合、C/C++のコードを分析し、ループ文を検出する。ループ文を検出すると、OpenACCで並列処理の文法である“#pragma acc kernels”を使ってループ文に対して書き込む。詳細には、何も入っていない“#pragma acc kernels”に、一つ一つループ文を入れてコンパイルして、エラーであれば、そのループ文はそもそも、GPU処理できないので、除外する。このようにして、残るループ文を検出する。そして、エラーが出ないものを、長さ(遺伝子長)とする。エラーのないループ文が5つであれば、遺伝子長は5であり、エラーのないループ文が10であれば、遺伝子長は10である。なお、並列処理できないものは、前の処理を次の処理に使うようなデータに依存がある場合である。
以上が準備段階である。次に遺伝的アルゴリズム処理を行う。
【0149】
ループ文の数に対応する遺伝子長を有するコードパターンが得られている。始めはランダムに並列処理のパターン10010、01001、00101、…などを割り当てる。遺伝的アルゴリズム処理を行い、コンパイルする。その時に、オフロードできるループ文であるにもかかわらず、エラーがでることがある。ループ文が階層になっている(どちらか指定すればGPU処理できる)場合である。この場合は、エラーとなったループ文は、残してもよい。具体的には、処理時間が多くなった形にして、タイムアウトさせる方法がある。
【0150】
検証用マシン14でデプロイして、ベンチマーク、例えば画像処理であればその画像処理でベンチマークする、その処理時間が短い程、適応度が高いと評価する。例えば、処理時間の逆数、処理時間に10秒かかる個体の適応度は1とする。処理時間に100秒かかる個体の適応度は0.1とする。処理時間に1秒かかる個体の適応度は10とする。
【0151】
オフロードサーバ1は、適応度が高いものを選択する。オフロードサーバ1は、例えば10個の個体のなかから、3~5個を選択して、それを組み替えて新しいコードパターンを作る。作成途中で、前と同じものができる場合がある。この場合、同じベンチマークを行う必要はないので、オフロードサーバ1は、前と同じ適応度のデータを使う。本実施形態のオフロードサーバ1は、コードパターンと、その処理時間を記憶部13に保存している。
【0152】
以上で、単純遺伝的アルゴリズムによる制御部11の探索イメージについて説明した。
【0153】
図8は、ループ文のメニーコアCPUへの遺伝子配列マッピングを示す図である。
コードパターン141dは、3つのループ文を含んでいる。ここで、各ループ文に対してバイナリ1桁が割り振られ、3つのループ文に対して3桁の1または0がランダムに割り当てられる。
【0154】
コードパターン141dの最初のforループ文には、ディレクティブ“#pragma omp parallel for”が付与されている。このとき、最初のforループ文は、メニーコアにオフロードするようにコンパイルされる。更に、コードパターン141dの左側には、コードパターン141dの遺伝子配列100が示されている。
【0155】
図9A図9Bは、ループ文をメニーコアCPUへオフロードするパターンの選択処理のフローチャートである。
最初、コード分析部112は、C/C++ソースコードのループ文を分析する(S90)。処理指定部114は、C/C++ソースコードのループ文、参照関係を特定する(S91)。
【0156】
処理指定部114は、ベンチマークツールを動作させて、各ループ文のループ回数を把握すると共に、各ループを閾値で振分けると(S92)、各ループ文の並列処理可能性をチェックする(S93)。
【0157】
なお、GPUでの自動オフロードで用いていたPGIコンパイラは、並列化不能時はコンパイラがエラーを出力していた。しかし、gcc等のOpenMPコンパイラはそのようなエラーはプログラマの責任となる。そこで、自動化するために、OpenMP指示句で行う処理は、ループ文をメニーコアCPUで並列処理するかどうかだけと単純化するとともに、並列処理した場合の最終計算結果が正しいかどうかのチェックも性能測定時に行うことで、正しい計算結果が出るパターンだけ進化計算の中で残る仕組みとする。
【0158】
次に処理指定部114は、並列処理可能性を有するループ文の数をカウントして遺伝子長とし(S94)、初期値として指定個体数の遺伝子配列を準備する(S95)。ここで、処理指定部114は、0と1をランダムに割り当てた遺伝子配列を所定個体数だけ作成する。
【0159】
処理指定部114は、C/C++ソースコードを、遺伝子にマッピングし、指定個体数パターンを準備する(S96)。具体的には、処理指定部114は、準備された遺伝子配列に応じて、遺伝子の値が1の場合は並列処理を指定するディレクティブをC/C++コードに挿入する(例えば図8の#pragmaディレクティブ参照)。
【0160】
制御部11は、ステップS100~S108の処理を、指定世代数だけ繰り返す。
また、指定世代数の繰り返しにおいて、さらにステップS101~S104の処理について指定個体数だけ繰り返す。すなわち、指定世代数の繰り返しの中で、指定個体数の繰り返しが入れ子状態で処理される。
【0161】
指定個体数の繰り返しにおいて、処理パターン作成部115(図1参照)は、遺伝子パターンに応じてディレクティブ指定したC/C++ソースコード、すなわち、各オフロードパターンをgccコンパイラでコンパイルする(S102)。すなわち、処理パターン作成部115は、作成したC/C++コードを、メニーコアCPUを備えた検証用マシン14上のgccコンパイラでコンパイルする。
ここで、ネストした複数のループ文を並列処理を指定する場合等でコンパイルエラーとなることがある。この場合は、性能測定時の処理時間がタイムアウトした場合と同様に扱う。
【0162】
性能測定部116(図1参照)は、メニーコアCPU搭載の検証用マシン14に、オフロードパターンをコンパイルした実行ファイル、すなわち、コンパイルしたオフロードパターンをデプロイして(S103)、配置した実行ファイルを実行し、オフロードした際のベンチマーク性能を測定する(S104)。
【0163】
ここで、途中世代で、以前と同じパターンの遺伝子については測定せず、同じ値を使う。つまり、遺伝的アルゴリズム処理の中で、以前と同じパターンの遺伝子が生じた場合は、その個体についてはコンパイルや性能測定をせず、以前と同じ測定値を用いる。
【0164】
ステップS105において、制御部11は、指定個体数の繰り返しが完了していないならば、ステップS101の処理に戻り、指定個体数を全て繰り返したならば、ステップS106に進む。
【0165】
次にステップS106で、実行ファイル作成部117(図1参照)は、処理時間が短い個体ほど適合度が高くなるように評価し、性能の高い個体を選択する。
実行ファイル作成部117(図1参照)は、各個体の計算結果とシングルコアCPUの計算結果との差を評価し、許容範囲となる個体を選択する(S107)。実行ファイル作成部117は、性能測定の際に、最終計算結果が並列処理しない場合と同じ結果であることを、オリジナルコードを通常CPUで処理した場合と比較し、もし差分が許容できない程大きい場合はそのパターンの適応度は0として次世代には選ばれないようにする。実行ファイル作成部117は、並列処理した場合の最終計算結果が正しいかどうかのチェックも性能測定時に行うことで、進化計算の中で、正しい計算結果が出るパターンに絞り込むことができる。
【0166】
実行ファイル作成部117は、選択された個体に対して、交叉、突然変異の処理を行い、次世代の個体を作成する(S108)。これは、次世代の個体に対して、コンパイル、性能測定、適合度設定、選択、交叉、突然変異処理を行うためである。
【0167】
すなわち、実行ファイル作成部117は、全個体に対して、ベンチマーク性能測定後、ベンチマーク処理時間に応じて、各遺伝子配列の適合度を設定する。実行ファイル作成部117は、設定された適合度に応じて、残す個体を選択する。そして実行ファイル作成部117は、選択された個体に対して、交叉、突然変異、そのままコピーによる遺伝的アルゴリズム処理を行い、次世代の個体群を作成する。
【0168】
ステップS109において、制御部11は、指定世代数の繰り返しが完了していないならば、ステップS100の処理に戻り、指定世代数を全て繰り返したならば、ステップS110に進む。
【0169】
ステップS110で、実行ファイル作成部117は、指定世代数の遺伝的アルゴリズム処理終了後、最高性能の遺伝子配列に該当するC/C++コード(最高性能の並列処理パターン)を解とすると、図9Bの処理を終了する。
このようにすることで、メニーコアCPUの環境が移行先であっても、ループ文を効率的に高速化可能なパターンを探索できる。
【0170】
メニーコアCPUもGPUと同様に、多数の計算コアを生かして、処理を並列化することで高速化する。GPUと異なる点は、メニーコアCPUの場合、メモリは共通であるため、GPUへのオフロードでしばしば問題となったCPUとGPUのメモリ間のデータ転送によるオーバヘッドは考慮する必要がない。また、メニーコアCPUでのプログラム処理の並列化には、OpenMP仕様が頻繁に利用される。OpenMPは、“#pragma omp parallel for”等の指示句でプログラムに対して、並列処理等を指定する仕様である。OpenMPでの処理並列化は、OpenMPプログラマが責任を持つこととなっており、並列化できない処理を並列化した場合には、コンパイラがエラー出力をするわけでなく、計算結果が誤って出力される。
【0171】
これらを踏まえ、本実施形態では、ループ文のメニーコアCPU向け自動オフロードは、ループの並列処理可否を、OpenMPにおいて“#pragma”で指定するパターンを複数作成し、検証環境で実際の性能測定を繰り返すことで、徐々に高速化していく進化計算手法を採用する。
【0172】
《実装》
オフロードサーバ1は、C/C++ソースコードを解析して、ループ文を発見するとともに、ループ文内で使われる変数データ、その変数の処理等の、プログラム構造を把握する。
【0173】
並列処理自体が不可なループ文は排除する必要があるため、オフロードサーバ1は、各ループ文に対して、GPUで処理するディレクティブ挿入を試行し、エラーが出るループ文は遺伝的アルゴリズムの対象外とする。ここで、エラーが出ないループ文の数が遺伝子長となる。
【0174】
次に、オフロードサーバ1は、初期値として、指定個体数の遺伝子配列を準備する。遺伝子の各値は、0と1をランダムに割当てて作成する。オフロードサーバ1は、準備された遺伝子配列に応じて、遺伝子の値が1の場合はGPUやメニーコアCPU処理を指定するディレクティブをC/C++コードに挿入する。
【0175】
オフロードサーバ1は、ディレクティブを挿入されたC/C++コードをgccでコンパイルし、コンパイルした実行ファイルをデプロイして性能を測定する。性能測定において、オフロードサーバ1は、処理時間とともに、例えば、PGIコンパイラのPCAST機能を用いて並列処理した場合の計算結果が、元のコードと大きく差分がないかチェックし、許容外の場合は、適応度を0とする。
【0176】
オフロードサーバ1は、全個体に対して、性能測定後、処理時間に応じて、各個体の適合度を設定する。設定された適合度に応じて、残す個体を選択する。選択された個体に対して、交叉、突然変異、そのままコピーによる遺伝的アルゴリズム処理を行い、次世代の個体群を作成する。
【0177】
オフロードサーバ1は、次世代の個体に対して更に、指示挿入、コンパイル、性能測定、適合度設定、選択、交叉、突然変異処理を行い、これを指定された世代数だけ繰り返す。指定世代数の遺伝的アルゴリズム処理終了後、オフロードサーバ1は、最高性能の遺伝子配列に該当する、ディレクティブ付きC/C++コードを解とする。
【0178】
図10は、ループ文のGPUへの遺伝子配列マッピングを示す図である。
コードパターン141eの最初のforループ文には、“#pragma acc kernels”が付与されている。このとき、最初のforループ文は、GPUにオフロードするようにコンパイルされる。更に、コードパターン141eの左側には、コードパターン141eの遺伝子配列100が示されている。
【0179】
図11A図11Bは、ループ文をGPUへオフロードするパターンの選択処理のフローチャートである。この選択処理は、非特許文献2の手法を用いている。
オフロードサーバ1は、C/C++向けOpenACCコンパイラを用いて以下の処理を行う。
【0180】
コード分析部112(図1参照)は、C/C++ソースコードのコード解析によりループ文を分析する(S120)。そして、処理指定部114(図1参照)は、C/C++ソースコードのループ文とその参照関係を特定すると(S121)、ベンチマークツールを動作させ、各ループ文のループ回数を把握し、閾値で振分ける(S122)。そして、処理指定部114は、各ループ文の並列処理可能性をチェックする(S123)。
【0181】
次に制御部11は、ステップS124~S127の処理を、ループ文の数だけ繰り返す。
処理指定部114は、各ループ文に対して並列処理を指定してコンパイルする(S125)。図10に示すように、OpenACCにおける並列処理の指定は、“#pragma acc kernels”である。
コンパイルのエラー時に処理指定部114は、並列処理の指定を削除し、当該ループ文をオフロード対象から除外する(S126)。そして制御部11は、全てのループ文について処理を繰り返したならば、ステップS128に進む。
【0182】
処理指定部114は、コンパイルエラーが出ないループ文の数をカウントして遺伝子長とすると(S128)、指定個体数の遺伝子配列を準備する。ここでは、初期値として0と1をランダムに割り当てた指定個体数の遺伝子配列を作成する。次に処理指定部114は、C/C++ソースコードを、遺伝子にマッピングして、指定個体数のパターンを準備する(S129)。具体的にいうと、処理指定部114は、準備された遺伝子配列に応じて、遺伝子の値が1の場合は並列処理を指定するディレクティブをC/C++コードに挿入する(例えば図10の#pragmaディレクティブ参照)。
【0183】
制御部11は、ステップS130~S137の処理を、指定世代数だけ繰り返す。
また、指定世代数の繰り返しにおいて、さらにステップS131~S134の処理について指定個体数だけ繰り返す。すなわち、指定世代数の繰り返しの中で、指定個体数の繰り返しが入れ子状態で処理される。
【0184】
指定個体数の繰り返しにおいて、処理パターン作成部115(図1参照)は、遺伝子パターンに応じてディレクティブ指定したC/C++ソースコード、すなわち各オフロードパターンをPGIコンパイラでコンパイルする(S132)。すなわち、処理パターン作成部115は、作成したC/C++コードを、GPUを備えた検証用マシン14上のPGIコンパイラでコンパイルを行う。
ここで、ネストループ文を複数並列指定する場合等でコンパイルエラーとなることがある。この場合は、性能測定時の処理時間がタイムアウトした場合と同様に扱う。
【0185】
性能測定部116(図1参照)は、CPUとGPUを搭載した検証用マシン14に、オフロードパターンをコンパイルした実行ファイル、すなわちコンパイルしたオフロードパターンをデプロイし(S133)、配置した実行ファイルを実行し、オフロードした際のベンチマーク性能を測定する(S134)。
【0186】
ここで、途中世代で、以前と同じパターンの遺伝子については測定せず、同じ値を使う。つまり、遺伝的アルゴリズム処理の中で、以前と同じパターンの遺伝子が生じた場合は、その個体についてはコンパイルや性能測定をせず、以前と同じ測定値を用いる。
【0187】
ステップS135において、制御部11は、指定個体数の繰り返しが完了していないならば、ステップS131の処理に戻り、指定個体数を全て繰り返したならば、ステップS136に進む。
【0188】
ステップS136で、実行ファイル作成部117(図1参照)は、処理時間が短い個体ほど適合度が高くなるように評価し、性能の高い個体を選択する。そして実行ファイル作成部117は、選択された個体に対して、交叉、突然変異の処理を行い、次世代の個体を作成する(S137)。これは、次世代の個体に対して、コンパイル、性能測定、適合度設定、選択、交叉、突然変異処理を行うためである。
すなわち、実行ファイル作成部117は、全個体に対して、ベンチマーク性能測定後、ベンチマーク処理時間に応じて、各遺伝子配列の適合度を設定する。そして実行ファイル作成部117は、設定された適合度に応じて、残す個体を選択する。そして実行ファイル作成部117は、選択された個体に対して、交叉、突然変異、そのままコピーの遺伝的アルゴリズム処理を行い、次世代の個体群を作成する。
【0189】
ステップS138において、制御部11は、指定世代数の繰り返しが完了していないならば、ステップS130の処理に戻り、指定世代数を全て繰り返したならば、ステップS139に進む。
【0190】
指定世代数の遺伝的アルゴリズム処理終了後のステップS139において、実行ファイル作成部117は、最高性能の遺伝子配列に該当するC/C++コード(最高性能の並列処理パターン)を解として、図11Bの処理を終了する。
【0191】
基本的な課題として、コンパイラがこのループ文はGPUで並列処理できないという制限を見つけることは可能だが、このループ文はGPUの並列処理に適しているという適合性を見つけることは難しい。
【0192】
一般的にループ回数が多い等のループの方が、GPUオフロードに適していると言われるが、実際にGPUにオフロードすることでどの程度の性能になるかは、実測なしに予測は困難である。そのため、このループをGPUにオフロードするという指示を手作業で行い、性能測定を試行錯誤することが頻繁に行われている。
【0193】
非特許文献2では、GPUにオフロードする適切なループ文の発見を、進化計算手法の一つである遺伝的アルゴリズムで自動的に行うことを提案している。GPU処理を想定していない通常CPU向け汎用プログラムから、最初に並列可能ループ文のチェックを行い、次に並列可能ループ文群に対して、GPU実行の際を1、CPU実行の際を0と値を置いて遺伝子化して、検証環境で性能検証を反復し適切な領域を探索している。
【0194】
並列可能ループ文に絞った上で、遺伝子の部分の形で、高速化可能な並列処理パターンを保持し組み換えていくことで、取り得る膨大な並列処理パターンから、効率的に高速化可能なパターンを探索している。
【0195】
非特許文献2では、ループ文の適切な抽出に加えて、ネストループ文の中で利用される変数について、ループ文をGPUにオフロードする際に、ネストの下位でCPU-GPU転送が行われると下位のループの度に転送が行われ効率的でないため、上位でCPU-GPU転送が行われても問題ない変数については、上位でまとめて転送を行うことを提案している。
ループ文のGPU自動オフロードについては、進化計算手法を用いた最適化と、CPU-GPU転送の低減により、自動でのオフロードを可能としている。
【0196】
図12A図12Bは、ループ文をFPGAへオフロードするパターンの選択処理のフローチャートである。この選択処理は、非特許文献3の手法を用いている。
最初、コード分析部112は、オフロードしたいソースコードを分析し(S150)、ソースコードの言語に合わせて、ループ文や変数の情報を分析する。
【0197】
そして、オフロード範囲抽出部114aは、ソースコードのループ文および参照関係を特定すると(S151)、特定したループ文に対して、FPGAオフロードを試行するかどうか候補を絞る。ループ文に対してオフロード効果があるかどうかは、算術強度が一つの指標となる。
【0198】
オフロード範囲抽出部114aは、算術強度分析ツールを用いてアプリケーションのループ文の算術強度を算出する(S152)。算術強度は、計算数が多いと増加し、アクセス数が多いと減少する指標である。算術強度が高い処理は、プロセッサにとって重い処理となる。そこで、オフロード範囲抽出部114aは、算術強度分析ツールでループ文の算術強度を分析し、算術強度が高いループ文をオフロード候補に絞る。
【0199】
高算術強度のループ文であっても、それをFPGAで処理する際に、FPGAリソースを過度に消費してしまうのは問題である。そこで、ここでは、高算術強度ループ文をFPGA処理する際のリソース量の算出について述べる。
【0200】
FPGAにコンパイルする際の処理としては、OpenCL等の高位言語からハードウェア記述のHDL等のレベルに変換され、それに基づき実際の配線処理等がされる。この時、配線処理等は多大な時間がかかるが、HDL等の途中状態の段階までは時間は分単位でしかかからない。HDL等の途中状態の段階であっても、FPGAで利用するFlip FlopやLook Up Table等のリソースは分かる。このため、HDL等の途中状態の段階をみれば、利用するリソース量はコンパイルが終わらずとも短時間でわかる。
【0201】
そこで、本実施形態では、処理パターン作成部115は、対象のループ文をOpenCL等の高位言語化し、まずリソース量を算出する。また、ループ文をオフロードした際の算術強度とリソース量が決まるため、算術強度/リソース量または算術強度×ループ回数/リソース量をリソース効率とする。そして、高リソース効率のループ文をオフロード候補として更に絞り込む。
【0202】
図12Aのフローに戻って説明を続ける。処理パターン作成部115は、gcov、gprof等のプロファイリングツールを用いてアプリケーションのループ文のループ回数を測定し(S153)、ループ文のうち、高算術強度で高ループ回数のループ文を絞り込む(S154)。
【0203】
処理パターン作成部115は、絞り込まれた各ループ文をFPGAにオフロードするためのOpenCLを作成する(S155)。
【0204】
ここで、ループ文のOpenCL化について、補足して説明する。すなわち、ループ文をOpenCL等によって、高位言語化する際には、2つの処理が必要である。一つは、CPU処理のプログラムを、カーネル(FPGA)とホスト(CPU)に、OpenCL等の高位言語の文法に従って分割することである。もう一つは、分割する際に、高速化するための技法を盛り込むことである。一般に、FPGAを用いて高速化するためには、ローカルメモリキャッシュ、ストリーム処理、複数インスタンス化、ループ文の展開処理、ネストループ文の統合、メモリインターリーブ等がある。これらは、ループ文によっては、絶対効果があるわけではないが、高速化するための手法として、よく利用されている。
【0205】
次に、高リソース効率のループ文が幾つか選択されたので、それらを用いて性能を実測するオフロードパターンを実測する数だけ作成する。FPGAでの高速化は、1個の処理だけFPGAリソース量を集中的にかけて高速化する形もあれば、複数の処理にFPGAリソースを分散して高速化する形もある。オフロードサーバ1は、選択された単ループ文のパターンを一定数作り、FPGA実機で動作する前段階としてプレコンパイルする。
【0206】
処理パターン作成部115は、作成したOpenCLをプレコンパイルして利用するリソース量を算出し(S156)、高リソース効率のループ文を絞り込む(S157)。
【0207】
そして、実行ファイル作成部117は、絞り込んだループ文をオフロードするためのOpenCLをコンパイルする(S158)。性能測定部116は、コンパイルされたプログラムの性能を測定する(S159)。これは、1回目の性能測定である。
【0208】
処理パターン作成部115は、性能測定された中でCPUに比べ高性能化されたループ文をリスト化し(S160)、リストのループ文を組み合わせてオフロードするOpenCLを作成する(S161)。処理パターン作成部115は、組み合わせたオフロードOpenCLでプレコンパイルして利用するリソース量を算出する(S162)。これは、2回目のリソース量の算出である。なお、処理パターン作成部115は、プレコンパイルせず、1回目測定前のプレコンパイルでのリソース量の和でもよい。このようにすれば、プレコンパイル回数を削減することができる。
【0209】
実行ファイル作成部117は、組み合わせたオフロードOpenCLをコンパイルする(S163)。性能測定部116は、コンパイルされたプログラムの性能を測定する(S164)。これは、2回目の性能測定である。
【0210】
本番環境配置部118は、1回目と2回目の測定の中で最高性能のパターンを選択して(S165)、本フローの処理を終了する。
【0211】
このように、ループ文のFPGA自動オフロードは、算術強度とループ回数が高くリソース効率が高いループ文に絞って、オフロードパターンを作り、検証環境で実測を通じて高速なパターンの探索を行う。
【0212】
FPGAで、処理時間が長時間かかる特定のループ文をFPGAにオフロードして高速化することを考えた際に、どのループをオフロードすれば高速になるかの予測は難しいため、GPUと同様に検証環境で性能測定を自動で行うことを提案している。しかし、FPGAは、OpenCLをコンパイルして実機で動作させるまでに数時間以上かかるため、GPU自動オフロードでの遺伝的アルゴリズムを用いて何回も反復して性能測定することは、処理時間が膨大となり現実的ではない。
【0213】
そこで、本実施形態では、FPGAにオフロードする候補のループ文を絞ってから、性能測定試行を行う形をとる。具体的には、まず、発見されたループ文に対して、ROSEフレームワーク等の算術強度分析ツールを用いて算術強度が高いループ文を抽出する。更に、gcovやgprof等のプロファイリングツールを用いてループ回数が多いループ文も抽出する。
【0214】
そして、算術強度やループ回数が多いループ文を候補として、OpenCL化を行う。算術強度やループ回数が多いオフロード候補ループ文に対して、作成したOpenCLをプレコンパイルして、リソース効率が高いループ文を見つける。これは、コンパイルの途中で、作成するFlip FlopやLook Up Table等のリソースは分かるため、利用するリソース量が少ないループ文に更に絞り込む。
【0215】
ループ文が幾つか選択されたため、それらを用いて性能を実測する。FPGAでの高速化は、1個の処理だけFPGAリソース量を集中的にかけて高速化する形もあれば、複数の処理にFPGAリソースを分散して高速化する形もある。そこで、選択された単ループ文に対してFPGA実機で動作するようコンパイルして性能測定し、更に高速化できた単ループ文に対してはその組み合わせのパターンも作り、2回目の性能測定をする。オフロードサーバ1は、検証環境で性能測定された複数パターンの中で、最高速のパターンを解として選択する。
【0216】
ループ文のFPGA自動オフロードについては、算術強度やループ回数、リソース量を用いて候補ループ文を絞り込んでから、検証環境での複数パターン性能測定を行い、自動でのオフロードを可能としている。
【0217】
《実装》
オフロードサーバ1は、C/C++ソースコードを解析して、ループ文を発見するとともに、ループ文内で使われる変数データ等の、プログラム構造を把握する。
次に、オフロードサーバ1は、ROSEを実行して、各ループ文の算術強度を取得し、gcovを用いて、各ループ文のループ回数を取得する。
【0218】
次に、オフロードサーバ1は、高算術強度、高ループ回数の個々のループ文をFPGAにオフロードするOpenCLコードを生成する。OpenCLコードは当該ループ文をFPGAカーネルとして、残りをCPUホストプログラムとして分割したものである。
【0219】
次に、オフロードサーバ1は、作成したOpenCLコードに対してプレコンパイルをして、利用するFlip Flop等のリソース量を算出する。使用リソース量は全体リソース量の割合で表示される。ここでオフロードサーバ1は、算術強度、ループ回数とリソース量から、高算術強度、高ループ回数かつ低リソース量(高リソース効率)のループ文を選定する。
【0220】
次に、オフロードサーバ1は、選定したループ文を候補に、実測するパターンを作り、コンパイルする。オフロードサーバ1は、選定されたループ文一つずつに対してオフロードした場合の性能測定をして高速化できるかを確認する。その結果、複数が高速化できた場合、オフロードサーバ1は、その組み合わせのOpenCLも作成して性能測定を行い、単体よりも高速化できるか確認する。ただし、FPGAはリソース量が限られるため、オフロードサーバ1は、複数オフロード時にリソース量が上限値に収まらない場合は作成しない。
最後に、オフロードサーバ1は、複数の測定パターンから高速なパターンを解として選択する。
【0221】
《本発明の原出願とその作用効果》
請求項1に記載の発明では、ソフトウェアプログラムのソースコードがアクセラレータによる実行が可能な機能ブロックを含むか否かを分析するコード分析部と、前記機能ブロックを前記アクセラレータにオフロードするパターンを作成する処理パターン作成部と、前記機能ブロックをオフロードする各前記パターンを検証環境にデプロイして性能を測定する性能測定部と、前記性能測定部が測定した性能が所望のものであった場合、前記処理パターン作成部により、前記ソフトウェアプログラムのうち、前記機能ブロックを除く残りのループ文をオフロードするパターンを作成して、前記性能測定部により、各前記パターンを前記検証環境にデプロイして性能を測定し、前記性能測定部が測定した性能が所望のものでなかった場合、前記処理パターン作成部により、前記ソフトウェアプログラムのループ文をオフロードするパターンを作成して、前記性能測定部により、各前記パターンを前記検証環境にデプロイして性能を測定する制御部と、を備えることを特徴とするオフロードサーバとした。
【0222】
このようにすることで、複数種類のアクセラレータが混在する環境が移行先であっても、自動で高性能化できる。更に移行先が同一ノードに複数種類のアクセラレータを持つ場合は、複数種類のアクセラレータに対して同時にオフロードすることで、単一アクセラレータの利用の場合よりも高速なオフロードを実現する。
【0223】
請求項2に記載の発明では、前記アクセラレータは複数種類であり、前記制御部は、各前記アクセラレータにオフロードするパターンのうち、最も高速なものを選択する、ことを特徴とする請求項1に記載のオフロードサーバとした。
【0224】
このようにすることで、複数種類のアクセラレータが混在する環境が移行先であっても、自動で高性能化できる。
【0225】
請求項3に記載の発明では、前記制御部は、前記アクセラレータへのオフロード対象として前記機能ブロックの試行の次に前記ループ文を試行し、前記機能ブロックまたは/および前記ループ文のオフロード先の前記アクセラレータとして、メニーコアCPU、GPU、FPGAの順に試行する、ことを特徴とする請求項1または2に記載のオフロードサーバとした。
【0226】
このようにすることで、複数種類のアクセラレータが混在する環境に対して、効率的に高速化可能なパターンを探索できる。
【0227】
請求項4に記載の発明では、前記制御部は、前記機能ブロックまたは前記ループ文のオフロードにおいて、元の処理よりも高速なパターンが複数のアクセラレータに対して見つかり、かつ同じ機能ブロックまたはループ文が前記複数のアクセラレータにオフロードできる場合、より性能が高くなるアクセラレータをオフロード先とし、異なる機能ブロックまたは異なるループ文が異なるアクセラレータにオフロードでき,かつ同一ノードのアクセラレータにオフロードできない場合、より性能が高くなるアクセラレータをオフロード先とし、異なる機能ブロックまたは異なるループ文が異なるアクセラレータにオフロードでき,かつ同一ノードのアクセラレータにオフロードできる場合、前記機能ブロックまたは前記ループ文のオフロード先をそれぞれ異なるアクセラレータとする、ことを特徴とする請求項1に記載のオフロードサーバとした。
【0228】
このようにすることで、複数種類のアクセラレータが混在する環境に対して、機能ブロックまたはループ文を効率的に高速化可能なパターンを探索できる。
【0229】
請求項5に記載の発明では、前記制御部は、前記機能ブロックと前記ループ文のオフロードにおいて、前記ループ文のオフロード先が,前記機能ブロックのオフロード先とは別ノードとなる場合,ループ文のオフロードによる性能の向上が前記機能ブロックのオフロードによる性能向上以下ならば、前記ループ文をオフロードするパターンを試行せず、かつ前記機能ブロックをオフロードするパターンを試行し、前記ループ文のオフロードによる性能の向上が前記機能ブロックのオフロードによる性能向上を超えたならば、前記機能ブロックをオフロードするパターンを試行せず、かつ前記ループ文をオフロードするパターンを試行し、前記ループ文のオフロード先が前記機能ブロックのオフロード先と同一ノードとなる場合,前記機能ブロックと前記ループ文とをオフロードしたパターンを試行する、ことを特徴とする請求項1に記載のオフロードサーバとした。
【0230】
このようにすることで、複数種類のアクセラレータが混在する環境に対して、機能ブロックまたはループ文を効率的に高速化可能なパターンを探索できる。
【0231】
請求項6に記載の発明では、ソフトウェアプログラムのソースコードが、メニーコアCPUによる実行が可能なループ文を含むか否かを分析するコード分析部と、前記ループ文を前記メニーコアCPUにオフロードするパターンを作成する処理パターン作成部と、各前記ループ文を遺伝子パターンにマッピングし、各前記ループ文をオフロードする各前記パターンを検証環境にデプロイして性能を測定し、高い性能を高い適応度に設定して、次世代のパターンを遺伝的アルゴリズムのエリート選択,交叉,突然変異の処理により作成することを繰り返す性能測定部と、を備え、前記性能測定部は、前記検証環境での性能の測定において、前記メニーコアCPUが処理した場合の計算結果と、元の処理の計算結果を比較し、前記メニーコアCPUが処理した場合の計算結果の誤差が許容閾値を超える場合、遺伝子パターンの適応度を低く設定する、ことを特徴とするオフロードサーバとした。
【0232】
このようにすることで、メニーコアCPUの環境が移行先であっても、ループ文を効率的に高速化可能なパターンを探索できる。
【0233】
請求項7に記載の発明では、コード分析部が、ソフトウェアプログラムのソースコードがアクセラレータによる実行が可能な機能ブロックを含むか否かを分析するステップと、処理パターン作成部が、前記機能ブロックを前記アクセラレータにオフロードするパターンを作成するステップと、性能測定部が、前記機能ブロックをオフロードする各前記パターンを検証環境にデプロイして性能を測定するステップと、を実行し、前記性能測定部が測定した性能が所望のものであった場合、前記処理パターン作成部が、前記ソフトウェアプログラムのうち、前記機能ブロックを除く残りのループ文をオフロードするパターンを作成するステップと、前記性能測定部が、各前記パターンを前記検証環境にデプロイして性能を測定するステップと、を実行し、前記性能測定部が測定した性能が所望のものでなかった場合、前記処理パターン作成部が、前記ソフトウェアプログラムのループ文をオフロードするパターンを作成するステップと、前記性能測定部が、各前記パターンを前記検証環境にデプロイして性能を測定するステップと、を実行する、ことを特徴とするオフロード制御方法とした。
【0234】
このようにすることで、複数種類のアクセラレータが混在する環境が移行先であっても、自動で高性能化できる。更に移行先が同一ノードに複数種類のアクセラレータを持つ場合は、複数種類のアクセラレータに対して同時にオフロードすることで、単一アクセラレータの利用の場合よりも高速なオフロードを実現する。
【0235】
請求項8に記載の発明では、コンピュータに、ソフトウェアプログラムのソースコードがアクセラレータによる実行が可能な機能ブロックを含むか否かを分析させる手順、前記機能ブロックを前記アクセラレータにオフロードするパターンを作成させる手順、前記機能ブロックをオフロードする各前記パターンを検証環境にデプロイして性能を測定させる手順、測定した性能が所望のものであった場合、前記ソフトウェアプログラムのうち、前記機能ブロックを除く残りのループ文をオフロードするパターンを作成させ、各前記パターンを前記検証環境にデプロイして性能を測定させる手順、測定した性能が所望のものでなかった場合、前記ソフトウェアプログラムのループ文をオフロードするパターンを作成させ、各前記パターンを前記検証環境にデプロイして性能を測定させる手順、を実行させるためのオフロードプログラムとした。
【0236】
このようにすることで、複数種類のアクセラレータが混在する環境が移行先であっても、自動で高性能化できる。更に移行先が同一ノードに複数種類のアクセラレータを持つ場合は、複数種類のアクセラレータに対して同時にオフロードすることで、単一アクセラレータの利用の場合よりも高速なオフロードを実現する。
【符号の説明】
【0237】
1 オフロードサーバ
2 クラウドレイヤ
3 ネットワークレイヤ
4 デバイスレイヤ
10 ゲートウェイ
20 ネットワークエッジ
30 データセンタ
11 制御部
12 入出力部
13 記憶部
14 検証用マシン
15 リソース
111 コード指定部
112 コード分析部
114 処理指定部
114a オフロード範囲抽出部
114b 中間言語ファイル出力部
115 処理パターン作成部
116 性能測定部
116a 実行ファイル配置部
117 実行ファイル作成部
118 本番環境配置部
119 性能測定テスト抽出実行部
120 ユーザ提供部
130 ソースコード
131 テストケースデータベース
132 中間言語ファイル
133 コードパターンデータベース
141,142 コードパターン
151~154 装置
80 通信網
900 コンピュータ
910 CPU
920 RAM
930 ROM
940 HDD
950 通信インタフェース
960 入出力インタフェース
970 メディアインタフェース
980 記録媒体
図1
図2
図3A
図3B
図3C
図4A
図4B
図5A
図5B
図6
図7
図8
図9A
図9B
図10
図11A
図11B
図12A
図12B