熱伝導解析
熱伝導解析
本開発コードで用いられる有限要素法(Finite ElementMethod)による固体についての熱伝導解析手法を示す。
基礎方程式
連続体中での熱伝導方程式は以下のようになる。
ρc∂T∂t=∂∂x(kx∂T∂x)+∂∂y(ky∂T∂y)+∂∂z(kz∂T∂z)+Q
ここで、ρ=ρ(x)は質量(密度)、c=c(x,T)は比熱、T=T(x,t)は温度、k=k(x,T)は熱伝導率、Q=Q(x,T,t)は発熱量、 xは位置、Tは温度、tは時間を表す。
考慮している領域をS、その周囲をΓとする。 Γ上では、Dirichet型かNeumann型のいずれかの境界条件が、いたるところで与えられるものと仮定すると境界条件は以下のようになる。
T=T1(x,t),x∈Γ1
k∂T∂n=q(x,T,t),x∈Γ2
ただし、T1,qは関数形が既知とする。qは境界からの流出熱流束である。 本プログラムでは、3種類の熱流束が考慮できる。
q=−qs+qc+qr
qs=qs(x,t)
qc=hc(T−Tc)
qr=hr(T4−Tr4)
ここで、qsは分布熱流束、qcは対流熱伝達による熱流束、qrは輻射熱伝達による熱流束である。
ただし、 Tc=Tc(x,t)は対流熱伝達率雰囲気温度、 hc=hc(x,t)は対流熱伝達係数、 Tr=Tr(x,t)は輻射熱伝達率雰囲気温度、 hr=εσF=hr(x,t)は輻射熱伝達係数、 εは輻射率,σはStefanBoltzmann定数、Fは形態係数である.
離散化
方程式(1)をGalerkin法によって離散化すると、
KT+M∂T∂t=F
ただし、
K=∫(kx∂NT∂x∂N∂x+ky∂NT∂y∂N∂y+kz∂NT∂z∂N∂z)dV+∫hcNTNds+∫hrNTNds
M=∫ρcNTNdV
F=∫QNTdV−∫qsNTdS+∫hcTcNTdS+∫hcTr(T+Tr)(T2+Tr2)NTdS
N=(N1,N2,…,Ni)
方程式(8)は非線形かつ非定常の方程式である。 いま、時間に関して後退オイラー法により離散化して、時刻t=t0における温度が既知のとき時刻t=t0+Δtでの温度を次式を用いて計算することにする。
Kt=t0+ΔtTt=t0+Δt+Mt=t0+ΔtTt=t0+Δt−Tt=t0Δt=Ft=t0+Δt
ここでの式(13)を近似的にみたす温度ベクトルT(i)t=t0+Δt を改善して、精度の良い解T(i)+1t=t0+Δtを求めることを考える。
そのために、まず、温度ベクトルを次のようにあらわす。
Tt=t0+Δt=T(i)t=t0+Δt+ΔT(i)t=t0+Δt
熱伝導マトリクスと温度ベクトルとの積、質量マトリクスなどを次式のように近似的にあらわす。
Kt=t0+ΔtTt=t0+Δt=K(i)t=t0+ΔtT(i)t=t0+Δt+∂(K(i)t=t0+ΔtT(i)t=t0+Δt)∂T(i)t=t0+ΔtΔT(i)t=t0+Δt
Mt=t0+Δt=M(i)t=t0+Δt+∂M(i)t=t0+Δt∂T(i)t=t0+ΔtΔT(i)t=t0+Δt
式(14)、式(15)、式(16)を式(13)に代入して二次以上の項を省略すると次式を得る。
(M(i)t=t0+ΔtΔt+∂M(i)t=t0+Δt∂T(i)t=t0+ΔtT(i)t=t0+Δt−Tt=t0Δt+∂(K(i)t=t0+ΔtT(i)t=t0+Δt)∂T(i)t=t0+Δt)ΔT(i)t=t0+Δt =Ft=t0+Δt−M(i)t=t0+ΔtT(i)t=t0+Δt−Tt=t0Δt−K(i)t=t0+ΔtT(i)t=t0+Δt
さらに左辺の係数マトリクスを次式を用いて近似評価する。
K(i)=M(i)t=t0+ΔtΔt+∂(K(i)t=t0+ΔtT(i)t=t0+Δt)∂T(i)t=t0+Δt=M(i)t=t0+ΔtΔt+K(i)Tt=t0+Δt
ここでK(i)Tt=t0+Δtは接線剛性マトリクスである。
結局次式を用いて反復計算を行うことによって時刻 t=t0+Δtでの温度を計算することができる。
K(i)ΔT(i)t=t0+Δt=Ft=t0+Δt−M(i)t=t0+ΔtT(i)t=t0+Δt−Tt=t0Δt−K(i)T(i)t=t0+Δt
特に定常解析においては次式を用いて反復計算を行う。
K(i)TΔT(i)t=∞=Ft=∞−K(i)TΔT(i)t=∞
T(i+1)t=∞=T(i)t=∞+ΔT(i)t=∞
非定常解析において時間増分$\Delta t$の選び方は、時間に関する離散化に陰解法を採用しているので、一般にその大きさの制約を受けない。ただし時間増分Δtが大きすぎると、反復計算における収束回数は増加する。 そこで本プログラムは、反復計算過程における残差ベクトルの大きさをつねにモニターし、反復計算の収束がおそすぎれば時間増分Δtを減少させ、反復計算回数が少なくなると時間増分Δtを増加される自動増分機能を備えている。