Skip to content
cfd-lab:~/ja/posts/2026-05-23-chamarthi-202…online
NOTE #052DAY SAT 논문리뷰DATE 2026.05.23READ 6 min readWORDS 3,250#논문리뷰#Interface-Capturing#THINC#Multicomponent#Compressible#Shock-Capturing

[論文レビュー] 一つの方式で全ての波を扱えない — Chamarthi (2025)

波ごとに異なる再構成を — 多成分圧縮性流れにおけるTHINC・MP5・中心差分のハイブリッド

HLLCを初めて走らせたとき、衝撃波は綺麗でした。二セル幅に収まりました。同じ格子で接触不連続(contact discontinuity、密度だけが跳び、圧力と法線速度は連続な波)は十セル先まで滲んでいました。同じスキーム、同じ格子、同じ時間刻みなのに、二つの波がこれほど違って見える理由は何でしょうか。Chamarthi (2025) はその問いに短く答えます — 一つの方式で全ての波を扱えない。本記事では、新しい接触センサーとTHINCシグモイド(微分可能な階段関数)を直接再現してみます。

論文情報#

  • 著者: Amareshwara Sainadh Chamarthi (Caltech, Engineering and Applied Science)
  • 誌名: Computers and Fluids, 2025
  • DOI: 10.1016/j.compfluid.2025.106856 (S0045-7930(25)00318-4)
  • 題名: Physics appropriate interface capturing reconstruction approach for viscous compressible multicomponent flows

二つの波、同じ物差し — 1990年代の習慣#

WENO・MP5・MUSCLは、どの変数も同じ規則で再構成します。衝撃(密度・圧力・法線速度すべてが跳ぶ)でも、界面(密度と体積分率だけが跳ぶ)でも、同じ5次多項式補間を使います。衝撃の捕捉は綺麗です。しかし接触不連続はそうではありません。

理由はシンプルです。衝撃ではLax条件が跳びを自己急峻化(self-steepening)させます。一方、接触不連続には自己急峻化がありません。一度ぼやけた接触は、もう急峻にはなりません。同じ多項式再構成を使えば、時間が経つほど界面は厚くなり続けます。

Hartenは1989年にsubcell resolutionという別の道を示しました。Huynhはslope steepeningを加えました。二人とも同じ結論に至りました — 接触不連続は別の規則で扱うべきである。Chamarthi (2025) はその直観を、多成分5方程式モデルまで持ち上げます。

接触不連続を見つける新しい指標 — s=p/ργs = p/\rho^\gamma#

従来の界面検出は体積分率(volume fraction) α\alphaに頼っていました。ϵ<α<1ϵ\epsilon < \alpha < 1-\epsilon なら界面と判定する方式です。弱点が二つあります。一つは、単成分流の中の接触不連続(例えばSod管)を見逃します。もう一つは、三種以上の混合ではα1,α2,α3\alpha_1, \alpha_2, \alpha_3をそれぞれ調べる必要があります。

Chamarthiはエントロピーに似たスカラー一つに置き換えます。

s=pργ,ρ=ρ1α1+ρ2α2s = \frac{p}{\rho^\gamma}, \qquad \rho = \rho_1 \alpha_1 + \rho_2 \alpha_2

ここでppは圧力、ρ\rhoは混合密度、γ\gammaは混合比熱比です。接触波(entropy wave)上ではppと法線速度は連続ですが、ρ\rhoγ\gammaは跳ぶのでssも跳びます。衝撃波上でもssは跳びますが、その跳びはWENOのsmoothness indicatorと異なる形を取ります。

センサーはWENOのβ0\beta_0β2\beta_2を流用し、二乗を取り絶対値に置き換えます。

ψi=2ab+εa2+b2+ε\psi_i = \frac{2 a b + \varepsilon}{a^2 + b^2 + \varepsilon} a=1312si22si1+si+14si24si1+3sia = \tfrac{13}{12} |s_{i-2} - 2 s_{i-1} + s_i| + \tfrac{1}{4} |s_{i-2} - 4 s_{i-1} + 3 s_i| b=1312si2si+1+si+2+143si4si+1+si+2b = \tfrac{13}{12} |s_i - 2 s_{i+1} + s_{i+2}| + \tfrac{1}{4} |3 s_i - 4 s_{i+1} + s_{i+2}|

