空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法_第1頁
空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法_第2頁
空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法_第3頁
空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法_第4頁
空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法_第5頁
已閱讀5頁,還剩26頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法1空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法1.1緒論1.1.1有限體積法的起源與應(yīng)用有限體積法(FiniteVolumeMethod,FVM)起源于20世紀(jì)50年代,最初用于解決流體力學(xué)中的偏微分方程。它是一種基于守恒定律的數(shù)值方法,通過將計(jì)算域離散成一系列控制體積,然后在每個(gè)控制體積上應(yīng)用守恒定律,從而將連續(xù)的偏微分方程轉(zhuǎn)化為離散的代數(shù)方程組。FVM在空氣動(dòng)力學(xué)、熱力學(xué)、環(huán)境工程、化學(xué)工程等多個(gè)領(lǐng)域有著廣泛的應(yīng)用,特別是在處理復(fù)雜的流體動(dòng)力學(xué)問題時(shí),如湍流、邊界層、激波等,F(xiàn)VM因其守恒性和穩(wěn)定性而成為首選方法。1.1.2高精度算法的重要性在有限體積法中,高精度算法對于提高數(shù)值解的準(zhǔn)確性和減少計(jì)算誤差至關(guān)重要。傳統(tǒng)的低精度算法,如一階迎風(fēng)格式,雖然簡單且計(jì)算效率高,但在處理具有強(qiáng)梯度或激波的流場時(shí),容易產(chǎn)生非物理的振蕩和擴(kuò)散。高精度算法,如二階迎風(fēng)格式、WENO(WeightedEssentiallyNon-Oscillatory)格式、Roe平均法等,能夠在保持?jǐn)?shù)值穩(wěn)定性的同時(shí),顯著提高解的精度,減少非物理振蕩,更準(zhǔn)確地捕捉流場中的細(xì)節(jié)特征,如激波、旋渦等。這對于空氣動(dòng)力學(xué)中的精確模擬和預(yù)測,如飛機(jī)設(shè)計(jì)、風(fēng)洞實(shí)驗(yàn)等,具有不可替代的作用。1.2高精度有限體積法算法示例1.2.1階迎風(fēng)格式二階迎風(fēng)格式是一種常用的高精度算法,它通過引入上風(fēng)向和下風(fēng)向的差分,提高了數(shù)值解的精度。下面是一個(gè)使用二階迎風(fēng)格式求解一維對流方程的Python代碼示例:importnumpyasnp

#參數(shù)設(shè)置

nx=100#空間網(wǎng)格點(diǎn)數(shù)

nt=100#時(shí)間步數(shù)

dx=2/(nx-1)#空間步長

dt=0.025#時(shí)間步長

c=1#對流速度

#初始化網(wǎng)格和初始條件

u=np.ones(nx)

u[int(.5/dx):int(1/dx+1)]=2

#邊界條件

u[0]=1.0

u[-1]=1.0

#二階迎風(fēng)格式求解

forninrange(nt):

un=u.copy()

foriinrange(1,nx):

ifun[i]>un[i-1]:

u[i]=un[i]-c*dt/dx*(un[i]-un[i-1])

else:

u[i]=un[i]-c*dt/dx*(un[i+1]-un[i])

#輸出結(jié)果

print(u)1.2.2WENO格式WENO格式是一種非線性高精度算法,特別適用于處理具有激波的流場。它通過加權(quán)多個(gè)低精度格式的解,來獲得一個(gè)高精度且非振蕩的解。下面是一個(gè)使用WENO格式求解一維Burgers方程的MATLAB代碼示例:%參數(shù)設(shè)置

nx=100;%空間網(wǎng)格點(diǎn)數(shù)

nt=100;%時(shí)間步數(shù)

dx=2/(nx-1);%空間步長

dt=0.025;%時(shí)間步長

c=1;%對流速度

%初始化網(wǎng)格和初始條件

u=ones(1,nx);

u(ceil(.5/dx):ceil(1/dx+1))=2;

%邊界條件

u(1)=1.0;

u(end)=1.0;

%WENO格式求解

forn=1:nt

un=u;

fori=2:nx-1

%WENO權(quán)重計(jì)算

omega1=0.3;

omega2=0.6;

omega3=0.1;

%低精度格式解

uL=(un(i-2)+2*un(i-1)+un(i))/4;

uC=(un(i-1)+2*un(i)+un(i+1))/4;

uR=(un(i)+2*un(i+1)+un(i+2))/4;

%非線性權(quán)重計(jì)算

alpha1=(omega1/(eps+(uL-uC)^2));

alpha2=(omega2/(eps+(uC-uR)^2));

alpha3=(omega3/(eps+(uR-un(i+3))^2));

%WENO格式解

u(i)=un(i)-c*dt/dx*(alpha1*(un(i-1)-un(i-2))+alpha2*(un(i)-un(i-1))+alpha3*(un(i+1)-un(i)));

end

end

%輸出結(jié)果

disp(u);1.2.3Roe平均法Roe平均法是一種基于特征線理論的高精度算法,它通過計(jì)算流場的平均狀態(tài),來提高數(shù)值解的精度和穩(wěn)定性。下面是一個(gè)使用Roe平均法求解一維Euler方程的C++代碼示例:#include<iostream>

#include<vector>

//參數(shù)設(shè)置

constintnx=100;//空間網(wǎng)格點(diǎn)數(shù)

constintnt=100;//時(shí)間步數(shù)

constdoubledx=2.0/(nx-1);//空間步長

constdoubledt=0.025;//時(shí)間步長

constdoublec=1.0;//對流速度

//初始化網(wǎng)格和初始條件

std::vector<double>u(nx,1.0);

for(inti=int(.5/dx);i<=int(1/dx+1);i++){

u[i]=2.0;

}

//邊界條件

u[0]=1.0;

u[nx-1]=1.0;

//Roe平均法求解

for(intn=0;n<nt;n++){

std::vector<double>un=u;

for(inti=1;i<nx-1;i++){

doubleuL=un[i-1];

doubleuR=un[i+1];

//計(jì)算Roe平均速度

doubleuRoe=(sqrt(uL)+sqrt(uR))/(1.0/sqrt(uL)+1.0/sqrt(uR));

//更新解

u[i]=un[i]-c*dt/dx*(uRoe*(un[i]-un[i-1]));

}

}

