空氣動力學(xué)數(shù)值方法:格子玻爾茲曼方法(LBM):LBM在多相流中的應(yīng)用_第1頁
空氣動力學(xué)數(shù)值方法:格子玻爾茲曼方法(LBM):LBM在多相流中的應(yīng)用_第2頁
空氣動力學(xué)數(shù)值方法:格子玻爾茲曼方法(LBM):LBM在多相流中的應(yīng)用_第3頁
空氣動力學(xué)數(shù)值方法:格子玻爾茲曼方法(LBM):LBM在多相流中的應(yīng)用_第4頁
空氣動力學(xué)數(shù)值方法:格子玻爾茲曼方法(LBM):LBM在多相流中的應(yīng)用_第5頁
已閱讀5頁,還剩24頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

空氣動力學(xué)數(shù)值方法:格子玻爾茲曼方法(LBM):LBM在多相流中的應(yīng)用1空氣動力學(xué)數(shù)值方法:格子玻爾茲曼方法(LBM):LBM在多相流中的應(yīng)用1.1緒論1.1.1LBM方法的歷史背景格子玻爾茲曼方法(LatticeBoltzmannMethod,LBM)起源于20世紀(jì)80年代末,最初由FrancescoHiguera和Rapoport在研究流體動力學(xué)問題時提出。LBM結(jié)合了統(tǒng)計物理和流體動力學(xué)的原理,通過在格子上模擬粒子的碰撞和傳輸過程,來求解流體的宏觀行為。這一方法在90年代得到了迅速發(fā)展,尤其是在并行計算領(lǐng)域,因其天然的并行性和直觀的物理圖像而受到青睞。1.1.2LBM在空氣動力學(xué)中的重要性在空氣動力學(xué)領(lǐng)域,LBM提供了一種高效且直觀的數(shù)值模擬工具。與傳統(tǒng)的數(shù)值方法如有限差分、有限元和有限體積法相比,LBM能夠更自然地處理復(fù)雜的邊界條件和流體動力學(xué)問題,如湍流、多相流和微尺度流動。這使得LBM在模擬飛機(jī)翼型周圍的氣流、發(fā)動機(jī)內(nèi)部的燃燒過程以及風(fēng)洞實驗中的流場分析等方面展現(xiàn)出獨(dú)特的優(yōu)勢。1.1.3多相流研究的挑戰(zhàn)與機(jī)遇多相流,即包含兩種或兩種以上相態(tài)(如氣液兩相、氣固兩相等)的流動,是空氣動力學(xué)研究中的一個復(fù)雜領(lǐng)域。LBM在處理多相流問題時,能夠通過引入相界面模型和相變模型,有效地模擬不同相態(tài)之間的相互作用和轉(zhuǎn)換。然而,多相流的模擬也面臨著相界面穩(wěn)定性、相變過程的準(zhǔn)確描述以及計算效率等挑戰(zhàn)。LBM的并行計算特性和直觀的物理模型為克服這些挑戰(zhàn)提供了機(jī)遇,使其成為研究多相流現(xiàn)象的有力工具。1.2LBM方法在多相流中的應(yīng)用1.2.1相界面模型在LBM中,相界面模型是處理多相流的關(guān)鍵。其中,最常用的是色流模型(ColorGradientModel)和相場模型(PhaseFieldModel)。色流模型通過引入一個額外的標(biāo)量場(顏色場)來區(qū)分不同的相態(tài),而相場模型則通過一個連續(xù)的相場函數(shù)來描述相界面的演化。下面是一個使用Python實現(xiàn)的LBM色流模型的簡化示例:importnumpyasnp

#定義格子速度和權(quán)重

velocities=np.array([[0,0],[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])

weights=np.array([4/9,1/9,1/9,1/9,1/9,1/36,1/36,1/36,1/36])

#初始化分布函數(shù)和顏色場

f=np.zeros((9,100,100))

color_field=np.zeros((100,100))

#設(shè)置邊界條件

#假設(shè)在左側(cè)邊界有氣相,右側(cè)邊界有液相

color_field[:,0]=1#氣相

color_field[:,-1]=-1#液相

#LBM迭代

fortinrange(1000):

#流動

foriinrange(9):

f[i,:,:]=np.roll(f[i,:,:],velocities[i],axis=(0,1))

#碰撞

rho=np.sum(f,axis=0)

feq=np.outer(weights,rho)

f+=-3*(f-feq)

#更新顏色場

color_field=np.sum(f*np.array([1,1,1,-1,-1,1,-1,-1,1]),axis=0)/rho

#可視化顏色場

importmatplotlib.pyplotasplt

plt.imshow(color_field,cmap='coolwarm')

plt.colorbar()

plt.show()1.2.2相變模型相變模型在LBM中用于描述物質(zhì)從一種相態(tài)轉(zhuǎn)變?yōu)榱硪环N相態(tài)的過程,如水的蒸發(fā)和凝結(jié)。這通常涉及到能量的交換和相變潛熱的處理。在LBM中,可以通過引入溫度場和能量傳輸方程來模擬相變過程。下面是一個使用LBM模擬水蒸發(fā)過程的簡化示例:importnumpyasnp

#定義格子速度和權(quán)重