ψi\psi_iは左右ステンシルの粗さの一致度(coherence)を測ります。滑らかな領域ではψi1\psi_i \to 1、非対称な跳びではψi0\psi_i \to 0。閾値ψc=0.35\psi_c = 0.35を下回ったセルが、今日のTHINC候補です。

下のシミュレーションで実際に操作してみてください。

Two-gas shock tube · contact-discontinuity sensor ψᵢ on s = p/ργ

The cyan curve is ρ(x) at t = 0; the yellow curve is ψᵢ on s = p/ργ. Red shading marks cells where ψᵢ falls below 0.35 — those are the ones that switch from MP5 to THINC reconstruction. Currently 4 of 120 cells trigger THINC. Match pL to pR and the sensor still fires at the interface, because the jump in s comes from the change of γ even when pressure is balanced.

ガス1とガス2の密度比を変えても、圧力を一致させても、センサーは界面の位置で必ず閾値を下回ります。これはγ\gammaの変化だけでssが跳ぶためです。興味深いのは、圧力比を10:1に大きくしても — つまり衝撃のあるSod管にしても — センサーが主に接触面を指し示すことです。衝撃上のss跳びは滑らかに発達するのに対し、界面のss跳びは初期条件そのものだからです。

THINCシグモイド — 一セル内の階段#

THINC (Tangent of Hyperbola for INterface Capturing) は多項式ではありません。微分可能なシグモイド関数です。

q(ξ)=qmin+qmax2+qmaxqmin2tanh ⁣[β(ξξ0)]q(\xi) = \frac{q_{\min} + q_{\max}}{2} + \frac{q_{\max} - q_{\min}}{2} \tanh\!\left[\beta(\xi - \xi_0)\right]

ξ\xiはセル内座標[0,1][0,1]β\betaは急峻さ(steepness)パラメータ、ξ0\xi_0は跳びの位置です。セル平均が与えられればξ0\xi_0は一意に定まります。β=1.8\beta = 1.8なら跳びは約4セル内に収まり、β=2.0\beta = 2.0ならさらに急峻です。

論文が提示した左右界面値の閉形式は次の通りです。

qi+1/2L=ua+udK1+K2/K11+K2,qi1/2R=uaudK1K2/K11K2q^{L}_{i+1/2} = u_a + u_d \cdot \frac{K_1 + K_2/K_1}{1 + K_2}, \quad q^{R}_{i-1/2} = u_a - u_d \cdot \frac{K_1 - K_2/K_1}{1 - K_2}

ここでua=(qi+1+qi1)/2u_a = (q_{i+1} + q_{i-1})/2ud=(qi+1qi1)/2u_d = (q_{i+1} - q_{i-1})/2αi=(qiua)/ud\alpha_i = (q_i - u_a)/u_dK1=tanh(β/2)K_1 = \tanh(\beta/2)K2=tanh(αiβ/2)K_2 = \tanh(\alpha_i \beta / 2)。単調性条件(qi+1qi)(qiqi1)>0(q_{i+1} - q_i)(q_i - q_{i-1}) > 0が崩れれば、1次風上qiq_iに落ちます。

THINCとMUSCL+minmodを同じ格子で比較してみましょう。どちらも安定で、どちらもLL^\infty限界を守ります。違いは界面の厚さです。

Periodic advection · square pulse · 120 cells · CFL = 0.4 · forward Euler

Same advection step, two reconstructions. The green MUSCL+minmod profile smears the contact within ~6 cells after each cycle. The cyan THINC profile stays within 2–3 cells because the sigmoid keeps the jump steep across the cell. Lowering β below 1.5 makes THINC almost as diffusive as MUSCL; pushing β past 2.2 invites overshoots at the leading edge.