//輸出結(jié)果

for(inti=0;i<nx;i++){

std::cout<<u[i]<<std::endl;

}以上代碼示例展示了如何使用二階迎風(fēng)格式、WENO格式和Roe平均法來求解一維流體動(dòng)力學(xué)方程。這些算法在處理具有復(fù)雜結(jié)構(gòu)的流場時(shí),能夠提供更準(zhǔn)確、更穩(wěn)定的數(shù)值解,是空氣動(dòng)力學(xué)數(shù)值模擬中不可或缺的工具。1.3結(jié)論高精度有限體積法算法,如二階迎風(fēng)格式、WENO格式和Roe平均法,通過引入更復(fù)雜的數(shù)值格式和計(jì)算方法,顯著提高了數(shù)值解的精度和穩(wěn)定性,對于空氣動(dòng)力學(xué)中的復(fù)雜流場模擬具有重要意義。通過上述代碼示例,我們可以看到這些算法在實(shí)際應(yīng)用中的實(shí)現(xiàn)過程,以及它們?nèi)绾螏椭覀兏鼫?zhǔn)確地理解和預(yù)測流體動(dòng)力學(xué)現(xiàn)象。2空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法2.1有限體積法基礎(chǔ)2.1.1網(wǎng)格與控制體積在有限體積法(FVM)中,網(wǎng)格的構(gòu)建是解決空氣動(dòng)力學(xué)問題的第一步。網(wǎng)格將流體域劃分為一系列互不重疊的控制體積,每個(gè)控制體積通常包含一個(gè)節(jié)點(diǎn)或單元中心??刂企w積的選擇和設(shè)計(jì)直接影響到數(shù)值解的準(zhǔn)確性和計(jì)算效率。2.1.1.1網(wǎng)格類型結(jié)構(gòu)網(wǎng)格:網(wǎng)格單元在空間中規(guī)則排列,如矩形或六面體網(wǎng)格,適用于形狀規(guī)則的流體域。非結(jié)構(gòu)網(wǎng)格:網(wǎng)格單元在空間中不規(guī)則排列,如三角形或四面體網(wǎng)格,適用于形狀復(fù)雜的流體域。2.1.1.2控制體積控制體積是流體域中用于積分守恒方程的虛擬體積。在FVM中,每個(gè)控制體積的界面是流體流動(dòng)的邊界,通過計(jì)算界面的通量來更新控制體積內(nèi)的物理量。2.1.2離散化過程詳解離散化是將連續(xù)的偏微分方程轉(zhuǎn)化為離散形式的過程,以便在計(jì)算機(jī)上進(jìn)行數(shù)值求解。在FVM中,離散化主要通過在每個(gè)控制體積上應(yīng)用積分守恒方程來實(shí)現(xiàn)。2.1.2.1離散化步驟積分守恒方程:將連續(xù)的守恒方程在控制體積上進(jìn)行積分。通量計(jì)算:計(jì)算控制體積界面的通量,通常使用數(shù)值通量公式,如Roe平均或HLLC通量。時(shí)間推進(jìn):使用時(shí)間積分方法,如顯式或隱式時(shí)間推進(jìn),更新控制體積內(nèi)的物理量。2.1.2.2示例:一維非穩(wěn)態(tài)對流方程的離散化考慮一維非穩(wěn)態(tài)對流方程:?其中,u是流體的速度,a是對流速度。在有限體積法中,我們首先將方程在控制體積上積分:d對于一維問題,控制體積可以簡化為一個(gè)線段,界面通量可以簡化為:F時(shí)間推進(jìn)可以使用顯式歐拉方法:u2.1.2.3代碼示例importnumpyasnp

#參數(shù)設(shè)置

a=1.0#對流速度

L=1.0#域長度

N=100#網(wǎng)格單元數(shù)

T=1.0#終止時(shí)間

dt=0.01#時(shí)間步長

dx=L/N#空間步長

#初始條件

u=np.zeros(N+1)