velocities=np.array([[0,0],[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])

weights=np.array([4/9,1/9,1/9,1/9,1/9,1/36,1/36,1/36,1/36])

#初始化分布函數(shù)、溫度場和相場

f=np.zeros((9,100,100))

T=np.zeros((100,100))

phase_field=np.zeros((100,100))

#設(shè)置初始條件

T[:,0]=100#高溫區(qū)域,水蒸發(fā)

T[:,-1]=0#低溫區(qū)域,水凝結(jié)

#LBM迭代

fortinrange(1000):

#流動

foriinrange(9):

f[i,:,:]=np.roll(f[i,:,:],velocities[i],axis=(0,1))

#碰撞

rho=np.sum(f,axis=0)

feq=np.outer(weights,rho)

f+=-3*(f-feq)

#更新溫度場

T=np.sum(f*np.array([1,1,1,-1,-1,1,-1,-1,1]),axis=0)/rho

#相變處理

phase_field=np.where(T>50,1,-1)#假設(shè)50是相變溫度

#可視化相場

importmatplotlib.pyplotasplt

plt.imshow(phase_field,cmap='coolwarm')

plt.colorbar()

plt.show()1.2.3并行計算LBM的并行計算特性是其在多相流模擬中的一大優(yōu)勢。由于LBM的計算過程基于格子上的局部更新,這使得LBM非常適合在并行架構(gòu)上運(yùn)行,如GPU和多核CPU。下面是一個使用Python的multiprocessing庫實現(xiàn)LBM并行計算的簡化示例:importnumpyasnp

frommultiprocessingimportPool

#定義格子速度和權(quán)重

velocities=np.array([[0,0],[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])

weights=np.array([4/9,1/9,1/9,1/9,1/9,1/36,1/36,1/36,1/36])

#初始化分布函數(shù)

f=np.zeros((9,100,100))

#并行計算函數(shù)

deflbm_step(i):

globalf

f[i,:,:]=np.roll(f[i,:,:],velocities[i],axis=(0,1))

rho=np.sum(f,axis=0)

feq=np.outer(weights,rho)

f[i,:,:]+=-3*(f[i,:,:]-feq[i])

#使用并行計算進(jìn)行LBM迭代

if__name__=='__main__':

pool=Pool(processes=8)

fortinrange(1000):

pool.map(lbm_step,range(9))

pool.close()

pool.join()通過上述示例,我們可以看到LBM在多相流模擬中的應(yīng)用,包括相界面模型、相變模型以及并行計算的實現(xiàn)。這些示例雖然簡化,但展示了LBM方法的基本思想和實現(xiàn)步驟,為深入研究和應(yīng)用LBM提供了基礎(chǔ)。2格子玻爾茲曼方法基礎(chǔ)2.1LBM的基本原理格子玻爾茲曼方法(LatticeBoltzmannMethod,LBM)是一種基于粒子動力學(xué)的流體模擬方法,它通過模擬流體中粒子的碰撞和傳輸過程來求解流體力學(xué)問題。LBM的核心思想是將流體視為大量微觀粒子的集合,這些粒子在離散的格子上進(jìn)行運(yùn)動,遵循特定的運(yùn)動規(guī)則和碰撞規(guī)則。這種方法能夠有效地模擬流體的復(fù)雜行為,如湍流、多相流等,同時保持計算的高效性。2.1.1粒子運(yùn)動在LBM中,粒子的運(yùn)動被簡化為在格子上的跳躍,每個粒子在每個時間步長內(nèi)只能從一個格點(diǎn)移動到另一個格點(diǎn)。粒子的分布函數(shù)fix,t描述了在時間t,位置2.1.2碰撞規(guī)則粒子在格點(diǎn)上進(jìn)行碰撞,碰撞過程通過碰撞算子描述,最常用的碰撞算子是Bhatnagar-Gross-Krook(BGK)算子。碰撞后,粒子的分布函數(shù)更新為:f其中,ei是粒子的運(yùn)動方向,τ是松弛時間,f2.2LBM的數(shù)學(xué)模型LBM的數(shù)學(xué)模型基于Boltzmann方程,但在實際應(yīng)用中,為了簡化計算,通常采用離散化的Boltzmann方程,即LatticeBoltzmann方程。該方程描述了粒子分布函數(shù)隨時間和空間的變化:f其中,F(xiàn)i2.2.1平衡態(tài)分布函數(shù)平衡態(tài)分布函數(shù)fif其中,wi是粒子沿著方向i的權(quán)重,ρx,2.3LBM與傳統(tǒng)CFD方法的比較LBM與傳統(tǒng)的計算流體力學(xué)(ComputationalFluidDynamics,CFD)方法相比,具有以下特點(diǎn):微觀模擬:LBM基于粒子動力學(xué),能夠更自然地模擬流體的微觀行為,如粘性、擴(kuò)散等。并行計算:LBM的計算過程易于并行化,適合大規(guī)模并行計算環(huán)境。邊界條件處理:LBM在處理復(fù)雜的邊界條件時更為靈活,能夠更準(zhǔn)確地模擬流體與固體邊界之間的相互作用。多相流模擬:LBM在模擬多相流(如氣液兩相流、氣固兩相流)時具有優(yōu)勢,能夠有效地處理相界面的動態(tài)變化。2.3.1示例代碼:二維LBM模擬下面是一個使用Python實現(xiàn)的二維LBM模擬的簡單示例。該示例模擬了一個在矩形域內(nèi)的流體流動,域的底部設(shè)置為固定速度邊界條件,模擬流體的流動。importnumpyasnp

importmatplotlib.pyplotasplt

#定義格子速度和權(quán)重

velocities=np.array([[0,0],[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])

weights=np.array([4/9,1/9,1/9,1/9,1/9,1/36,1/36,1/36,1/36])

#初始化分布函數(shù)

definit_distribution_function(nx,ny):

f=np.zeros((9,nx,ny))

rho=np.ones((nx,ny))

u=np.zeros((2,nx,ny))

returnf,rho,u

#計算平衡態(tài)分布函數(shù)

defequilibrium_distribution_function(rho,u):

cu=np.dot(velocities,u)

uu=np.sum(u**2,axis=0)

feq=np.outer(weights,rho)*(1+3*cu+4.5*cu**2-1.5*uu)

returnfeq

#更新分布函數(shù)

defupdate_distribution_function(f,rho,u,tau):

feq=equilibrium_distribution_function(rho,u)

f[1:9]=f[1:9]+(1.0/tau)*(feq[1:9]-f[1:9])

returnf

#流體流動模擬

deflbm_simulation(nx,ny,steps,tau):

f,rho,u=init_distribution_function(nx,ny)

forstepinrange(steps):

#碰撞

f=update_distribution_function(f,rho,u,tau)

#流動

foriinrange(1,9):

f[i]=np.roll(f[i],velocities[i],axis=(1,2))

#更新宏觀物理量

rho=np.sum(f,axis=0)

u=np.dot(velocities,f)/rho

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

u[1,:,0]=0.1#底部速度邊界條件

u[1,:,-1]=0#右側(cè)無滑移邊界條件

u[0,:,0]=0#底部無滑移邊界條件

u[0,:,-1]=0#右側(cè)無滑移邊界條件

returnrho,u

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

nx,ny=100,100

steps=1000

tau=0.7

#運(yùn)行模擬

rho,u=lbm_simulation(nx,ny,steps,tau)

#可視化結(jié)果

plt.imshow(rho,cmap='hot',interpolation='nearest')

plt.colorbar()

plt.show()2.3.2代碼解釋初始化分布函數(shù):init_distribution_function函數(shù)初始化分布函數(shù)f,密度ρ和速度u。計算平衡態(tài)分布函數(shù):equilibrium_distribution_function函數(shù)根據(jù)當(dāng)前的密度和速度計算平衡態(tài)分布函數(shù)。更新分布函數(shù):update_distribution_function函數(shù)執(zhí)行碰撞過程,更新分布函數(shù)。流體流動模擬:lbm_simulation函數(shù)執(zhí)行整個LBM模擬過程,包括碰撞、流動、更新宏觀物理量和應(yīng)用邊界條件??梢暬Y(jié)果:使用matplotlib庫可視化模擬后的密度分布。通過上述代碼,我們可以看到LBM在模擬流體流動時的基本流程和方法。LBM的并行計算特性使得它在處理大規(guī)模流體模擬問題時具有顯著優(yōu)勢。3LBM在單相流中的應(yīng)用3.1單相流的LBM模擬格子玻爾茲曼方法(LatticeBoltzmannMethod,LBM)是一種基于粒子動力學(xué)的流體模擬方法,特別適用于模擬單相流。LBM的核心是通過粒子在格子上的碰撞和流動作用來模擬流體的宏觀行為。下面通過一個簡單的Python示例來展示如何使用LBM模擬單相流。importnumpyasnp

#定義格子速度

velocities=np.array([[0,0],[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])

#初始化分布函數(shù)

definit_distribution_function(nx,ny):

f=np.zeros((9,nx,ny))

rho=np.ones((nx,ny))

u=np.zeros((2,nx,ny))

foriinrange(9):

f[i]=rho/9.0

returnf,rho,u

#流動更新

deflbm_step(f,rho,u):

#碰撞

feq=np.zeros_like(f)

foriinrange(9):

feq[i]=rho*(1.0/9.0+3.0*np.dot(velocities[i],u)/2.0+9.0*np.dot(velocities[i],u)**2/4.0-3.0*np.sum(u**2)/4.0)

f-=(f-feq)

#流動

f_new=np.zeros_like(f)

foriinrange(9):

f_new[i]=np.roll(f[i],velocities[i],axis=(1,2))

returnf_new

#主程序

nx,ny=100,100

f,rho,u=init_distribution_function(nx,ny)

forstepinrange(1000):

f=lbm_step(f,rho,u)

#更新密度和速度

rho=np.sum(f,axis=0)

u=np.zeros((2,nx,ny))

foriinrange(9):

u+=velocities[i]*f[i]

u/=rho

#打印最終的流體速度分布

print(u)3.1.1解釋此代碼示例初始化了一個100x100的網(wǎng)格,并定義了LBM中的九個格子速度。通過init_distribution_function函數(shù)初始化分布函數(shù)、密度和速度。lbm_step函數(shù)執(zhí)行了LBM的碰撞和流動步驟,更新分布函數(shù)。在主循環(huán)中,分布函數(shù)被更新,然后計算新的密度和速度。最后,打印出網(wǎng)格上的速度分布。3.2邊界條件處理在LBM中,邊界條件的處理至關(guān)重要,它直接影響流體模擬的準(zhǔn)確性。常見的邊界條件包括無滑移邊界條件和周期性邊界條件。下面的代碼示例展示了如何在Python中實現(xiàn)無滑移邊界條件。defapply_boundary_conditions(f,rho,u,nx,ny):

#無滑移邊界條件

f[:,0,:]=f[:,1,:]-2.0*velocities[:,0]*f[:,1,:]

f[:,nx-1,:]=f[:,nx-2,:]-2.0*velocities[:,0]*f[:,nx-2,:]

f[:,:,0]=f[:,:,1]-2.0*velocities[:,1]*f[:,:,1]

f[:,:,ny-1]=f[:,:,ny-2]-2.0*velocities[:,1]*f[:,:,ny-2]

#更新邊界上的密度和速度

rho[0,:]=np.sum(f[:,0,:],axis=0)

rho[nx-1,:]=np.sum(f[:,nx-1,:],axis=0)

rho[:,0]=np.sum(f[:,:,0],axis=0)

rho[:,ny-1]=np.sum(f[:,:,ny-1],axis=0)

u[:,0,:]=0.0

u[:,nx-1,:]=0.0

u[:,:,0]=0.0

u[:,:,ny-1]=0.0

returnf,rho,u

#在主循環(huán)中應(yīng)用邊界條件

forstepinrange(1000):

f=lbm_step(f,rho,u)

f,rho,u=apply_boundary_conditions(f,rho,u,nx,ny)3.2.1解釋apply_boundary_conditions函數(shù)在網(wǎng)格的邊界上應(yīng)用無滑移邊界條件,即邊界上的流體速度被設(shè)置為零。通過反射邊界上的分布函數(shù)來實現(xiàn)這一點(diǎn),同時更新邊界上的密度和速度,確保流體在邊界上的行為符合物理規(guī)律。3.3流體動力學(xué)性質(zhì)的計算LBM模擬后,可以計算流體的宏觀動力學(xué)性質(zhì),如壓力、速度和溫度。下面的代碼示例展示了如何從分布函數(shù)計算流體的速度。defcompute_fluid_properties(f):

#計算密度

rho=np.sum(f,axis=0)

#計算速度

u=np.zeros((2,nx,ny))

foriinrange(9):

u+=velocities[i]*f[i]

u/=rho

#計算壓力(假設(shè)理想氣體)

p=rho*1.0/3.0

returnrho,u,p

#計算流體性質(zhì)

rho,u,p=compute_fluid_properties(f)

#打印壓力分布

print(p)3.3.1解釋compute_fluid_properties函數(shù)從分布函數(shù)f中計算出流體的密度rho、速度u和壓力p。密度是分布函數(shù)的總和,速度是分布函數(shù)與格子速度的加權(quán)和,而壓力在理想氣體假設(shè)下是密度的線性函數(shù)。這些計算提供了LBM模擬結(jié)果的宏觀描述,可用于進(jìn)一步的流體動力學(xué)分析。通過上述示例,我們可以看到LBM在單相流模擬中的基本應(yīng)用,包括模擬步驟、邊界條件處理和流體動力學(xué)性質(zhì)的計算。這些原理和方法是理解和應(yīng)用LBM的關(guān)鍵。4多相流理論基礎(chǔ)4.1多相流的定義與分類多相流是指在流體系統(tǒng)中同時存在兩種或兩種以上不同相態(tài)的流動現(xiàn)象。這些相態(tài)可以是氣體、液體、固體或它們的任意組合。多相流在自然界和工業(yè)應(yīng)用中普遍存在,如石油開采、化工過程、能源轉(zhuǎn)換、環(huán)境工程和生物醫(yī)學(xué)等領(lǐng)域。4.1.1分類多相流主要可以分為以下幾類:氣液兩相流:如沸騰、噴霧、泡沫等。氣固兩相流:如氣力輸送、粉塵爆炸等。液固兩相流:如漿體輸送、水下挖掘等。氣液固三相流:如氣泡在液體中的攜帶固體顆粒流動。4.2界面動力學(xué)界面動力學(xué)研究的是不同相態(tài)之間的界面行為,包括界面的形成、移動、變形和消失等過程。在多相流中,界面的動態(tài)特性對流體的宏觀行為有著重要影響,如界面張力、接觸角、潤濕性等。4.2.1界面張力界面張力是界面層中分子間相互作用的結(jié)果,它使得界面傾向于最小化其表面積。在多相流模擬中,界面張力的準(zhǔn)確描述對于預(yù)測界面形狀和流動穩(wěn)定性至關(guān)重要。4.2.2接觸角與潤濕性接觸角描述了液體與固體表面接觸時的界面幾何形狀,潤濕性則反映了液體對固體表面的附著能力。這些特性在多相流的許多應(yīng)用中起著關(guān)鍵作用,如微流控、涂料和清潔劑的開發(fā)等。4.3相間相互作用在多相流中,不同相態(tài)之間的相互作用是復(fù)雜且多樣的,包括動量、能量和質(zhì)量的交換。這些相互作用的準(zhǔn)確模擬對于理解和預(yù)測多相流行為至關(guān)重要。4.3.1動量交換動量交換發(fā)生在不同相態(tài)之間的碰撞和拖曳過程中。例如,在氣液兩相流中,氣泡的上升會受到液體的阻力,同時也會對液體產(chǎn)生推力,這種相互作用可以通過動量方程來描述。4.3.2能量交換能量交換主要涉及相變過程,如蒸發(fā)和凝結(jié)。在這些過程中,能量從一個相態(tài)轉(zhuǎn)移到另一個相態(tài),導(dǎo)致溫度和相態(tài)的變化。能量方程是模擬這種交換的基礎(chǔ)。4.3.3質(zhì)量交換質(zhì)量交換發(fā)生在相變過程中,如氣泡的蒸發(fā)和凝結(jié),或固體顆粒在流體中的溶解和沉淀。質(zhì)量守恒方程是描述這種交換的關(guān)鍵。4.4LBM在多相流中的應(yīng)用格子玻爾茲曼方法(LatticeBoltzmannMethod,LBM)是一種基于粒子動力學(xué)的數(shù)值模擬方法,特別適用于流體動力學(xué)問題的求解。LBM通過在離散的格子上模擬粒子的碰撞和傳輸過程,能夠有效地模擬流體的宏觀行為。4.4.1LBM模擬氣液兩相流在LBM中模擬氣液兩相流,通常采用相場方法。相場是一個連續(xù)的標(biāo)量場,用于區(qū)分不同的相態(tài)。通過引入相場方程和相應(yīng)的界面張力模型,LBM能夠模擬氣泡的形成、變形和合并等復(fù)雜現(xiàn)象。4.4.1.1示例代碼#LBM模擬氣液兩相流的簡化示例

importnumpyasnp

#定義格子速度和權(quán)重

velocities=np.array([[0,0],[1,0],[0,1],[-1,0],[0,-1],[1,1],[-1,1],[-1,-1],[1,-1]])

weights=np.array([4/9,1/9,1/9,1/9,1/9,1/36,1/36,1/36,1/36])

#初始化分布函數(shù)

definit_distribution_function(shape):

f=np.zeros((9,)+shape)

rho=np.ones(shape)

u=np.zeros(shape+(2,))

foriinrange(9):

f[i]=weights[i]*rho*(1+3*np.sum(velocities[i]*u,axis=-1)+

4.5*np.sum(np.square(velocities[i])*np.square(u),axis=-1)-

1.5*np.sum(np.square(u),axis=-1))

returnf

#流動更新步驟

deflbm_step(f,omega):

#碰撞步驟

f_eq=equilibrium(f)

f-=omega*(f-f_eq)

#流動步驟

f=stream(f)

returnf

#碰撞步驟

defequilibrium(f):

#簡化示例,實際應(yīng)用中需要根據(jù)流體狀態(tài)計算平衡分布函數(shù)

returnf

#流動步驟

defstream(f):

#簡化示例,實際應(yīng)用中需要根據(jù)格子速度更新分布函數(shù)

returnf

#主程序

shape=(100,100)#模擬區(qū)域的形狀

f=init_distribution_function(shape)

omega=0.5#碰撞參數(shù)

#進(jìn)行多次LBM迭代

for_inrange(1000):

f=lbm_step(f,omega)

#輸出最終的流體密度和速度

rho=np.sum(f,axis=0)

u=np.zeros(shape+(2,))

foriinrange(9):

u+=velocities[i]*(f[i]-weights[i]*rho)4.4.2LBM模擬氣固兩相流在氣固兩相流中,LBM可以模擬氣體在固體顆粒周圍的流動,以及固體顆粒對氣體流動的影響。通過引入固體邊界條件和顆粒運(yùn)動模型,LBM能夠處理顆粒的沉積、懸浮和再懸浮等現(xiàn)象。4.4.3LBM模擬液固兩相流液固兩相流的LBM模擬通常涉及顆粒在液體中的運(yùn)動和相互作用。通過結(jié)合顆粒動力學(xué)和流體動力學(xué)模型,LBM能夠預(yù)測顆粒的軌跡、液體的流動模式以及顆粒對流體流動的影響。4.4.4LBM模擬氣液固三相流氣液固三相流的LBM模擬是最復(fù)雜的,它需要同時處理氣泡、液滴和固體顆粒之間的相互作用。通過綜合使用相場方法、顆粒動力學(xué)模型和界面張力模型,LBM能夠模擬這種復(fù)雜流體系統(tǒng)的行為。4.5結(jié)論格子玻爾茲曼方法在多相流模擬中展現(xiàn)出強(qiáng)大的能力,能夠處理復(fù)雜的界面動力學(xué)和相間相互作用。通過適當(dāng)?shù)哪P秃退惴?,LBM能夠為多相流的研究和應(yīng)用提供準(zhǔn)確的數(shù)值預(yù)測。然而,LBM的準(zhǔn)確性和效率在很大程度上取決于模型參數(shù)的選擇和邊界條件的處理,因此在實際應(yīng)用中需要仔細(xì)校準(zhǔn)和驗證。請注意,上述代碼示例是一個高度簡化的LBM框架,實際應(yīng)用中需要根據(jù)具體問題引入更復(fù)雜的物理模型和邊界條件處理。5LBM在多相流中的模擬技術(shù)5.1多相LBM模型的構(gòu)建在構(gòu)建多相LBM模型時,關(guān)鍵在于如何描述不同相之間的相互作用。一種廣泛使用的方法是基于色散力(dispersionforce)的模型,如Cahn-Hilliard方程與LBM的結(jié)合。此模型能夠處理復(fù)雜的界面動力學(xué),包括界面的形成、移動和消失。5.1.1Cahn-Hilliard-LBM模型Cahn-Hilliard方程描述了兩相系統(tǒng)中組分的擴(kuò)散過程,而LBM則負(fù)責(zé)流體動力學(xué)的模擬。結(jié)合這兩種方法,可以得到一個能夠模擬多相流的模型。5.1.1.1數(shù)學(xué)描述Cahn-Hilliard方程可以寫作:?其中,c是組分濃度,D是擴(kuò)散系數(shù),f是自由能函數(shù)。LBM的離散化方程為:f其中,fi是粒子分布函數(shù),τ是松弛時間,fie5.1.2代碼示例以下是一個使用Python實現(xiàn)的Cahn-Hilliard-LBM模型的簡化版本:importnumpyasnp

#定義LBM參數(shù)

nx,ny=100,100

D=0.1

dt=0.01

tau=1.0/(3.0*D+0.5)

#初始化濃度場

c=np.random.rand(nx,ny)

#初始化速度場和壓力場

u=np.zeros((2,nx,ny))

p=np.zeros((nx,ny))

#定義LBM的分布函數(shù)

deflbm_distribution(c,u,p):

#簡化示例,實際應(yīng)用中需要更復(fù)雜的平衡分布函數(shù)

feq=np.zeros((9,nx,ny))

foriinrange(9):

feq[i]=w[i]*(c*(1.0+3.0*u[i]+4.5*u[i]**2-1.5*np.sum(u**2)))

returnfeq

#定義Cahn-Hilliard方程的自由能函數(shù)

deffree_energy(c):

return0.25*(c**2-1)**2

#更新規(guī)則

defupdate(c,u,p):

#更新濃度場

c_new=c+dt*(D*laplacian(c)-laplacian(free_energy(c)))

#更新速度場和壓力場

f=lbm_distribution(c,u,p)

f_new=f-(1.0/tau)*(f-lbm_distribution(c_new,u,p))

#更新速度和壓力

u_new=np.sum(f_new*np.array([[0,1,0,-1,0,1,-1,-1,1]]),axis=0)/np.sum(f_new)

p_new=np.sum(f_new)

returnc_new,u_new,p_new

#主循環(huán)

fortinrange(1000):

c,u,p=update(c,u,p)5.1.2.1解釋上述代碼中,lbm_distribution函數(shù)用于計算LBM的平衡分布函數(shù),free_energy函數(shù)定義了Cahn-Hilliard方程的自由能函數(shù),update函數(shù)實現(xiàn)了濃度場、速度場和壓力場的更新。注意,為了簡化示例,這里省略了LBM的詳細(xì)計算過程,如粒子分布函數(shù)的碰撞和流過程,以及Cahn-Hilliard方程中自由能函數(shù)的精確形式。5.2界面追蹤方法在多相流模擬中,界面追蹤是至關(guān)重要的。LBM通過粒子分布函數(shù)的演化自然地追蹤界面,但為了提高精度和穩(wěn)定性,可以采用額外的界面追蹤方法,如VOF(VolumeofFluid)方法。5.2.1VOF方法VOF方法通過追蹤流體體積分?jǐn)?shù)來確定界面位置。在LBM框架下,可以將體積分?jǐn)?shù)作為額外的標(biāo)量場進(jìn)行模擬,與濃度場類似。5.2.1.1數(shù)學(xué)描述體積分?jǐn)?shù)C滿足以下方程:?其中,u是流體速度。5.2.2代碼示例以下是一個使用Python實現(xiàn)的VOF方法追蹤界面的簡化版本:#初始化體積分?jǐn)?shù)場