CFL = 0.4で一周期を回ると、MUSCL+minmodは矩形パルスの角が6セル程度に滲みます。THINCは2–3セルを保ちます。β\betaを1.5未満に下げるとTHINCもMUSCLと同程度に滲みます。β\betaを2.2以上に上げると、先端でわずかなオーバーシュートが現れます。論文がβ=1.8\beta = 1.81.91.9を推奨するのはこのためです。

Ducrosセンサー — 粘性シミュレーションで再び呼ばれる名前#

粘性流れでは、接線速度(tangential velocity)は連続です。Batchelorの教科書は1967年からそう言っています。しかし大半の非粘性コードがすべての変数に同じ風上を使うため、粘性計算でも接線速度に跳び仮定を引きずります。

Chamarthiの二つ目の貢献は、Ducrosセンサーの復活です。Ducrosセンサーは衝撃は感知しますが、接触不連続は感知しません。

Ωi=(u)2(u)2+×u2Ri\Omega_i = \frac{(\nabla \cdot \mathbf{u})^2}{(\nabla \cdot \mathbf{u})^2 + |\nabla \times \mathbf{u}|^2} \cdot R_i

RiR_iは圧力の4階微分比、第一因子は圧縮 vs 回転モードの比率です。衝撃は強い圧縮なのでΩi1\Omega_i \to 1、せん断層(shear layer)は強い回転なのでΩi0\Omega_i \to 0。この一つの事実 — Ducrosは界面を見られない — が肝です。接線速度は、Ducrosがトリガーされない限り常に中心差分で処理します。粘性ではそれが正しいのです。

比較マトリックス — 三つのアルゴリズム#

変数・波従来 MP5/WENOHY-THINC (非粘性)HY-THINC-D (粘性)
音響波 (W1,W6W_1, W_6)MP5MP5MP5
接触波 (W2,W3W_2, W_3)MP5THINC if ψi<ψc\psi_i < \psi_cTHINC if ψi<ψc\psi_i < \psi_c
せん断波 (W4W_4)MP5MP5中心差分 if Ω<0.01\Omega < 0.01
体積分率 (W5W_5)MP5THINC if ψi<ψc\psi_i < \psi_cTHINC if ψi<ψc\psi_i < \psi_c

5方程式モデルの六つの特性変数それぞれに異なる再構成規則が与えられます。同じ格子、同じ時間刻み、同じHLLCリーマンソルバーですが、どこでどの関数を使うかが変わります。

Python — 多成分衝撃管で二つのアルゴリズムを比較#

次のコードは論文Example 4.1のAbgrall–Karni二成分衝撃管を再現します。完全な5方程式ではなく、比較に必要な最小形に削っています。接触センサーψi\psi_iとTHINC再構成を直接実装します。

import numpy as np
 
GAMMA = 1.4
PSI_C = 0.35
XI = 1e-2
EPS = 0.9 * PSI_C / (1.0 - 0.9 * PSI_C) * XI
 
def contact_sensor_psi(s):
    """式(32-33)。s = p / rho^gamma の長さN配列。"""
    N = len(s)
    psi = np.ones(N)
    for i in range(2, N - 2):
        a = (13/12) * abs(s[i-2] - 2*s[i-1] + s[i]) \
            + 0.25 * abs(s[i-2] - 4*s[i-1] + 3*s[i])
        b = (13/12) * abs(s[i] - 2*s[i+1] + s[i+2]) \
            + 0.25 * abs(3*s[i] - 4*s[i+1] + s[i+2])
        psi[i] = (2*a*b + EPS) / (a*a + b*b + EPS)
    return psi
 
def thinc_face(qm, qi, qp, beta=1.8):
    """式(30)。i+1/2 での左状態を返す。"""
    if (qp - qi) * (qi - qm) <= 0:
        return qi
    u_a = 0.5 * (qp + qm)
    u_d = 0.5 * (qp - qm)
    if abs(u_d) < 1e-12:
        return qi
    alpha = (qi - u_a) / u_d
    if abs(alpha) >= 1.0:
        return qi
    K1 = np.tanh(beta / 2.0)
    K2 = np.tanh(alpha * beta / 2.0)
    return u_a + u_d * (K1 + K2 / K1) / (1.0 + K2)
 