u[N//2:N//2+20]=1.0#在中間部分設(shè)置初始速度為1

#時(shí)間推進(jìn)

t=0.0

whilet<T:

#計(jì)算界面通量

F=np.zeros(N+1)

foriinrange(N):

F[i+1/2]=a*(u[i]+u[i+1])/2

#更新速度

foriinrange(1,N):

u[i]=u[i]-dt/dx*(F[i+1/2]-F[i-1/2])

t+=dt

#輸出最終結(jié)果

print(u)這段代碼展示了如何使用有限體積法離散化并求解一維非穩(wěn)態(tài)對流方程。通過計(jì)算界面通量和使用顯式歐拉方法進(jìn)行時(shí)間推進(jìn),可以得到流體速度隨時(shí)間的變化。2.1.3高精度FVM算法高精度算法在有限體積法中用于提高數(shù)值解的精度,特別是在處理激波或強(qiáng)不連續(xù)性時(shí)。常見的高精度算法包括:高分辨率方案:如WENO(WeightedEssentiallyNon-Oscillatory)或ENO(EssentiallyNon-Oscillatory)方案,通過加權(quán)平均或多項(xiàng)式重構(gòu)來減少數(shù)值振蕩。通量限制器:如Superbee或VanLeer通量限制器,用于控制數(shù)值通量的非物理性振蕩。2.1.3.1示例:WENO方案WENO方案是一種高精度的重構(gòu)方法,用于在非結(jié)構(gòu)網(wǎng)格上處理強(qiáng)不連續(xù)性。它通過加權(quán)平均多個(gè)低階重構(gòu)方案來減少振蕩,同時(shí)保持高精度。2.1.3.2代碼示例WENO方案的實(shí)現(xiàn)較為復(fù)雜,涉及到多個(gè)低階重構(gòu)方案的加權(quán)平均。以下是一個(gè)簡化版的WENO方案代碼示例,用于一維非穩(wěn)態(tài)對流方程的界面通量計(jì)算:defweno_reconstruction(u,dx):

#低階重構(gòu)方案

u_left=np.zeros_like(u)

u_right=np.zeros_like(u)

u_left[:-1]=u[:-1]

u_right[1:]=u[1:]

#WENO權(quán)重計(jì)算

epsilon=1e-16

alpha1=(u_left[:-1]-u[:-2])**2

alpha2=(u_right[1:]-u_left[1:-1])**2

alpha3=(u[2:]-u_right[1:])**2

omega1=1/(epsilon+alpha1)**2

omega2=1/(epsilon+alpha2)**2

omega3=1/(epsilon+alpha3)**2

omega=omega1+omega2+omega3

omega1/=omega

omega2/=omega

omega3/=omega

#WENO重構(gòu)

u_weno=np.zeros_like(u)

u_weno[1:-1]=omega1*u_left[:-1]+omega2*u_right[1:]+omega3*u[2:]

returnu_weno

#使用WENO方案計(jì)算界面通量

F_weno=weno_reconstruction(u,dx)這段代碼展示了如何使用WENO方案進(jìn)行界面通量的高精度重構(gòu)。通過計(jì)算WENO權(quán)重并加權(quán)平均多個(gè)低階重構(gòu)方案,可以得到更平滑、更準(zhǔn)確的界面通量。通過以上內(nèi)容,我們深入了解了有限體積法的基礎(chǔ),包括網(wǎng)格與控制體積的概念,以及離散化過程的詳細(xì)步驟。同時(shí),我們還探討了高精度FVM算法,如WENO方案,用于提高數(shù)值解的精度和穩(wěn)定性。這些知識對于理解和應(yīng)用有限體積法解決空氣動(dòng)力學(xué)問題至關(guān)重要。3空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):高精度FVM算法3.1高精度重構(gòu)技術(shù)3.1.1線性重構(gòu)方法線性重構(gòu)方法是有限體積法中提高數(shù)值解精度的一種關(guān)鍵手段。它通過在每個(gè)網(wǎng)格單元內(nèi)假設(shè)狀態(tài)量的分布為線性,從而更準(zhǔn)確地捕捉流場中的梯度變化。線性重構(gòu)方法通常包括一階和二階重構(gòu),其中二階重構(gòu)能夠提供更平滑的解,減少數(shù)值振蕩。3.1.1.1階重構(gòu)一階重構(gòu)是最簡單的線性重構(gòu)方法,它假設(shè)網(wǎng)格單元內(nèi)的狀態(tài)量為常數(shù)。雖然這種方法在計(jì)算上較為簡單,但其精度較低,尤其是在流場梯度較大的區(qū)域。3.1.1.2階重構(gòu)二階重構(gòu)則假設(shè)網(wǎng)格單元內(nèi)的狀態(tài)量分布為線性,通過計(jì)算網(wǎng)格單元邊界上的狀態(tài)量來提高精度。一個(gè)常見的二階重構(gòu)方法是MUSCL(MonotonicUpstream-CenteredSchemeforConservationLaws)方法,它使用了單調(diào)性保持的插值技術(shù)。3.1.1.3示例:MUSCL重構(gòu)假設(shè)我們有一個(gè)一維流場,其中網(wǎng)格單元的狀態(tài)量為ui,我們想要在網(wǎng)格邊界xi?importnumpyasnp

defmuscl_reconstruction(u,limiter='van_leer'):

"""

MUSCL重構(gòu)方法示例

:paramu:網(wǎng)格單元的狀態(tài)量數(shù)組

:paramlimiter:限幅器類型,可選'van_leer','minmod','superbee'

:return:網(wǎng)格邊界上的狀態(tài)量

"""

#計(jì)算狀態(tài)量的梯度

grad_u=np.gradient(u)

#計(jì)算左右狀態(tài)量

u_left=u-0.5*grad_u

u_right=u+0.5*grad_u

#限幅器

iflimiter=='van_leer':

limiter_func=lambdar:(r+np.abs(r))/(1+np.abs(r))

eliflimiter=='minmod':

limiter_func=lambdar:np.minimum(1,r)

eliflimiter=='superbee':

limiter_func=lambdar:np.maximum(0,np.minimum(2*r,1),np.minimum(r,2))

else:

raiseValueError("Invalidlimitertype")

#計(jì)算網(wǎng)格邊界上的狀態(tài)量

u_face=0.5*(u_left[:-1]+u_right[1:])

r=grad_u[1:]/grad_u[:-1]

u_face+=0.5*limiter_func(r)*(u_right[1:]-u_left[:-1])

returnu_face

#示例數(shù)據(jù)

u=np.array([1,2,3,4,5])

u_face=muscl_reconstruction(u,limiter='van_leer')

print(u_face)在這個(gè)例子中,我們使用了VanLeer限幅器,它是一種常用的限幅器,能夠保持重構(gòu)的單調(diào)性,避免在流場梯度變化較大的區(qū)域產(chǎn)生數(shù)值振蕩。3.1.2非線性重構(gòu)方法非線性重構(gòu)方法超越了線性假設(shè),通過更復(fù)雜的插值技術(shù)來提高數(shù)值解的精度。這些方法通常在流場中存在激波或其它非線性特征時(shí)更為有效,因?yàn)樗鼈兡軌蚋鼫?zhǔn)確地捕捉這些特征。3.1.2.1示例:WENO(WeightedEssentiallyNon-Oscillatory)重構(gòu)WENO重構(gòu)是一種高精度的非線性重構(gòu)方法,它通過加權(quán)多個(gè)候選的低階重構(gòu)方案來構(gòu)建一個(gè)高階重構(gòu)方案,同時(shí)保持了數(shù)值解的非振蕩性。importnumpyasnp

defweno_reconstruction(u,order=5):

"""

WENO重構(gòu)方法示例

:paramu:網(wǎng)格單元的狀態(tài)量數(shù)組

:paramorder:重構(gòu)的階數(shù),通常為5

:return:網(wǎng)格邊界上的狀態(tài)量

"""

#WENO參數(shù)

epsilon=1e-16

a=np.array([1/3,2/3,1/3])

b=np.array([1/10,6/10,3/10])

#計(jì)算左右狀態(tài)量

u_left=np.zeros_like(u)

u_right=np.zeros_like(u)

#重構(gòu)過程

foriinrange(1,len(u)-1):

#計(jì)算候選重構(gòu)方案

u_left[i]=(u[i-2]+6*u[i-1]-3*u[i])/6

u_right[i]=(-3*u[i]+6*u[i+1]+u[i+2])/6

#計(jì)算平滑度指標(biāo)