C=np.zeros((nx,ny))

#更新規(guī)則

defupdate_vof(C,u):

#計算體積分?jǐn)?shù)的流

C_flow=np.zeros((nx,ny))

foriinrange(2):

C_flow+=u[i]*np.gradient(C,axis=i)

#更新體積分?jǐn)?shù)

C_new=C-dt*C_flow

returnC_new

#主循環(huán)

fortinrange(1000):

C=update_vof(C,u)5.2.2.1解釋update_vof函數(shù)實現(xiàn)了體積分?jǐn)?shù)場的更新,通過計算體積分?jǐn)?shù)的流來追蹤界面的移動。在實際應(yīng)用中,需要與LBM的速度場更新同步進(jìn)行,以確保界面追蹤的準(zhǔn)確性和穩(wěn)定性。5.3相變過程的模擬在多相流中,相變過程(如蒸發(fā)和凝結(jié))的模擬是復(fù)雜但重要的。LBM可以通過引入相變模型,如基于熱力學(xué)的模型,來處理相變。5.3.1基于熱力學(xué)的相變模型此模型基于熱力學(xué)原理,通過計算相界面附近的溫度和壓力,確定相變的發(fā)生。在LBM中,可以通過引入溫度場和相應(yīng)的分布函數(shù)來實現(xiàn)。5.3.1.1數(shù)學(xué)描述溫度場T滿足以下方程:?其中,ρ是密度,cp是比熱容,q是熱流,Q5.3.2代碼示例以下是一個使用Python實現(xiàn)的基于熱力學(xué)的相變模型的簡化版本:#初始化溫度場

