OpenFOAM ソースコードの探索・デバッグ on DEXCS2014

最近、あるソルバーの動作を調べてもらいたいという注文があったので、久しぶりにコード検索・デバッグツールを使ってみようと思い立ちました。

しかし、数年前に使ったきりで、その当時からお世話になったPENGUINITISさんのサイトには今でも紹介されているんですが、情報が少々古くなってきており、この最新の環境だと、昔の方法がそのまま使えない事項もあったので、ここにDEXCS2014(OpenFOAM-2.3.x on ubuntu-14.04)の場合、どうであったかを取りまとめておくこととしました。

なお、ここで取り扱うのは、本家のWikiページ(HowTo debugging)にあるような、コマンドライン入力でgdbなんかを使ってシコシコやるっていうのではなく、あくまでGUIツールを使ってやる方法です。

 

GUIデバッグツール

これまでに使用したことのあるデバッグツールは以下の3つです。

  • NetBeans
  • KDbg
  • Eclipse

ソースコードを静的に探索するならNetBeans、動的というかステップ実行したり、変数の内容を確認したりの、いわゆるデバッグするにはKDbgがお手軽に使える反面、これらのツールで両方共出来るということはない。片やEclipseではどちらも出来るのだが、設定が面倒だし重いとかあって、お手軽でないという、どれも一長一短あって、用途に応じて使い分けるしかないのかなぁ・・・というのがこれまでの個人的な結論でありました。

そこで、それぞれのツールについて、DEXCS2014で動かす方法とその結果について以下に記しておきます。

 

NetBeans

現時点での最新版 IDE 8.02が使えました。PENGUINITISさんのサイトでは、IDE 7.2 for OF-2.1.1 の説明で、当時は日本語表示がうまく使えなかったようですが、現在は問題なく使えます。言語設定(LANG=…)の必要はありません(英語で使いたい人は別ですが)。また、富山勉強会のサイトにも、NetBeans設定方法(IDE 7.4 for OF-2.2.2)について取りまとめられており、基本的にはこれらの方法と同じで大丈夫でした。

範囲を選択_016

ソースファイル一式を丸ごと解析するので、最初はちょっと時間がかかりますが、解析が終われば、上の図に示すような感じで、キーワードの上でマウス右クリックを使って、さほどストレスなくコードの中味をたどることが出来るようになります。

範囲を選択_015

但し、上の図の例でいうと、ソース行番号の欄で、何やらマークが付けられた行、

turbulence->correct();

は、ライブラリの中味まではたどることが出来ないということです。ただ、ここは後で述べるEclipseのようにコンパイル環境の設定までは実施していないのがそもそもの原因なので、そこが出来ていれば多分可能なんでしょう。そのやり方が判れば・・・なんですがね。(判りました⇒追記参照)

 

KDbg

残念ながら、KDbgはDEXCS2014上では動きませんでした。Synapticパッケージマネージャからはインストール出来るようになっていたのですが、インストール出来はしたものの、実行しようとするとSegmentation fault です。そもそもランチャー用のアイコンも実体がありませんでした。

ソースコードからインストールする方法も試してみましたが、KDEのヘッダーが何チャラというエラーメッセージで、要するにちゃんとしたKDE環境でないと動かないということらしい。多分、ubuntu系なら、Kubuntuを使えということなんでしょう。

とはいうものの、DEXCS2013(OS は、mint 13、実質ubuntu-12.04)の古い環境で、OpenFOAM-2.3.1(注)を動かすことは出来たので、ここで他のツールとの比較という観点から、ちょっとだけ紹介。

(注)本当は、OpenFOAM-2.3.xを調べたかったのですが、拙宅マシン(mint 13 / ubuntu-12.04)で、DEXCS2014公開当時の2.3.xはコンパイル出来ていたのですが、拙宅マシンに当時の版は残っておらず、更新した最新版2.3.xは、不完全なコンパイルしか出来なくなってしまっていたので、2.3.1で検証しました。

基本的には、PENGUINITISさんのサイト記載してある方法でインストールから、ブレークポイントを設定したり、ステップ実行が出来るようになります。

そこで、たとえばNetBeansの静的な解析でたどれなかった箇所にブレークポイントを置いてデバッグを「実行」すると、その箇所で待ち状態になってくれます。

範囲を選択_018

 

ここで「ステップ イントゥ」を何回か(この場合は4回)押すと…