beta1=(u[i-1]-u[i-2])**2+(u[i]-u[i-1])**2

beta2=(u[i+1]-u[i])**2+(u[i+2]-u[i+1])**2

#計(jì)算權(quán)重

alpha1=(epsilon+beta1)**(-2)

alpha2=(epsilon+beta2)**(-2)

omega1=alpha1/(alpha1+alpha2)

omega2=alpha2/(alpha1+alpha2)

#加權(quán)重構(gòu)

u_face=omega1*u_left[i]+omega2*u_right[i]

returnu_face

#示例數(shù)據(jù)

u=np.array([1,2,3,4,5])

u_face=weno_reconstruction(u)

print(u_face)在這個(gè)WENO重構(gòu)的例子中,我們使用了5階重構(gòu),通過計(jì)算候選的低階重構(gòu)方案和它們的平滑度指標(biāo),然后根據(jù)這些指標(biāo)加權(quán)選擇最終的高階重構(gòu)方案。這種方法在處理復(fù)雜流場時(shí),能夠提供更準(zhǔn)確的數(shù)值解,同時(shí)避免了數(shù)值振蕩。通過上述線性和非線性重構(gòu)方法的介紹和示例,我們可以看到,高精度的有限體積法算法通過在網(wǎng)格邊界上進(jìn)行更精細(xì)的狀態(tài)量重構(gòu),能夠顯著提高數(shù)值解的精度和穩(wěn)定性。在實(shí)際應(yīng)用中,選擇合適的重構(gòu)方法和限幅器對于獲得高質(zhì)量的數(shù)值解至關(guān)重要。4空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):通量計(jì)算與數(shù)值格式4.1通量差分分裂4.1.1原理通量差分分裂(FluxDifferenceSplitting,FDS)是一種在有限體積法中用于計(jì)算界面通量的高精度算法。其基本思想是將控制體積界面處的通量差分分解為正向和負(fù)向兩部分,然后分別用不同的數(shù)值格式進(jìn)行近似。這種方法可以有效地減少數(shù)值擴(kuò)散,提高計(jì)算的精度和穩(wěn)定性。4.1.2內(nèi)容在FDS中,我們首先定義一個(gè)通量函數(shù)Fu,其中u是流體的狀態(tài)變量。在控制體積的界面xΔ這里,ui+和ui?分別表示界面xi右側(cè)和左側(cè)的狀態(tài)變量。通量差分分裂將ΔΔ正向通量F+和負(fù)向通量F4.1.3示例假設(shè)我們正在解決一維的Euler方程,通量函數(shù)FuF其中,ρ是密度,u是速度,p是壓力,E是總能量。使用Roe平均進(jìn)行通量差分分裂,我們可以計(jì)算正向和負(fù)向通量:importnumpyasnp

defroe_flux(u_left,u_right):

"""

計(jì)算基于Roe平均的正向和負(fù)向通量。

參數(shù):

u_left:左側(cè)狀態(tài)變量[rho,rho*u,rho*E]

u_right:右側(cè)狀態(tài)變量[rho,rho*u,rho*E]

返回:

F_plus:正向通量

F_minus:負(fù)向通量

"""

rho_left,rho_u_left,rho_E_left=u_left

rho_right,rho_u_right,rho_E_right=u_right

#計(jì)算Roe平均值

u=(rho_u_left+rho_u_right)/(rho_left+rho_right)

c=np.sqrt((rho_left*rho_right*(rho_E_left-0.5*rho_u_left**2/rho_left-rho_E_right+0.5*rho_u_right**2/rho_right))/(rho_left+rho_right))

#計(jì)算正向和負(fù)向通量

F_plus=0.5*(F(u_right)+F(u_left)+c*(u_right-u_left))

F_minus=0.5*(F(u_right)+F(u_left)-c*(u_right-u_left))

returnF_plus,F_minus

defF(u):

"""

計(jì)算Euler方程的通量函數(shù)。

參數(shù):

u:狀態(tài)變量[rho,rho*u,rho*E]

返回:

F:通量函數(shù)

"""

rho,rho_u,rho_E=u

u=rho_u/rho

p=(gamma-1)*(rho_E-0.5*rho_u**2/rho)

returnnp.array([rho_u,p+rho_u*u,(rho_E+p)*u])

#示例數(shù)據(jù)

gamma=1.4

u_left=np.array([1.0,1.0,2.5])

u_right=np.array([1.0,-1.0,2.5])

#計(jì)算正向和負(fù)向通量

F_plus,F_minus=roe_flux(u_left,u_right)

print("正向通量:",F_plus)

print("負(fù)向通量:",F_minus)在這個(gè)例子中,我們定義了Euler方程的通量函數(shù)Fu4.2通量矢量分裂4.2.1原理通量矢量分裂(FluxVectorSplitting,FVS)是另一種在有限體積法中用于計(jì)算界面通量的高精度算法。與FDS不同,F(xiàn)VS將通量矢量本身分解為正向和負(fù)向兩部分,然后分別計(jì)算。這種方法同樣可以減少數(shù)值擴(kuò)散,提高計(jì)算精度。4.2.2內(nèi)容在FVS中,通量矢量Fu被分解為正向通量矢量F+uF正向和負(fù)向通量矢量的計(jì)算通?;诹黧w的特征速度,即聲速和流速。對于Euler方程,可以使用如下方法進(jìn)行分解:FF其中,c是聲速。4.2.3示例使用上述FVS方法,我們可以計(jì)算Euler方程的正向和負(fù)向通量矢量:deffvs_flux(u):

"""

計(jì)算基于通量矢量分裂的正向和負(fù)向通量矢量。

參數(shù):

u:狀態(tài)變量[rho,rho*u,rho*E]

返回:

F_plus:正向通量矢量

F_minus:負(fù)向通量矢量

"""

rho,rho_u,rho_E=u

u=rho_u/rho

p=(gamma-1)*(rho_E-0.5*rho_u**2/rho)

c=np.sqrt(gamma*p/rho)

#計(jì)算正向和負(fù)向通量矢量

F=np.array([rho_u,p+rho_u*u,(rho_E+p)*u])

F_plus=F+0.5*np.array([0,c**2,c**2*u])

F_minus=F-0.5*np.array([0,c**2,c**2*u])