T=np.zeros((nx,ny))

#定義相變熱源

defphase_change_heat_source(C,T):

#簡化示例,實際應(yīng)用中需要更復(fù)雜的相變熱源函數(shù)

Q=np.where(C>0.5,1.0,-1.0)*(T-T0)

returnQ

#更新規(guī)則

defupdate_temperature(T,u,rho,cp,q,Q):

#計算溫度的流

T_flow=np.zeros((nx,ny))

foriinrange(2):

T_flow+=u[i]*np.gradient(T,axis=i)

#更新溫度場

T_new=T-dt*(T_flow+(1.0/(rho*cp))*(laplacian(q)+Q))

returnT_new

#主循環(huán)

fortinrange(1000):

Q=phase_change_heat_source(C,T)

T=update_temperature(T,u,rho,cp,q,Q)5.3.2.1解釋phase_change_heat_source函數(shù)用于計算相變熱源,update_temperature函數(shù)實現(xiàn)了溫度場的更新。在實際應(yīng)用中,需要與LBM的速度場和濃度場更新同步進(jìn)行,以確保相變過程的準(zhǔn)確模擬。注意,為了簡化示例,這里省略了溫度場和熱流的詳細(xì)計算過程,如溫度分布函數(shù)的碰撞和流過程,以及熱流的計算。通過上述方法,LBM可以有效地模擬多相流中的復(fù)雜現(xiàn)象,包括界面動力學(xué)和相變過程。然而,實際應(yīng)用中需要考慮更多的細(xì)節(jié),如網(wǎng)格的大小、時間步長的選擇、邊界條件的處理等,以確保模擬的準(zhǔn)確性和穩(wěn)定性。6案例研究與應(yīng)用6.1LBM在氣泡動力學(xué)中的應(yīng)用6.1.1原理格子玻爾茲曼方法(LBM)在氣泡動力學(xué)中的應(yīng)用主要集中在模擬氣泡在流體中的運(yùn)動、變形以及與固體表面的相互作用。LBM通過模擬微觀粒子的碰撞和傳輸過程,能夠有效地處理復(fù)雜的流體動力學(xué)問題,特別是在多相流中,如氣泡或液滴在流體中的行為。LBM的氣泡動力學(xué)模擬通常涉及界面張力模型、多相流模型以及相應(yīng)的邊界條件處理。6.1.2內(nèi)容在LBM中,氣泡動力學(xué)的模擬通常包括以下幾個關(guān)鍵步驟:初始化:設(shè)定流體和氣泡的初始條件,包括速度、密度和界面位置。流體動力學(xué)模擬:使用LBM更新流體的速度和密度,考慮到氣泡的存在及其對流場的影響。界面追蹤:通過界面張力模型追蹤氣泡界面的移動,確保氣泡形狀的準(zhǔn)確模擬。邊界條件處理:正確處理氣泡與固體表面的相互作用,包括粘附、滑動和脫離。6.1.3示例以下是一個使用Python和LBM模擬氣泡在流體中上升的簡化示例。此示例使用了開源庫lbmpy,它提供了一個高效且易于使用的LBM框架。importlbmpyaslb

