OpenFOAM

OpenFOAMで総括熱伝達率(U値)を計算する方法。chtMultiRegionFoam対応

こんにちは(@t_kun_kamakiri

OpenFOAMの熱流体固体連成による総括熱伝達率(U値)を計算で求めたいと思います。
例えば以下のような平板が3層の場合の熱伝導を考えるにはどうするでしょうか?
3層の合成の熱伝導率を考えることができれば、両端の温度差からフーリエの法則を使って熱量が計算できます。

結論を先に言うと、合成の熱伝導率は総括熱伝達率(U値)と呼ばれ、$\frac{L}{KA}=\frac{L_{1}}{k_{1}A}+\frac{L_{2}}{k_{2}A}+\frac{L_{3}}{k_{3}A}$のように書けます。

熱伝達率の部分は経験則で与えるか、流体解析により求めるしかありません。
実際に熱流体解析により通過する熱流束$q$を求め、両端の温度差$\Delta T$からU値を算出することができます。

U=qΔTU=\frac{q}{\Delta T}


今回はこの総括熱伝達率(U値)を熱流体解析で求めたいと思います。

本記事の内容
  • マルチリージョン用メッシュからOpenFOAMでの流体解析の手順を紹介
  • 総括熱伝達率(U値)を計算

使用するソルバはchtMultiRegionFoamで熱流体と固体を連成させた非定常解析用のソルバになります。

OpenFOAMv2506のバージョンにおいて現在は、浮力を考慮した熱流体解析ソルバは以下のものがあります。

ソルバ名定常 / 非定常主な特徴主な用途・備考
chtMultiRegionSimpleFoam定常多領域の熱流体連成(非圧縮性)構造物と流体の熱連成、定常問題向け
chtMultiRegionFoam非定常多領域・非圧縮性の時間依存連成解析熱伝導と流体連成の過渡解析
chtMultiRegionTwoPhaseEulerFoam非定常多領域 + 二相流(Euler-Euler) + 熱連成液体/気体の二相流+固体との熱連成に対応
buoyantSimpleFoam定常単領域の自然対流・熱伝導密度差による自然対流、定常解析向け
buoyantPimpleFoam非定常上記の非定常版過渡的な自然対流解析
buoyantBoussinesqSimpleFoam定常Boussinesq近似(小温度差)温度変化が小さい自然対流
buoyantBoussinesqPimpleFoam非定常上記の時間依存版過渡的自然対流、簡略化モデル

この中のchtMultiRegion系は流体(液体、気体)・固体の複数領域の熱流体解析を行うために設計されています。
ただ、テキストベースで解析設定しようとすると、めちゃくちゃ大変です。
以下にOpenFOAMが用意しているチュートリアルを解説した記事がありますので、一度読んでみると良いでしょう。

以前にsappyHexMeshでヒートシンクの固体・流体連成の解析を紹介しました。

【ヒートシンクの熱流体(1)】OpenFOAMの熱流体固体連成のメッシュ作成こんにちは(@t_kun_kamakiri) OpenFOAMの熱流体固体連成によるヒートシンクの熱流体解析の設定方法を解説します。 ...
【ヒートシンクの熱流体(2)】OpenFOAMの熱流体固体連成の計算実行 こんにちは(@t_kun_kamakiri) OpenFOAMの熱流体固体連成によるヒートシンクの熱流体解析の設定方法を解...

また、別の方法としてsalomeでメッシュ作成する方法でモデル作成を行い、ヒートシンクの解析の記事もありますのでご参考ください。
領域分割やメッシュ作成はsalomeで行っています。

【SALOMEでヒートシンクの熱流体固体連成メッシュ作成】chtMultiRegionSimpleFoam用マルチリージョンモデル構築手順 こんにちは(@t_kun_kamakiri) OpenFOAMの熱流体固体連成によるヒートシンクの熱流体解析の設定方法を解説しま...
【SALOMEでヒートシンクの熱流体固体連成メッシュ作成】chtMultiRegionSimpleFoamで計算実行 こんにちは(@t_kun_kamakiri) OpenFOAMの熱流体固体連成によるヒートシンクの熱流体解析の設定方法を解説しま...

OpenFOAM v2506(WSL Ubuntu 22.04)

チュートリアルのコピー

20260301_U_thermal/ana001というフォルダが作業フォルダとします。

チュートリアルをコピー

$FOAM_TUTORIALS = /usr/lib/openfoam/openfoam2506/tutorials

メッシュ作成

blockMeshでメッシュ作成を行います。


blockMehshDictに以下のように記述することで領域に分けることができます。

以下のコマンドでメッシュを作成します。

blockMeshによりメッシュは作成されました。

ParaViewで結果を確認します。

ここからchtMultiRegionソルバのコツですが、領域ごとにすべての境界条件を設定する必要がありとても面倒ですが、以下の手順を踏めば比較的簡単に済みます。

まず、0フォルダを用意します。
今の場合は0.origをコピーして0フォルダを作成します。

0フォルダは以下のようなファイルが存在しています。

例えば、Uファイル(それ以外のファイルも)は以下のようにしておきます。

そのあとに領域分割を行います。

領域分割するには以下のコマンドで行います。

これによりフォルダは以下のように作成されます。
0フォルダには境界条件の情報が作成され、constantフォルダにはメッシュ情報(polyMesh)が作成されます。

流体は「流れ+熱」を解き、固体は「熱伝導」を解くため、必要な物理量が異なります。固体領域にもUなどが含まれていますが実際使われていません(そのまま何も設定しなくても

流体領域:
・速度 U
・温度 T
・圧力 p または p_rgh
・乱流モデルを使う場合は乱流量
 - k-epsilon なら k, epsilon
 - k-omega なら k, omega
 - SpalartAllmaras なら nuTilda

固体領域:
・温度 T
・圧力 p

0/U

共通している面は「fluid_1_to_solid_1」のように「領域1_to_領域2」のように名付けられます。

1 2
関連記事もどうぞ

COMMENT