returnF_plus,F_minus

#示例數(shù)據(jù)

gamma=1.4

u=np.array([1.0,1.0,2.5])

#計(jì)算正向和負(fù)向通量矢量

F_plus,F_minus=fvs_flux(u)

print("正向通量矢量:",F_plus)

print("負(fù)向通量矢量:",F_minus)在這個(gè)例子中,我們使用了通量矢量分裂方法來計(jì)算Euler方程的正向和負(fù)向通量矢量。通過將通量矢量分解,我們可以更精確地近似界面處的通量,從而提高數(shù)值解的精度。5時(shí)間推進(jìn)方法在高精度有限體積法中的應(yīng)用5.1顯式時(shí)間推進(jìn)5.1.1原理顯式時(shí)間推進(jìn)方法是一種直接計(jì)算時(shí)間步長內(nèi)狀態(tài)變化的方法。在有限體積法中,顯式方法通常用于求解瞬態(tài)問題,其中每個(gè)時(shí)間步的解僅依賴于前一時(shí)間步的解。這種方法的穩(wěn)定性受到CFL條件的限制,即時(shí)間步長必須足夠小,以確保信息不會(huì)在單個(gè)時(shí)間步內(nèi)跨越多個(gè)網(wǎng)格單元。顯式方法的簡單性和計(jì)算效率使其在許多應(yīng)用中成為首選,尤其是在問題的特征時(shí)間尺度較短時(shí)。5.1.2內(nèi)容顯式時(shí)間推進(jìn)方法的關(guān)鍵在于更新方程的構(gòu)造。對于一個(gè)典型的對流擴(kuò)散方程,顯式更新可以表示為:u其中,uin是網(wǎng)格點(diǎn)i在時(shí)間n的狀態(tài),F(xiàn)i+12n和Fi?12n是網(wǎng)格點(diǎn)i左右邊界在時(shí)間5.1.3示例假設(shè)我們有一個(gè)簡單的1D對流方程,使用顯式時(shí)間推進(jìn)方法求解。方程如下:?其中,F(xiàn)=importnumpyasnp

#定義參數(shù)

nx=100#網(wǎng)格點(diǎn)數(shù)

nt=100#時(shí)間步數(shù)

dx=2/(nx-1)#空間步長

dt=0.025#時(shí)間步長

c=1#對流速度

#初始化網(wǎng)格和狀態(tài)

x=np.linspace(0,2,nx)

u=np.ones(nx)

u[int(.5/dx):int(1/dx+1)]=2

#顯式時(shí)間推進(jìn)

forninrange(nt):

un=u.copy()

foriinrange(1,nx):

u[i]=un[i]-c*dt/dx*(un[i]-un[i-1])

#輸出結(jié)果

print(u)在這個(gè)示例中,我們首先定義了網(wǎng)格和初始狀態(tài),然后使用顯式時(shí)間推進(jìn)方法更新狀態(tài)。注意,為了滿足CFL條件,我們選擇了一個(gè)足夠小的時(shí)間步長。5.2隱式時(shí)間推進(jìn)5.2.1原理隱式時(shí)間推進(jìn)方法在計(jì)算下一個(gè)時(shí)間步的解時(shí),考慮了當(dāng)前時(shí)間步的未知狀態(tài)。這種方法可以提供更好的數(shù)值穩(wěn)定性,允許使用更大的時(shí)間步長,但代價(jià)是需要求解線性或非線性方程組。隱式方法通常使用迭代技術(shù)或直接求解器來找到解。5.2.2內(nèi)容對于一個(gè)典型的對流擴(kuò)散方程,隱式更新可以表示為:15.2.3示例考慮同樣的1D對流方程,但使用隱式時(shí)間推進(jìn)方法求解。我們將使用Python和SciPy庫中的scipy.sparse.linalg.spsolve函數(shù)來求解線性方程組。importnumpyasnp

fromscipy.sparseimportdiags

fromscipy.sparse.linalgimportspsolve

#定義參數(shù)

nx=100

nt=100

dx=2/(nx-1)

dt=1.0

c=1

#初始化網(wǎng)格和狀態(tài)

x=np.linspace(0,2,nx)

u=np.ones(nx)

u[int(.5/dx):int(1/dx+1)]=2

#構(gòu)建隱式矩陣

main_diag=np.ones(nx)*(1+c*dt/dx)

off_diag=np.ones(nx-1)*(-c*dt/dx)

A=diags([main_diag,off_diag,off_diag],[0,-1,1],shape=(nx,nx)).toarray()

#隱式時(shí)間推進(jìn)

forninrange(nt):

b=u.copy()

b[1:]=b[1:]+c*dt/dx*(u[1:]-u[:-1])

u=spsolve(diags([main_diag,off_diag,off_diag],[0,-1,1]),b)

#輸出結(jié)果

print(u)在這個(gè)示例中,我們構(gòu)建了一個(gè)隱式矩陣A,并使用spsolve函數(shù)來求解線性方程組Au=b通過上述示例,我們可以看到顯式和隱式時(shí)間推進(jìn)方法在有限體積法中的應(yīng)用。顯式方法簡單直觀,但受限于CFL條件;而隱式方法雖然計(jì)算復(fù)雜度較高,但提供了更好的穩(wěn)定性,允許使用更大的時(shí)間步長。在實(shí)際應(yīng)用中,選擇哪種方法取決于問題的特性和計(jì)算資源的限制。6空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):多維問題處理6.1維有限體積法6.1.1原理二維有限體積法是將流體動(dòng)力學(xué)方程在二維空間中離散化的一種方法。它基于控制體的概念,將計(jì)算域劃分為一系列非重疊的控制體,每個(gè)控制體的中心點(diǎn)稱為網(wǎng)格節(jié)點(diǎn)。在每個(gè)控制體上,流體的守恒定律被應(yīng)用于計(jì)算流場的數(shù)值解。這種方法在處理復(fù)雜幾何形狀和多物理場問題時(shí)特別有效,因?yàn)樗軌蛑苯釉诓灰?guī)則網(wǎng)格上工作,而無需進(jìn)行復(fù)雜的坐標(biāo)變換。6.1.2內(nèi)容在二維有限體積法中,流體動(dòng)力學(xué)的基本方程,如連續(xù)性方程、動(dòng)量方程和能量方程,被表示為積分形式。對于每個(gè)控制體,這些方程被應(yīng)用于計(jì)算體積內(nèi)的平均值。例如,連續(xù)性方程可以表示為:?在有限體積法中,這個(gè)方程被轉(zhuǎn)化為:d其中,V是控制體的體積,S是控制體的表面。6.1.3示例假設(shè)我們有一個(gè)簡單的二維流體流動(dòng)問題,其中流體在矩形區(qū)域內(nèi)流動(dòng)。我們將使用Python和NumPy庫來實(shí)現(xiàn)一個(gè)基本的二維有限體積法求解器。首先,我們需要定義網(wǎng)格和邊界條件。importnumpyasnp