importpystencilsasps

importnumpyasnp

#定義流體和氣泡的參數(shù)

fluid_density=1.0

bubble_density=0.5

viscosity=0.01

bubble_radius=10

grid_size=(200,200)

#創(chuàng)建LBM網(wǎng)格

lbm_grid=lb.Grid(lb.D2Q9)

#初始化流場

field=lb.create_lb_field(lbm_grid,grid_size)

field[:,:]=fluid_density

#創(chuàng)建氣泡

bubble_mask=np.zeros(grid_size)

bubble_mask[grid_size[0]//2-bubble_radius:grid_size[0]//2+bubble_radius,

grid_size[1]//2-bubble_radius:grid_size[1]//2+bubble_radius]=1

bubble_mask=lb.create_mask(bubble_mask,lbm_grid)

#設(shè)置氣泡內(nèi)的密度

field[bubble_mask]=bubble_density

#設(shè)置邊界條件

lb.set_boundary_conditions(field,lbm_grid,{'top':lb.BounceBack,'bottom':lb.BounceBack,

'left':lb.BounceBack,'right':lb.BounceBack})

#進(jìn)行LBM迭代

foriinrange(1000):

lb.stream_and_collide(field,lbm_grid,viscosity)

lb.update_boundary_conditions(field,lbm_grid)

#可視化結(jié)果

importmatplotlib.pyplotasplt

plt.imshow(field[:,:],cmap='hot',interpolation='nearest')

plt.show()6.1.4描述此代碼示例首先導(dǎo)入了必要的庫,然后定義了流體和氣泡的物理參數(shù)。接著,創(chuàng)建了一個LBM網(wǎng)格和流場,初始化了氣泡的位置和密度。通過設(shè)置邊界條件,確保流體在邊界上反彈,模擬了一個封閉的容器。最后,通過迭代LBM的流和碰撞步驟,模擬了氣泡在流體中的上升過程,并使用matplotlib庫可視化了最終的流場密度分布。6.2LBM在液滴碰撞中的模擬6.2.1原理LBM在液滴碰撞中的應(yīng)用主要關(guān)注液滴之間的相互作用,包括碰撞、合并和分裂。通過LBM,可以精確地模擬液滴界面的動態(tài)變化,以及液滴內(nèi)部和周圍流體的流動。液滴碰撞的模擬通常需要考慮液滴的表面張力、粘度以及碰撞時的流體動力學(xué)效應(yīng)。6.2.2內(nèi)容液滴碰撞的LBM模擬包括:初始化:設(shè)定兩個或多個液滴的初始位置、速度和密度。流體動力學(xué)模擬:使用LBM更新流體的速度和密度,同時處理液滴之間的相互作用。界面追蹤:通過表面張力模型追蹤液滴界面的移動,確保液滴形狀的準(zhǔn)確模擬。碰撞檢測與處理:檢測液滴之間的碰撞,并根據(jù)碰撞類型(合并或分裂)更新液滴的形狀和位置。6.2.3示例以下是一個使用Python和LBM模擬兩個液滴碰撞的簡化示例。此示例同樣使用了lbmpy庫。importlbmpyaslb

importpystencilsasps

importnumpyasnp

#定義流體和液滴的參數(shù)

fluid_density=1.0

drop_density=1.5

viscosity=0.01

drop_radius=10

grid_size=(200,200)

#創(chuàng)建LBM網(wǎng)格

lbm_grid=lb.Grid(lb.D2Q9)

#初始化流場

field=lb.create_lb_field(lbm_grid,grid_size)

field[:,:]=fluid_density

#創(chuàng)建兩個液滴

drop1_mask=np.zeros(grid_size)

drop1_mask[grid_size[0]//4-drop_radius:grid_size[0]//4+drop_radius,

grid_size[1]//2-drop_radius:grid_size[1]//2+drop_radius]=1

drop1_mask=lb.create_mask(drop1_mask,lbm_grid)

drop2_mask=np.zeros(grid_size)

drop2_mask[grid_size[0]//4*3-drop_radius:grid_size[0]//4*3+drop_radius,

grid_size[1]//2-drop_radius:grid_size[1]//2+drop_radius]=1

drop2_mask=lb.create_mask(drop2_mask,lbm_grid)

#設(shè)置液滴內(nèi)的密度

field[drop1_mask]=drop_density

field[drop2_mask]=drop_density

#設(shè)置邊界條件

lb.set_boundary_conditions(field,lbm_grid,{'top':lb.BounceBack,'bottom':lb.BounceBack,

'left':lb.BounceBack,'right':lb.BounceBack})

#進(jìn)行LBM迭代

foriinrange(1000):

lb.stream_and_collide(field,lbm_grid,viscosity)

lb.update_boundary_conditions(field,lbm_grid)

#可視化結(jié)果

importmatplotlib.pyplotasplt

plt.imshow(field[:,:],cmap='hot',interpolation='nearest')

plt.show()6.2.4描述此代碼示例首先定義了流體和液滴的物理參數(shù),然后創(chuàng)建了LBM網(wǎng)格和流場。通過初始化兩個液滴的位置和密度,模擬了它們在流體中的狀態(tài)。通過迭代LBM的流和碰撞步驟,模擬了液滴在流體中的運(yùn)動,直到它們相遇并可能合并。最終,使用matplotlib庫可視化了流場密度分布,展示了液滴碰撞后的流體狀態(tài)。6.3LBM在多孔介質(zhì)流動中的研究6.3.1原理LBM在多孔介質(zhì)流動中的應(yīng)用主要關(guān)注流體在復(fù)雜幾何結(jié)構(gòu)中的傳輸,如土壤、巖石或生物組織。LBM能夠處理多孔介質(zhì)的不規(guī)則幾何形狀,通過模擬流體粒子在孔隙中的傳輸和碰撞,準(zhǔn)確地模擬流體流動和壓力分布。6.3.2內(nèi)容多孔介質(zhì)流動的LBM模擬包括:多孔介質(zhì)幾何建模:創(chuàng)建多孔介質(zhì)的幾何模型,包括孔隙和固體骨架。初始化:設(shè)定流體的初始條件,包括速度和密度。流體動力學(xué)模擬:使用LBM更新流體的速度和密度,考慮到多孔介質(zhì)的復(fù)雜結(jié)構(gòu)。邊界條件處理:正確處理流體與多孔介質(zhì)邊界之間的相互作用,包括滲透和反彈。6.3.3示例以下是一個使用Python和LBM模擬流體在多孔介質(zhì)中流動的簡化示例。此示例使用了lbmpy庫,并假設(shè)多孔介質(zhì)的幾何模型已經(jīng)創(chuàng)建。importlbmpyaslb

importpystencilsasps

importnumpyasnp

#定義流體和多孔介質(zhì)的參數(shù)

fluid_density=1.0

viscosity=0.01

porosity=0.3

grid_size=(200,200)

#創(chuàng)建LBM網(wǎng)格

lbm_grid=lb.Grid(lb.D2Q9)

#初始化流場

field=lb.create_lb_field(lbm_grid,grid_size)

field[:,:]=fluid_density

#創(chuàng)建多孔介質(zhì)的孔隙模型

porous_mask=np.random.rand(*grid_size)<porosity

porous_mask=lb.create_mask(porous_mask,lbm_grid)

#設(shè)置孔隙內(nèi)的流體密度

field[porous_mask]=fluid_density

#設(shè)置邊界條件

lb.set_boundary_conditions(field,lbm_grid,{'top':lb.BounceBack,'bottom':lb.BounceBack,

'left':lb.BounceBack,'right':lb.BounceBack})

#進(jìn)行LBM迭代

foriinrange(1000):

lb.stream_and_collide(field,lbm_grid,viscosity)

lb.update_boundary_conditions(field,lbm_grid)

#可視化結(jié)果

importmatplotlib.pyplotasplt

plt.imshow(field[:,:],cmap='hot',interpolation='nearest')

plt.show()6.3.4描述此代碼示例首先定義了流體和多孔介質(zhì)的物理參數(shù),然后創(chuàng)建了LBM網(wǎng)格和流場。通過隨機(jī)生成孔隙模型,模擬了多孔介質(zhì)的不規(guī)則結(jié)構(gòu)。通過迭代LBM的流和碰撞步驟,模擬了流體在多孔介質(zhì)中的流動,考慮到孔隙的存在和流體的傳輸。最終,使用matplotlib庫可視化了流場密度分布,展示了流體在多孔介質(zhì)中的流動狀態(tài)。以上示例提供了LBM在氣泡動力學(xué)、液滴碰撞和多孔介質(zhì)流動中應(yīng)用的基本框架。通過調(diào)整參數(shù)和模型,可以進(jìn)一步研究這些現(xiàn)象的復(fù)雜性。7結(jié)果分析與后處理7.1LBM模擬結(jié)果的可視化在格子玻爾茲曼方法(LBM)模擬多相流的過程中,可視化是理解流體動力學(xué)行為的關(guān)鍵步驟。通過將模擬數(shù)據(jù)轉(zhuǎn)換為圖像或動畫,可以直觀地觀察流體的分布、速度場、壓力場等特性。以下是一個使用Python的matplotlib庫進(jìn)行LBM模擬結(jié)果可視化的示例:importnumpyasnp

importmatplotlib.pyplotasplt

#假設(shè)的LBM模擬結(jié)果數(shù)據(jù)

data=np.random.rand(100,100)#100x100的流體密度分布

#創(chuàng)建圖像

plt.imshow(data,cmap='hot',interpolation='nearest')

plt.colorbar()

plt.title('LBM模擬結(jié)果的密度分布')

plt.xlabel('X軸')

plt.ylabel('Y軸')

plt.show()7.1.1代碼解釋導(dǎo)入庫:首先,我們導(dǎo)入numpy用于數(shù)據(jù)處理,以及matplotlib.pyplot用于數(shù)據(jù)可視化。模擬數(shù)據(jù):這里我們使用numpy.random.rand生成一個100x100的隨機(jī)數(shù)組,模擬LBM的流體密度分布。創(chuàng)建圖像:使用plt.imshow函數(shù)顯示數(shù)據(jù),cmap='hot'設(shè)置顏色映射,interpolation='nearest'表示使用最近鄰插值方法,以保持?jǐn)?shù)據(jù)的原始分辨率。添加顏色條和標(biāo)題:plt.colorbar()添加顏色條,plt.title、plt.xlabel和plt.ylabel設(shè)置圖像的標(biāo)題和坐標(biāo)軸標(biāo)簽。顯示圖像:最后,plt.show()顯示圖像。7.2數(shù)據(jù)后處理技術(shù)LBM模擬產(chǎn)生的數(shù)據(jù)通常需要后處理來提取有意義的信息。這包括數(shù)據(jù)的清洗、轉(zhuǎn)換和分析。例如,從速度分布中計算平均速度或湍流強(qiáng)度。下面是一個示例,展示如何從LBM速度分布數(shù)據(jù)中計算平均速度:importnumpyasnp

#假設(shè)的LBM速度分布數(shù)據(jù)

velocity_data=np.random.rand(100,100,2)#100x100的流體速度分布,每個點(diǎn)有x和y兩個方向的速度

#計算平均速度

average_velocity=np.mean(velocity_data,axis=(0,1))

print(f'平均速度:{average_velocity}')7.2.1代碼解釋導(dǎo)入庫:導(dǎo)入numpy用于數(shù)據(jù)處理。模擬數(shù)據(jù):使用numpy.random.rand生成一個100x100x2的隨機(jī)數(shù)組,模擬LBM的速度分布數(shù)據(jù),其中第三個維度表示x和y方向的速度。計算平均速度:使用np.mean函數(shù)沿著前兩個維度(即x和y軸)計算平均速度。輸出結(jié)果:打印計算得到的平均速度。7.3結(jié)果的物理意義解釋理解LBM模擬結(jié)果的物理意義是分析的關(guān)鍵。例如,在多相流模擬中,密度分布圖可以揭示不同流體的分界面,速度分布圖則可以顯示流體的流動方向和速度大小。壓力分布圖則有助于理解流體內(nèi)部的壓力變化,這對于預(yù)測流體行為和設(shè)計流體動力學(xué)系統(tǒng)至關(guān)重要。在分析LBM結(jié)果時,重要的是要將數(shù)值結(jié)果與物理現(xiàn)象聯(lián)系起來。例如,觀察到的密度梯度可能指示相界面的位置,而速度場中的渦旋則可能表明存在湍流或旋渦。通過與實驗數(shù)據(jù)或理論預(yù)測的比較,可以進(jìn)一步驗證模擬結(jié)果的準(zhǔn)確性。7.3.1示例:解釋密度分布圖假設(shè)我們有以下的密度分布圖:importmatplotlib.pyplotasplt

importnumpyasnp

#假設(shè)的LBM密度分布數(shù)據(jù)

density_data=np.random.rand(100,100)

#創(chuàng)建圖像

plt.imshow(density_data,cmap='gray',interpolation='nearest')

plt.colorbar()

plt.title('LBM模擬結(jié)果的密度分布')

plt.xlabel('X軸')

plt.ylabel('Y軸')

plt.show()在該圖中,密度較高的區(qū)域(較亮的部分)可能代表了流體的某一相,而密度較低的區(qū)域(較暗的部分)則代表了另一相。這種分布可以幫助我們識別不同流體的分界面,以及流體混合的程度。7.3.2示例:解釋速度分布圖對于速度分布圖,我們可以使用以下代碼示例:importmatplotlib.pyplotasplt

importnumpyasnp

#假設(shè)的LBM速度分布數(shù)據(jù)

velocity_data=np.random.rand(100,100,2)

#創(chuàng)建速度矢量圖

X,Y=np.meshgrid(np.arange(velocit

溫馨提示

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

最新文檔

評論

0/150

提交評論