OpenFOAM

【水面高さ時刻歴データ(OpenFOAM)】ParaViewとPythonでグラフ化する方法(12)

こんにちは(@t_kun_kamakiri

今回は下記の記事で解説した水面高さをParaViewで表示し、Pythonで実験データとする方法について解説を行います。

ちなみに、水面高さは「system/controlDict」ファイル内でfunctionObjectのinterfaceHeightで特定座標の水位や波高を取得することが可能です。

system/controlDict

「direction (0 0 -1);」は重力の方向を正しく指定する必要があります。
今回はz方向下向きに重力がはたらいているためこのような設定としました。

また、「postProcessing/interfaceHeight1/0/height.dat」には一つの座標に対して以下の出力結果が出されます。

  • # hB : Interface height above the boundary:水面の高さ
  • # hL : Interface height above the location:波の高さ

いずれも重力の方向を正しく指定することが重要です。

本来はこちらの設定の方が結果処理の手間が省けて良いのですが、計算実行後に設定し忘れて(もしくは後で見たくなった)などの理由で可視化ソフトで表示させたいということは稀にあります。

今回の内容

3次元ダムブレイクの実験の指定した座標位置での水面高さをParaViewで表示し、Pythonで実験データと比較する方法について解説を行います。

OpenFOAM初心者でチュートリアルを動かしたことがある方を対象にしています。

DEXCS2020
OpenFOAM v2006
gnuplot 5.2

3次元ダムブレイクの実験データと解析モデル

実験データ

こちらの実験データのより以下の時刻歴データを計測しています。

  • 圧力計測点P1~P8(前回の記事)
  • 水面の高さH1~H4←今回OpenFOAMと比較する対象

実験ではx方向に

  1. H1=0.496m
  2. H2=0.992m
  3. H3=1.488m
  4. H4=2.638m

のポイントで水面高さを出力しています。

ちなみに「system/controlDict」ファイル内のfunctionObjectのinterfaceHeightで取得した特定座標の水面高さを実験データと比較すると下記のようになります。

そこそこ実験とOpenFOAMの結果が合っていますね。
今回はこれをParaViewとPythonを使ってグラフ化をします。

解析モデル

OpenFOAMでの解析モデルの設定方法は下記の記事に書いています。
※追々ファイルもモデルファイルも公開します。

ParaViewで水面高さのコンター図

ParaViewを起動したら資料に従ってParaviewの操作を行います。

「(13)「Export SpreadSheet」を選択」以降は行わず、左上の「File>Save Data」でcsvで保存します。「OK」を押すと、「Configure Writer(DataSetCSVWriter)」と出るので、「Write Time Steps」にチェックを入れて「OK」を押します。

するとこのように「height0.ステップ数.csv」で全てのステップ数のデータが保存されます。

例えば「height0.0.csv」の中身を確認すると・・・
「Points:0」が横軸、「Points:2」が体積分率0.5の高さを表しているので、グラフにすると以下のように水面高さの分布になります。

Pythonでデータの加工

以上で各ステップの体積分率0.5(水面高さに相当する量)のデータがそろったので、指定した座標での水面高さの時刻歴をPythonでグラフ化したいと思います。

jupyter lab(Python3系)でデータを加工します。

コードをまとめると以下のようになります。

水面高さの時刻歴をグラフ化できました。

まとめ

今回はParaviewで水面高さの時刻歴のグラフ化をParaViewとPythonで出力する方法を解説しました。

計算実行後に、データの分析したい場合はデータ加工が必要ですがParaViewとPythonで十分行えることがわかりました。

参考書

PENGUINさんサイトを体系的に学べる書籍となっています。ネット記事でも十分勉強できるのですが、OpenFOAMの初学者でOpenFOAMをインストール済みであれば一冊持って置き、体系的に学ぶのが良いでしょう。

あとは初心者向けに丁寧に解説がされているこちらの書籍もお勧めです。最後の章にはオーバーセットメッシュ(重合メッシュ)の機能を使った解析を最後まで丁寧に解説しているので挫折することはないでしょう。

関連記事もどうぞ

COMMENT