#定義網(wǎng)格參數(shù)

nx,ny=100,100#網(wǎng)格點(diǎn)數(shù)

dx,dy=1.0,1.0#網(wǎng)格間距

rho=np.zeros((nx,ny))#密度初始化

u=np.zeros((nx,ny))#x方向速度初始化

v=np.zeros((nx,ny))#y方向速度初始化

#定義邊界條件

rho[:,0]=1.0#下邊界

rho[:,-1]=0.0#上邊界

u[0,:]=0.0#左邊界

u[-1,:]=0.0#右邊界

v[0,:]=0.0#左邊界

v[-1,:]=0.0#右邊界

#定義時(shí)間步長和迭代次數(shù)

dt=0.01

nt=1000

#主循環(huán)

forninrange(nt):

#計(jì)算面通量

flux_x=rho*u

flux_y=rho*v

#更新密度

rho[1:-1,1:-1]-=dt/dx*(flux_x[1:-1,2:]-flux_x[1:-1,:-2])\

-dt/dy*(flux_y[2:,1:-1]-flux_y[:-2,1:-1])

#應(yīng)用邊界條件

rho[:,0]=1.0

rho[:,-1]=0.0在這個(gè)例子中,我們使用了一個(gè)簡單的矩形網(wǎng)格,并且假設(shè)流體的流動(dòng)是不可壓縮的。我們通過計(jì)算面通量和更新控制體內(nèi)的密度來模擬流體的流動(dòng)。邊界條件被應(yīng)用于網(wǎng)格的邊緣,以確保流體在邊界上的正確行為。6.2維有限體積法6.2.1原理三維有限體積法是將流體動(dòng)力學(xué)方程在三維空間中離散化的方法。與二維有限體積法類似,它將計(jì)算域劃分為一系列非重疊的控制體,每個(gè)控制體的中心點(diǎn)稱為網(wǎng)格節(jié)點(diǎn)。但是,三維有限體積法需要處理三個(gè)方向上的流動(dòng),因此方程的離散化和求解過程更加復(fù)雜。6.2.2內(nèi)容在三維有限體積法中,流體動(dòng)力學(xué)的基本方程,如連續(xù)性方程、動(dòng)量方程和能量方程,被表示為積分形式。對于每個(gè)控制體,這些方程被應(yīng)用于計(jì)算體積內(nèi)的平均值。例如,連續(xù)性方程可以表示為:?在三維有限體積法中,這個(gè)方程被轉(zhuǎn)化為:d其中,V是控制體的體積,S是控制體的表面。6.2.3示例假設(shè)我們有一個(gè)簡單的三維流體流動(dòng)問題,其中流體在一個(gè)立方體區(qū)域內(nèi)流動(dòng)。我們將使用Python和NumPy庫來實(shí)現(xiàn)一個(gè)基本的三維有限體積法求解器。首先,我們需要定義網(wǎng)格和邊界條件。importnumpyasnp

#定義網(wǎng)格參數(shù)

nx,ny,nz=50,50,50#網(wǎng)格點(diǎn)數(shù)

dx,dy,dz=1.0,1.0,1.0#網(wǎng)格間距

rho=np.zeros((nx,ny,nz))#密度初始化

u=np.zeros((nx,ny,nz))#x方向速度初始化

v=np.zeros((nx,ny,nz))#y方向速度初始化

w=np.zeros((nx,ny,nz))#z方向速度初始化

#定義邊界條件

rho[:,:,0]=1.0#下邊界

rho[:,:,-1]=0.0#上邊界

u[0,:,:]=0.0#左邊界

u[-1,:,:]=0.0#右邊界

v[:,0,:]=0.0#前邊界

v[:,-1,:]=0.0#后邊界

w[:,:,0]=0.0#前邊界

w[:,:,-1]=0.0#后邊界

#定義時(shí)間步長和迭代次數(shù)

dt=0.01

nt=1000

#主循環(huán)

forninrange(nt):

#計(jì)算面通量

flux_x=rho*u

flux_y=rho*v

flux_z=rho*w

#更新密度

rho[1:-1,1:-1,1:-1]-=dt/dx*(flux_x[1:-1,2:,1:-1]-flux_x[1:-1,:-2,1:-1])\

-dt/dy*(flux_y[2:,1:-1,1:-1]-flux_y[:-2,1:-1,1:-1])\

-dt/dz*(flux_z[1:-1,1:-1,2:]-flux_z[1:-1,1:-1,:-2])

#應(yīng)用邊界條件

rho[:,:,0]=1.0