範囲を選択_019となって、所望のライブラリファイル(この例ではkEpsilonを使っているので、kEpsilon.C)にたどり着くことが出来るという次第です。

チャチャッと調べるには、このツールがなかなか便利なだけに、DEXCS2014で使えないのが残念です。

 

Eclipse

はっきり言って、これはややこしい。

「openfoam eclipse debug 」あたりでググっても、拙作記事が結構上位に出てくるくらいで、本家の方にも新しい情報がない。結局、この拙作記事からたどれる、これまた拙作のインストール方法やら、使用(コンパイルから実行までの)方法やらを頼りに、ほぼ同じ方法で、DEXCS2014に環境構築するところまでは出来ました。

範囲を選択_020

コードを検索するあたりは、Ctrlキーを押しながらマウスクリックで、範囲を選択_021

簡単にたどれるようにはなる。

また、Eclipseの上でコンパイルする方法も判っていたので、これも同じやり方(といってもかなり試行錯誤でやり直したが)でなんとかコンパイル出来るようにはなった。

範囲を選択_022

ただこの時点でも、ライブラリの中味までたどれないのはNetBeansと同じです。

次にデバッグ用のケースファイルを作成してデバッグを実行しますが、設定を間違えていなければ、次のメッセージ画面が現れます。

範囲を選択_023

問題は、これが出てくるまでに、異常に長い時間(数分というオーダー)がかかってしまう事でした。2回目以降はそうでもないようですが。

範囲を選択_024

何はともあれ、デバッグが開始されれば、KDbgと同じように、ブレークポイントを設定⇒Step Into(F5) で、所望のライブラリまでたどり着くことは出来ました。

 

なお、以前の方法と「ほぼ同じ」やり方と記しましたが、違う点はgdbをインストールし直す点です。以前の方法では、標準のgdbをアンインストールして、古いヴァージョン(gdb-6.8)を入れ直す必要がありました。今回もそれを試みましたが、残念ながら出来ませんでした。コンパイルすると…

In file included from amd64-linux-nat.c:26:0:
linux-nat.h:63:18: error: field ‘siginfo’ has incomplete type
struct siginfo siginfo;
^
make[2]: *** [amd64-linux-nat.o] エラー 1

というエラーで、ググったところ、それらしい情報もいくつか見かけましたけど、解決策には到らずでした。

デバッガーが起動するまでにやたら時間がかかるのはこのことが原因なのかもしれません。ここ(gdbを入れ直すところ)はスキップ、もしくは最新版を入れ直すなどもやってみて、違いがあるような、無いような・・・よく判りません。

 

まぁ、とりあえず動くようになって、今回調べたいコードの探索も出来るようにはなっており、これ以上時間をかけるのは本筋ではないので、これにて調査終了としました。

 

追記(2015/1/30)

NetBeansでデバッグまでは出来ていないと記しましたが、本記事を見たFaceBookの読者さん(富山県立大の中川慎二先生)から情報を頂きました。

範囲を選択_025