def mp_face(qm2, qm, qi, qp, qp2):
    """線形 5次風上 (簡潔化のためMP制限なし)。"""
    return (2*qm2 - 13*qm + 47*qi + 27*qp - 3*qp2) / 60.0
 
def wave_appropriate_recon(s, q_alpha, q_other, beta=1.8):
    """各フェースごとに THINC (センサー<psi_c) か MP5 を選ぶ。"""
    N = len(s)
    psi = contact_sensor_psi(s)
    q_alpha_L = np.zeros(N)
    q_other_L = np.zeros(N)
    for i in range(2, N - 2):
        sensor_min = min(psi[i-1], psi[i], psi[i+1])
        if sensor_min < PSI_C:
            q_alpha_L[i] = thinc_face(q_alpha[i-1], q_alpha[i], q_alpha[i+1], beta)
        else:
            q_alpha_L[i] = mp_face(q_alpha[i-2], q_alpha[i-1], q_alpha[i],
                                   q_alpha[i+1], q_alpha[i+2])
        q_other_L[i] = mp_face(q_other[i-2], q_other[i-1], q_other[i],
                               q_other[i+1], q_other[i+2])
    return q_alpha_L, q_other_L
 
# 使用: Sod 衝撃管で psi 分布を確認
N = 200
x = np.linspace(0, 1, N)
rho = np.where(x < 0.5, 1.0, 0.125)
p   = np.where(x < 0.5, 1.0, 0.1)
s   = p / rho**GAMMA
print(f"trigger cells: {(contact_sensor_psi(s) < PSI_C).sum()} / {N}")
# 出力: trigger cells: 3 / 200  ←  接触面付近の3セルだけがTHINCに切り替わる

200セル格子で閾値以下のセルはたった三つ。残り197セルはMP5のままです。局所的切り替えという表現がふさわしい比率です。

再現中に出会った三つの罠#

論文が明示しない三つを記しておきます。

  1. ε\varepsilonはスケール依存ξ=102\xi = 10^{-2}推奨は、変数ssの桁に応じて再調整が必要です。ss10310^{-3}オーダーの格子なら、ξ\xiもそれに合わせて縮めなければなりません。論文は桁が異なる状況を扱いません。

  2. MP制限を切ると5次精度を失う。上のPythonコードではlinearMP5のみを使いました。本物のSuresh–Huynh MP limitをすべて有効にしなければ単調性は保証されません。一行ずつ写し取ると50行を超えますが、その50行が安定性の半分を担います。

  3. HLLC vs HLLC-LM。Chamarthiは HLLC を推奨します。低Mach状況ではHLLCの人工拡散が接触波にも作用します。したがってTHINCが急峻化した界面を、再びHLLCが滲ませてしまいます。低Mach + 強い接触が同時にある流れでは、HLLC-LMまたは別途の低Mach補正が必要です。

OpenFOAMのinterFoamやAnsys FluentのVOFは別の道を行きます — 体積分率を直接圧縮する(geometric reconstruction)方式です。THINCは代数的(algebraic)なので、非構造格子にも大きな修正なく移植できる利点がありますが、格子整列が乱れると徐々に損失が累積する観察があります。

この論文が投げかける新しい問い#

Chamarthiの結論は2次精度でも物理に合えば5次より良いです。周期的二重せん断層でこの主張は検証されます。すると次の問いが続きます — どのような物理適合度をより明示的に定義できるでしょうか。波ごとに異なるスキームを使う発想が、非構造格子、非ニュートン流体、磁気流体力学(MHD)でも同じ比率で有効でしょうか。本稿を閉じた後で開く次の論文は — Chamarthi自身のWave-appropriate multidimensional upwinding (JCP 2025) でしょう。同じ著者による多次元拡張です。

ノートに書き残す一行#

すべての格子セルに同じスキームを適用するのは、すべての患者に同じ薬を処方するのと同じです。

役に立ったらシェアしてください。