rho[:,:,-1]=0.0在這個(gè)例子中,我們使用了一個(gè)簡單的立方體網(wǎng)格,并且假設(shè)流體的流動(dòng)是不可壓縮的。我們通過計(jì)算面通量和更新控制體內(nèi)的密度來模擬流體的流動(dòng)。邊界條件被應(yīng)用于網(wǎng)格的邊緣,以確保流體在邊界上的正確行為。通過這些示例,我們可以看到二維和三維有限體積法的基本實(shí)現(xiàn)過程。然而,實(shí)際應(yīng)用中,有限體積法的求解過程可能需要更復(fù)雜的數(shù)值方法,如高精度通量計(jì)算、時(shí)間積分方案和非結(jié)構(gòu)化網(wǎng)格處理,以確保計(jì)算的準(zhǔn)確性和穩(wěn)定性。7空氣動(dòng)力學(xué)數(shù)值方法:有限體積法(FVM):特殊問題與算法優(yōu)化7.1激波捕捉技術(shù)7.1.1原理激波捕捉技術(shù)是有限體積法中處理激波和間斷問題的關(guān)鍵方法。在空氣動(dòng)力學(xué)中,激波是流體速度突然變化的區(qū)域,這種變化通常伴隨著壓力、密度和溫度的急劇增加。傳統(tǒng)的數(shù)值方法在處理激波時(shí)容易產(chǎn)生非物理的振蕩,而激波捕捉技術(shù)通過使用非線性穩(wěn)定性限制器和高分辨率格式,能夠準(zhǔn)確地模擬激波和間斷,避免數(shù)值振蕩,提高計(jì)算結(jié)果的準(zhǔn)確性和穩(wěn)定性。7.1.2內(nèi)容激波捕捉技術(shù)的核心在于選擇合適的數(shù)值通量和限制器。數(shù)值通量用于計(jì)算網(wǎng)格單元界面的流體交換,而限制器則用于控制數(shù)值通量的斜率,以確保數(shù)值穩(wěn)定性。常見的限制器包括超限限制器(Superbee)、最小模限制器(Minmod)和VanLeer限制器等。7.1.2.1示例:超限限制器(Superbee)在激波捕捉中的應(yīng)用假設(shè)我們正在模擬一維的激波問題,使用有限體積法進(jìn)行離散。我們采用超限限制器來控制數(shù)值通量的斜率,以避免非物理振蕩。importnumpyasnp

defsuperbee_limiter(r):

"""

Superbeelimiterfunctionforslopelimitinginshockcapturing.

Parameters:

r(numpyarray):Theratioofthedownstreamandupstreamgradients.

Returns:

numpyarray:Thelimitedslope.

"""

returnnp.maximum(0,np.minimum(2*r,1),np.minimum(r,2))

defcalculate_limited_slope(q,dx):

"""

CalculatethelimitedslopeusingSuperbeelimiter.

Parameters:

q(numpyarray):Theconservedvariablesatcellcenters.

dx(float):Thegridspacing.

Returns:

numpyarray:Thelimitedslope.

"""

dq=np.diff(q)/dx

r=np.where(dq[:-1]==0,0,dq[1:]/dq[:-1])

returnsuperbee_limiter(r)

#Exampledata

q=np.array([1,1.5,2,2.5,3,3.5,4,4.5,5])

dx=0.1

#Calculatethelimitedslope

limited_slope=calculate_limited_slope(q,dx)

print("Limitedslope:",limited_slope)在這個(gè)例子中,我們定義了一個(gè)超限限制器函數(shù)superbee_limiter,它接受一個(gè)比率r作為輸入,r是下游和上游梯度的比值。我們還定義了一個(gè)calculate_limited_slope函數(shù),它使用超限限制器來計(jì)算有限體積法中網(wǎng)格單元的有限斜率。最后,我們使用一個(gè)示例數(shù)據(jù)q和網(wǎng)格間距dx來計(jì)算有限斜率,并打印結(jié)果。7.2湍流模擬7.2.1原理湍流是流體動(dòng)力學(xué)中一個(gè)復(fù)雜的現(xiàn)象,其特征是流體運(yùn)動(dòng)的不規(guī)則性和隨機(jī)性。在空氣動(dòng)力學(xué)數(shù)值模擬中,湍流的準(zhǔn)確模擬對于預(yù)測飛機(jī)、汽車等物體的氣動(dòng)性能至關(guān)重要。有限體積法通過使用湍流模型,如Spalart-Allmaras模型、k-ε模型或大渦模擬(LES),來處理湍流問題。這些模型能夠捕捉湍流的統(tǒng)計(jì)特性,從而提供更準(zhǔn)確的流場預(yù)測。7.2.2內(nèi)容湍流模型的選擇取決于模擬的特定問題和所需的精度。Spalart-Allmaras模型是一種單方程模型,適用于邊界層和分離流的模擬。k-ε模型是一種雙方程模型,能夠更準(zhǔn)確地描述湍流的動(dòng)能和耗散率。大渦模擬(LES)則是一種更高級的湍流模擬方法,它直接模擬大尺度渦流,而對小尺度渦流使用亞網(wǎng)格模型。7.2.2.1示例:Spalart-Allmaras湍流模型在有限體積法中的應(yīng)用假設(shè)我們正在使用有限體積法模擬一個(gè)二維湍流問題,我們將使用Spalart-Allmaras湍流模型來處理湍流效應(yīng)。importnumpyasnp

defspalart_allmaras_rhs(q,nu_t,nu,y,delta,c_b1,c_b2,c_w2,c_w3,sigma):

"""

Calculatetheright-handsideoftheSpalart-Allmarasturbulencemodel.

Parameters:

q(numpyarray):Theconservedvariablesatcellcenters.

nu_t(numpyarray):Theturbulentviscosity.

nu(float):Thekinematicviscosity.

y(numpyarray):Thedistancefromthewall.

delta(numpyarray):Thedistancetothenearestwall.

c_b1,c_b2,c_w2,c_w3,sigma(float):Modelconstants.

Returns:

numpyarray:Theright-handsideoftheturbulencemodelequation.

"""

#Calculatetheproductionterm

P=c_b1*q[:,1]*(q[:,0]/delta)

#Calculatethedestructionterm

D=c_b2*nu_t*q[:,0]/delta

#Calculatethediffusionterm

Df=(nu+nu_t*sigma)*(q[:,0]/delta**2)

#Calculatetheright-handside

rhs=P-D-Df

#Applywalldampingfunction

f_w=np.where(y<5*nu*delta/nu_t,1-(y/(3*delta))**3,1)

rhs*=f_w

returnrhs

#Exampledata

q=np.array([[1,0.1],[1.5,0.2],[2,0.3],[2.5,0.4],[3,0.5]])

nu_t=np.array([0.01,0.02,0.03,0.04,0.05])

nu=0.001

y=np.array([0.01,0.02,0.03,0.04,0.05])

delta=np.array([0.1,0.1,0.1,0.1,0.1])

c_b1=0.135

c_b2=0.62

c_w2=0.3

c_w3=2.0

sigma=2.0

#Calculatetheright-handsideoftheSpalart-Allmarasmodel

rhs=spalart_allmaras_rhs(q,nu_t,nu,y,delta,c_b1,c_b2,c_w2,c_w3,sigma)