情報はこちら(⇒ http://eddy.pu-toyama.ac.jp/bb7e59f23-126/#_126

早速確認させていただきました。

範囲を選択_017やはり、コンパイルのやり方にひと工夫(wmakeを変更)が必要だったようですが、出来てしまえば、あとは簡単でした。

英語メニューでの解説を日本語メニューで読み替えるのに少し戸惑いましたが、Eclipseに比べるとメニューがそれほど込み入っておらず、メニュー探しに手間取ったり、間違えたりすることは断然少なく済みそうです。

安定性の面では、もう少し使い込まないことにはわかりませんが、これもEclipseとの比較でOKなら、Eclipseは不要になりますね。

 

 

 

NetBeans on DEXCS2013 for OpenFOAM

範囲を選択_410

先月のオープンCAE勉強会@富山にて紹介のあったNetBeansですが、その後調べたら、DEXCSでごく簡単に(しかも日本語版で)インストールが出来て、しかも結構サクサクとソースコードをたどる事ができることが判ったのでここに紹介します。

インストール

ダウンロードはここから、C/C++用をダウンロードする。 ⇒ netbeans-7.4-cpp-linux.sh

これを適当な場所(下記例ではデスクトップ上)に置いて、端末を起動、その場所へ移動(cd)して、

範囲を選択_385

> sh netbeans-7.4-cpp-linux.sh

を実行。インストーラが立ち上がるので、あとは、基本的に順番にボタンを押していくだけ。

範囲を選択_386

 

色んなモジュールをダウンロードしたりしながらインストールするので、場合によっては時間がかかります。自分の環境では、数分かかりました。

範囲を選択_387

NetBeansの起動

インストールが完了すれば、デスクトップ上にランチャーアイコンが出来るので、それをダブルクリックするだけです。

範囲を選択_388

 OpenFOAMソースコード検索の為のセットアップ作業

OpenFOAMのルートフォルダに、Makefileという空ファイルを作成しておく。

範囲を選択_412

 

NetBeansのメニューから、

範囲を選択_390

 

 

    • ファイル⇒新規プロジェクト を選択

範囲を選択_391

 

 

 

 

 

 

    • カテゴリ⇒C/C++
    • プロジェクト⇒既存のソースを参照する を選択
    • 次> ボタンを押す。

範囲を選択_393

 

 

    • 参照ボタンを押して、Makefileを設置したフォルダを指定
    • 構成モード選択⇒カスタム
    • 次>ボタンを押す

 

 

範囲を選択_394

 

 

    • 終了時に消去してビルドのチェックマークを外す
    • 次>ボタンを押す

 

範囲を選択_395

 

 

 

 

 

 

 

  • 次>ボタンを押す

 

範囲を選択_396

 

 

 

 

 

  • 次>ボタンを押す

範囲を選択_397

 

 

 

 

 

 

  • 次>ボタンを押す

 

範囲を選択_398

 

 

 

 

 

  • 終了ボタンを押す

 

 

 

以下、画面下のプログレスバーが動いて、ソースコードを解析中であることを教えてくれる。範囲を選択_402

解析が完了するまでにはしばらく時間がかかる。自分のマシンでは5分程度かかった。この時間は、マシンのリソースに強く依存するだろう。参考に、システム・モニタの稼働状況をお見せしておく。メモリは2GB以上、確保しておく必要がありそう。

範囲を選択_404

ソースコードの探索

解析が終わったら、左上ウィンドウのフォルダーツリーを展開して、調べたいソルバーのメインプログラム(下の図では、laplacianFoam.C)をダブルクリックする。

範囲を選択_407

 

ソースコードが開く

範囲を選択_408

 

調べたいキーワードの上にマウスカーソルを置いて、Ctrlキーを押すと、参照先などが表示される。

範囲を選択_409

 

引き続きマウス左ボタンをクリックすると、キーワードを定義したプログラム(simpleControl.H)が開いて、該当箇所にカーソルが移動する。

範囲を選択_410というように、どんどんソースコードの奥深くまで入っていくことができるようです。

 

その他参考情報

OpenFOAMのソースコード探索には色んな方法があって、有名なPENGUINITISさんのOpenFOAMに関する情報HPに詳しくまとめられています。

ここに書いた方法も、そこにあったNetBeansに関する情報の焼き直し版で、そこにも書いてあったように、ソースコードを探索するだけで、デバッグまでは出来ません。

一方、意図的なコード探索は出来ないが、プログラムの実行時デバッグが出来てその過程(ステップ実行など)で結果的にソースコードをたどることが出来るツールとして、KDbgというのがあって、これもサクサク動いてくれます。インストールは普通にパッケージマネージャで出来るし、設定方法も同じくPENGUNITISさんの情報ページに書かれており簡単です。冒頭に記した富山の勉強会にて、デモンストレーションもさせていただきました。

意図的なコード探索も出来てデバッグも出来るとなると、eclipseを使うことになり、DEXCS2011(OpenFOAM-2.0.x)でのインストールや使用方法は、以下のページにまとめてあります。最新版(DEXCS2013/OpenFOAM-2.2.x)についても同様に出来るとは思いますが、やってみないと判らないこともあるだろうし、NetBeansやKDbgがサクサク動くという面ではやや劣る感があります。

WordPress Eclipse 上で、OpenFOAM をデバッグする方法
  et (2012-1-29 21:08:36)
WordPress Eclipse 上で、OpenFOAM を動かす方法
  et (2012-1-29 11:04:49)
WordPress DEXCS2011 for OpenFOAM(R) にEclipseをインストールする方法
  et (2012-1-26 21:08:48)
WordPress Eclipse上でOpenFOAMを使う方法
  et (2012-1-25 6:05:57)
WordPress EclipsePDT 1歩前進
  et (2008-2-29 8:08:19)