print("Right-handside:",rhs)在這個(gè)例子中,我們定義了一個(gè)spalart_allmaras_rhs函數(shù),它計(jì)算Spalart-Allmaras湍流模型的右端項(xiàng)。我們使用了示例數(shù)據(jù)q(包含速度和湍流粘度),nu_t(湍流粘度),nu(動(dòng)力粘度),y(壁面距離),delta(到最近壁面的距離),以及模型常數(shù)c_b1、c_b2、c_w2、c_w3和sigma。最后,我們計(jì)算了湍流模型的右端項(xiàng),并打印結(jié)果。通過上述兩個(gè)示例,我們可以看到激波捕捉技術(shù)和湍流模擬在有限體積法中的具體應(yīng)用。這些技術(shù)不僅提高了數(shù)值模擬的精度,還確保了計(jì)算結(jié)果的穩(wěn)定性和可靠性。在實(shí)際的空氣動(dòng)力學(xué)數(shù)值模擬中,選擇合適的激波捕捉技術(shù)和湍流模型是至關(guān)重要的,它們能夠幫助我們更準(zhǔn)確地預(yù)測流體動(dòng)力學(xué)行為,從而優(yōu)化設(shè)計(jì)和提高性能。8案例分析與應(yīng)用8.1飛機(jī)翼型分析在空氣動(dòng)力學(xué)中,飛機(jī)翼型的分析是至關(guān)重要的,它涉及到翼型的氣動(dòng)性能,如升力、阻力和穩(wěn)定性。有限體積法(FVM)作為一種數(shù)值模擬技術(shù),被廣泛應(yīng)用于解決這類問題,尤其是在高精度要求的場景下。8.1.1理論基礎(chǔ)有限體積法基于守恒定律,將計(jì)算域劃分為一系列控制體積,然后在每個(gè)控制體積上應(yīng)用守恒方程。對于飛機(jī)翼型分析,主要關(guān)注的是Navier-Stokes方程,它描述了流體的運(yùn)動(dòng)和動(dòng)力學(xué)特性。在高精度FVM算法中,通常采用高階重構(gòu)和時(shí)間積分方案來提高解的準(zhǔn)確性和穩(wěn)定性。8.1.2實(shí)踐應(yīng)用假設(shè)我們正在分析一個(gè)NACA0012翼型在亞音速流中的氣動(dòng)性能。我們使用OpenFOAM,一個(gè)開源的CFD軟件包,來進(jìn)行數(shù)值模擬。下面是一個(gè)簡化的OpenFOAM案例設(shè)置示例:#設(shè)置計(jì)算網(wǎng)格

blockMeshDict

{

convertToMeters1;

vertices

(

(000)

(100)

(110)

(010)

);

blocks

(

hex(01234567)(10101)simpleGrading(111)

);

edges

(

);

boundary

(

inlet

{

typepatch;

faces

(

(0154)

);

}

outlet

{

typepatch;

faces

(

(2376)

);

}

wing

{

typewall;

faces

(

(1265)

);

}

farField

{

typepatch;

faces

(

(0473)

);

}

);

mergePatchPairs

(

);

}在上述blockMeshDict文件中,我們定義了一個(gè)簡單的二維網(wǎng)格,其中wing邊界代表翼型表面,inlet和outlet分別代表流體的入口和出口,farField代表遠(yuǎn)離翼型的邊界條件。接下來,我們需要設(shè)置流體的物理屬性和求解器參數(shù):#物理屬性

transportProperties

{

transportModelconstant;

nu1e-5;//動(dòng)力粘度

}

#求解器參數(shù)

fvSchemes

{

divSchemes

{

div(phi,U)Gausslinear;

}

gradSchemes

{

grad(U)Gausslinear;

}

laplacianSchemes

{

laplacian(nu,U)Gausslinearcorrected;

}

interpolationSchemes

{

interpolate(U)linear;

}

fluxRequired

{

p;

}

}在transportProperties中,我們設(shè)定了流體的動(dòng)力粘度。而在fvSchemes中,我們選擇了高精度的離散方案,如Gausslinear,以提高解的精度。最后,我們運(yùn)行求解器:#運(yùn)行求解器

simpleFoam通過分析輸出的流場數(shù)據(jù),我們可以計(jì)算翼型的升力和阻力系數(shù),評估其氣動(dòng)性能。8.2發(fā)動(dòng)機(jī)流場模擬發(fā)動(dòng)機(jī)流場模擬是另一個(gè)有限體積法高精度應(yīng)用的領(lǐng)域。它幫助工程師理解發(fā)動(dòng)機(jī)內(nèi)部的流體動(dòng)力學(xué),優(yōu)化設(shè)計(jì),提高效率。8.2.1理論基礎(chǔ)發(fā)動(dòng)機(jī)流場模擬通常涉及復(fù)雜的幾何結(jié)構(gòu)和多相流,如空氣、燃料和燃燒產(chǎn)物。高精度FVM算法需要處理這些復(fù)雜性,同時(shí)保持計(jì)算的穩(wěn)定性和準(zhǔn)確性。這通常涉及到使用高階重構(gòu)方案和自適應(yīng)網(wǎng)格細(xì)化技術(shù)。8.2.2實(shí)踐應(yīng)用使用OpenFOAM進(jìn)行發(fā)動(dòng)機(jī)流場模擬,我們首先需要?jiǎng)?chuàng)建一個(gè)詳細(xì)的幾何模型,然后設(shè)置多相流的物理屬性和邊界條件。下面是一個(gè)簡化的設(shè)置示例:#物理屬性

phaseProperties

{

phases

(

air

fuel

);

phaseair

{

typeincompressible;

rho1.225;//密度

nu1.5e-5;//動(dòng)力粘度

}

phasefuel

{

typeincompressible;

rho800;//密度

nu1e-6;//動(dòng)力粘度

}

}

#求解器參數(shù)

fvSchemes

{

divSchemes

{

div(phi,U)Gausslinear;

div(phi,alpha)Gausslinear;

}

gradSchemes

{

grad(U)Gausslinear;

grad(alpha)Gausslinear;

}

laplacianSchemes

{

laplacian(nu,U)Gausslinearcorrected;

laplacian(alpha)Gausslinearcorrected;

}

interpolationSchemes

{

interpolate(U)linear;

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論