納維-斯托克斯方程

納維-斯托克斯方程Navier-Stokes equations),是一組描述液體空氣流體的運動的偏微分方程。該方程以法國物理學家克勞德-路易·納維和愛爾蘭物理學家喬治·斯托克斯的名字命名。

納維爾-斯托克斯方程描述了牛頓流體在運動過程中需要滿足的動量質量守恆性質。在納維-斯托克斯方程的一些應用中,會將該方程與狀態方程一同列出,以說明流體壓強溫度密度三者之間的關係。[1]

納維-斯托克斯方程是將牛頓第二定律應用到流體動力學之後得到的結果。與歐拉方程不同,納維-斯托克斯方程考慮了流體的粘性。它假設流體在運動過程中,其所受的應力是正比於速度梯度擴散黏性力和壓力的總和。因此,納維-斯托克斯方程可以描述有黏性流體的運動;而歐拉方程僅能描述無粘性流的運動。在流體黏性為零時,納維-斯托克斯方程退化為歐拉方程。

納維-斯托克斯方程的應用十分廣泛。它可以用於模擬天氣洋流、管道中的水流、星系中恆星的運動、翼型周圍的氣流,也可以用於設計飛行器和車輛、研究血液循環、設計電站、分析污染效應等等。如果將納維爾-斯托克斯方程與馬克士威方程組聯立,還可以研究磁流體力學

納維-斯托克斯方程難以求解。實用上,也只有最簡單的情況才能用這種方法獲得已知解。這些情況通常涉及穩定態(流場不隨時間變化)的非紊流,其中流體的粘滯係數很大或者其速度很小(低雷諾數)。對於更複雜的情形,例如厄爾尼諾這樣的全球性氣象系統或機翼升力,現時僅能藉助計算機求出納維-斯托克斯方程的數值解。這個科學領域稱為計算流體力學

雖然紊流是日常經驗中就可以遇到的,但這類非線性問題在理論上極難求解,仍未能證明三維空間中是否總存在光滑解,甚至有界解。此問題稱為納維-斯托克斯存在性與光滑性克雷數學學院於2000年5月21日列入七大未解難題,懸賞一百萬美元,獎勵找到數學證明反例的任何人。[2][3]

性質

非線性

納維-斯托克斯方程的一般形式是非線性偏微分方程,所以在大多數實際情況下仍是如此。[4][5]在特定情況,如一維流和斯托克斯流(又稱蠕動流)下,方程可以簡化為線性方程組。非線性項的出現,令大部分問題變得很難,甚至無法求解。另一方面,方程組能描述湍流,而非線性正是湍流出現的重要因素。

方程式中的非線性項是對流加速(與點速度變化相關聯的加速度),因此,任何對流,無論湍流與否,都會涉及非線性。有對流但仍為層流(而非湍流)的例子如下:考慮黏性液體(如油),流經一個細小並逐漸收窄的噴嘴英語nozzle。此種流,不論能否確切解出,通常都能透徹研究、理解。[6]

湍流

湍流是時變的混沌行為,這種行為常見於許多流體流動中。人們普遍認為,湍流的成因,是整個流體的慣性:時變加速度與對流加速度疊加,以產生亂流告終。因此慣性影響很小的流體,往往是層流(雷諾數量化了流所受慣性的大小)。雖然不完全確定,但一般相信納維-斯托克斯方程能夠合理地描述湍流。[7]

納維-斯托克斯方程關於湍流的數值解是非常難得到的,而且由於湍流之中,有多個顯著不同的混合長度英語Turbulence modeling尺度,若要得到穩定解,所需要的分辨率要極度精細,於是計算或直接數值模擬英語Direct numerical simulation的時間長得不可行。若試圖用解層流的方法來解決湍流問題,通常會得到時間不穩定的解,而不能適當收斂。為了解決這個問題,計算流體力學中,實際模擬湍流的程序,多採用雷諾平均納維-斯托克斯方程(RANS)等時間平均方程,再輔以各湍流模型,如Spalart-Allmaras英語Spalart–Allmaras turbulence modelkω英語k–omega turbulence modelkε英語turbulence kinetic energySST英語Menter's Shear Stress Transport,以添加另外的方程。另一種數值解法是大渦模擬(LES)。這種方法比RANS方法,佔用更多計算時間記憶體空間,但效果較好,因為LES明確解出較大的湍流尺度。

適用性

連同其他方程(如質量守恆定律)和良好的邊界條件一併考慮時,納維-斯托克斯方程似乎是流體運動的精確模型;甚至湍流(平均而言)也符合實際觀察結果。

納維-斯托克斯方程假定所研究的流體連續(無限可分,而不是由粒子組成),且不具相對論流速。在非常小的尺度或極端條件下,由離散分子組成的真實流體,與由納維-斯托克斯方程描繪的連續流體,將產生不同的結果。例如,大梯度流的流體內層,有毛細現象[8]對於大克努森數的問題,用統計力學的波茲曼方程式可能更適合[9] ,甚至要用分子動力學或其他混合方法[10]

另一個限制是方程的複雜性。要刻劃一般常見的流體類,有行之有效的公式,但對於較罕見的類別,應用納維-斯托克斯方程時,往往會得到非常複雜的描述,甚至是未解難題。出於這個原因,這些方程通常用於描述牛頓流體。研究這種液體是「簡單」的,因為粘度模型最終被線性化;真正描述其他類型流體(如血液)的普遍模型,截至2012年還不存在。[11]

基本假設

在解釋納維-斯托克斯方程的細節之前,首先對流體的性質作幾個假設。第一個假設是流體是連續的。這強調其內部沒有空隙,例如,汽水中有氣泡,便不屬此例;同樣,包含霧狀粒子的氣體亦不屬此例。另一個必要的假設是,所有涉及到的場,即壓強速度密度溫度等,全部都可微

該方程從質量守恆動量守恆能量守恆等基本原理導出。推導過程中,經常考慮一個有限的任意體積,稱為控制體積,並對其應用這些原理。該有限體積記為 ,而其表面記為 。該控制體積可以在空間中固定,也可能隨着流體運動。這會導致一些特殊的結果,見下文。

隨質導數

運動流體的屬性變化,譬如大氣風速的變化,可以有兩種不同的方法來測量:風速儀可以固定在氣象站上,也可以隨氣象氣球飄動。第一種情況下,風速儀測量的速度,是所有運動的粒子經過一個固定點的速度;而第二種情況下,儀器測量的數值,是其隨着流體運動時,速度的變化。同樣的論證對於密度、溫度等物理量的測量也是成立的。因此,當作微分時必須區分兩種情況。第一種情況稱為空間導數或者歐拉導數。第二種情況稱為實質導數拉格朗日導數

隨質導數定義為算子

 

其中 是流體的速度。方程右邊的第一項是普通的歐拉導數(也就是在靜止參照系中的導數),而第二項表示由於流體的運動帶來的變化。這個效應稱為移流英語advection

L在一個控制體積 上守恆,可用以下積分式表示:

 

設Ω共動(隨流體移動),則它隨着時間而改變,所以不能將時間導數和積分簡單的交換,但有:

 

因為這個表達式對於所有 成立,它可以簡化為:

 

(第一個等號用到隨質導數的定義,以及對 用到導數的積法則)對於不是密度的量(因而它不必在空間中積分), 給出了正確的共動時間導數。

守恆定律

在上式中,依次取 為下列各守恆量:

並且狀態定律閉合[需要解釋],就能推導出NS方程。

連續性方程

質量的守恆寫作:

 

其中 是流體的密度。

不可壓縮流體的情況, 是常數,不取決於時間或位置,於是方程簡化為:

 

動量守恆

動量守恆寫作:

 

注意 是一個張量 代表張量積

可以進一步簡化,利用連續性方程,上式變成:

 

可以認出這就是通常牛頓第二定律 

方程組

一般形式

方程組的形式

納維-斯托克斯方程的一般形式是:

 

關於動量守恆。張量 代表施加在一個流體粒子上的表面力(應力張量)。除非流體是由象旋渦這樣的旋轉自由度組成, 是一個對稱張量。一般來講,我們有如下形式:

 

其中 是法向約束,而 是切向約束。

 在流體處於平衡態時為0。這等價於流體粒子上的法向力的積分為0。

我們再加上連續性方程:

 

對於處於平衡的液體, 的跡是3p

其中

p是壓強

最後,我們得到:

 

其中  的非對角線部分。

閉合問題

這些方程是不完整的。要對它們進行完備化,必須對 的形式作一些假設。例如在理想流體的情況 分量為0。用於完備方程組的方程是狀態方程

再如,壓強可以主要是密度溫度的函數。

要求解的變量是速度的各個分量,流體密度,靜壓力,和溫度。流場假定為可微連續,使得這些平衡得以用偏微分方程表達。這些方程可以轉化為渦度流函數這些次變量的威爾金森方程組。解依賴於流體的性質(例如粘滯度比熱、和熱導率),並且依賴於所研究的區域的邊界條件。

 的分量是流體的一個無窮小元上面的約束。它們代表垂直和剪切約束。 對稱的,除非存在非零的自旋密度

所謂非牛頓流體就是其中該張量沒有特殊性質使得方程的特殊解出現的流體

特殊形式

這些是問題的特定的常見簡化,有時解是已知的。

牛頓流體

在牛頓流體中,如下假設成立:

 

其中

 是液體的粘滯度
 
 

其中為簡化書寫,對腳標使用了愛因斯坦求和約定

不採用簡化書寫的完整形式非常繁瑣,分別為:

動量守恆:

 
 
 

質量守恆:

 

因為密度是一個未知數,我們需要另一個方程。

能量守恆:

 

其中:

 

假設一個理想氣體

 

上面是一共6個方程6個未知數的系統。(u,v,w,T,e以及  )。

賓漢(Bingham)流體

在賓漢流體中,我們有稍微不同的假設:

 

那些流體在開始流動之前能夠承受一定的剪切。牙膏是一個例子。

冪律流體

這是一種理想化的流體,其剪切應力 ,由下式給出

 

該形式對於模擬各種一般流體有用。

不可壓縮流體

其納維-斯托克斯方程(Navier-Stoke equation)分為動量守恆公式

 

質量守恆公式

 

其中,對不可壓縮牛頓流體來說,只有對流項(convective terms)為非線性形式。對流加速度(convective acceleration)來自於流體流動隨空間之變化所產生的速度改變,例如:當流體通過一個漸縮噴嘴(convergent nozzle)時,流體產生加速之情況。由於此項的存在,對於暫態運動中的流體來說,其流場速度變化不再單是時間的函數,亦與空間有關。

另外一個重要的觀察重點,在於黏滯力(viscosity)在流場中的以流體速度作拉普拉斯運算來表現。這暗示了在牛頓流體中,黏滯力為動量擴散(diffusion of momentum),與熱擴散方程式非常類似。

 ;
 散度
 克羅內克記號

 在整個流體上均勻,動量方程簡化為

 

(若 這個方程稱為歐拉方程;那裡的重點是可壓縮流衝擊波)。

如果現在再有 為常數,我們得到如下系統:

 
 
 

連續性方程(假設不可壓縮性):

 
N-S方程的簡化版本。採用《不可壓縮流》,Ronald Panton所著第二版

注意納維-斯托克斯方程僅可近似描述液體流,而且在非常小的尺度或極端條件下,由離散的分子和其他物質(例如懸浮粒子和溶解的氣體)的混合體組成的真實流體,會產生和納維-斯托克斯方程所描述的連續並且齊性的液體不同的結果。依賴於問題的納森數,統計力學可能是一個更合適的方法。但是,納維-斯托克斯方程對於很大範圍的實際問題是有效的,只要記住他們的缺陷是天生的就可以了。

程式模擬

參考MIT18086_NAVIERSTOKES

[12]

function mit18086_navierstokes
%MIT18086_NAVIERSTOKES
%    Solves the incompressible Navier-Stokes equations in a
%    rectangular domain with prescribed velocities along the
%    boundary. The solution method is finite differencing on
%    a staggered grid with implicit diffusion and a Chorin
%    projection method for the pressure.
%    Visualization is done by a colormap-isoline plot for
%    pressure and normalized quiver and streamline plot for
%    the velocity field.
%    The standard setup solves a lid driven cavity problem.

% 07/2007 by Benjamin Seibold
%            http://www-math.mit.edu/~seibold/
% Feel free to modify for teaching and learning.
%-----------------------------------------------------------------------
Re = 1e2;     % Reynolds number
dt = 1e-2;    % time step
tf = 4e-0;    % final time
lx = 1;       % width of box
ly = 1;       % height of box
nx = 90;      % number of x-gridpoints
ny = 90;      % number of y-gridpoints
nsteps = 10;  % number of steps with graphic output
%-----------------------------------------------------------------------
nt = ceil(tf/dt); dt = tf/nt;
x = linspace(0,lx,nx+1); hx = lx/nx;
y = linspace(0,ly,ny+1); hy = ly/ny;
[X,Y] = meshgrid(y,x);
%-----------------------------------------------------------------------
% initial conditions
U = zeros(nx-1,ny); V = zeros(nx,ny-1);
% boundary conditions
uN = x*0+1;    vN = avg(x)*0;
uS = x*0;      vS = avg(x)*0;
uW = avg(y)*0; vW = y*0;
uE = avg(y)*0; vE = y*0;
%-----------------------------------------------------------------------
Ubc = dt/Re*([2*uS(2:end-1)' zeros(nx-1,ny-2) 2*uN(2:end-1)']/hx^2+...
      [uW;zeros(nx-3,ny);uE]/hy^2);
Vbc = dt/Re*([vS' zeros(nx,ny-3) vN']/hx^2+...
      [2*vW(2:end-1);zeros(nx-2,ny-1);2*vE(2:end-1)]/hy^2);

fprintf('initialization')
Lp = kron(speye(ny),K1(nx,hx,1))+kron(K1(ny,hy,1),speye(nx));
Lp(1,1) = 3/2*Lp(1,1);
perp = symamd(Lp); Rp = chol(Lp(perp,perp)); Rpt = Rp';
Lu = speye((nx-1)*ny)+dt/Re*(kron(speye(ny),K1(nx-1,hx,2))+...
     kron(K1(ny,hy,3),speye(nx-1)));
peru = symamd(Lu); Ru = chol(Lu(peru,peru)); Rut = Ru';
Lv = speye(nx*(ny-1))+dt/Re*(kron(speye(ny-1),K1(nx,hx,3))+...
     kron(K1(ny-1,hy,2),speye(nx)));
perv = symamd(Lv); Rv = chol(Lv(perv,perv)); Rvt = Rv';
Lq = kron(speye(ny-1),K1(nx-1,hx,2))+kron(K1(ny-1,hy,2),speye(nx-1));
perq = symamd(Lq); Rq = chol(Lq(perq,perq)); Rqt = Rq';

fprintf(', time loop\n--20%%--40%%--60%%--80%%-100%%\n')
for k = 1:nt
   % treat nonlinear terms
   gamma = min(1.2*dt*max(max(max(abs(U)))/hx,max(max(abs(V)))/hy),1);
   Ue = [uW;U;uE]; Ue = [2*uS'-Ue(:,1) Ue 2*uN'-Ue(:,end)];
   Ve = [vS' V vN']; Ve = [2*vW-Ve(1,:);Ve;2*vE-Ve(end,:)];
   Ua = avg(Ue')'; Ud = diff(Ue')'/2;
   Va = avg(Ve);   Vd = diff(Ve)/2;
   UVx = diff(Ua.*Va-gamma*abs(Ua).*Vd)/hx;
   UVy = diff((Ua.*Va-gamma*Ud.*abs(Va))')'/hy;
   Ua = avg(Ue(:,2:end-1));   Ud = diff(Ue(:,2:end-1))/2;
   Va = avg(Ve(2:end-1,:)')'; Vd = diff(Ve(2:end-1,:)')'/2;
   U2x = diff(Ua.^2-gamma*abs(Ua).*Ud)/hx;
   V2y = diff((Va.^2-gamma*abs(Va).*Vd)')'/hy;
   U = U-dt*(UVy(2:end-1,:)+U2x);
   V = V-dt*(UVx(:,2:end-1)+V2y);
   
   % implicit viscosity
   rhs = reshape(U+Ubc,[],1);
   u(peru) = Ru\(Rut\rhs(peru));
   U = reshape(u,nx-1,ny);
   rhs = reshape(V+Vbc,[],1);
   v(perv) = Rv\(Rvt\rhs(perv));
   V = reshape(v,nx,ny-1);
   
   % pressure correction
   rhs = reshape(diff([uW;U;uE])/hx+diff([vS' V vN']')'/hy,[],1);
   p(perp) = -Rp\(Rpt\rhs(perp));
   P = reshape(p,nx,ny);
   U = U-diff(P)/hx;
   V = V-diff(P')'/hy;
   
   % visualization
   if floor(25*k/nt)>floor(25*(k-1)/nt), fprintf('.'), end
   if k==1|floor(nsteps*k/nt)>floor(nsteps*(k-1)/nt)
      % stream function
      rhs = reshape(diff(U')'/hy-diff(V)/hx,[],1);
      q(perq) = Rq\(Rqt\rhs(perq));
      Q = zeros(nx+1,ny+1);
      Q(2:end-1,2:end-1) = reshape(q,nx-1,ny-1);
      clf, contourf(avg(x),avg(y),P',20,'w-'), hold on
      contour(x,y,Q',20,'k-');
      Ue = [uS' avg([uW;U;uE]')' uN'];
      Ve = [vW;avg([vS' V vN']);vE];
      Len = sqrt(Ue.^2+Ve.^2+eps);
      quiver(x,y,(Ue./Len)',(Ve./Len)',.4,'k-')
      hold off, axis equal, axis([0 lx 0 ly])
      p = sort(p); caxis(p([8 end-7]))
      title(sprintf('Re = %0.1g   t = %0.2g',Re,k*dt))
      drawnow
   end
end
fprintf('\n')

%=======================================================================

function B = avg(A,k)
if nargin<2, k = 1; end
if size(A,1)==1, A = A'; end
if k<2, B = (A(2:end,:)+A(1:end-1,:))/2; else, B = avg(A,k-1); end
if size(A,2)==1, B = B'; end

function A = K1(n,h,a11)
% a11: Neumann=1, Dirichlet=2, Dirichlet mid=3;
A = spdiags([-1 a11 0;ones(n-2,1)*[-1 2 -1];0 a11 -1],-1:1,n,n)'/h^2;

模擬結果

執行MATLAB 即可觀察4秒的模擬結果

參看

參考文獻

  1. ^ McLean, Doug. Continuum Fluid Mechanics and the Navier-Stokes Equations. Understanding Aerodynamics: Arguing from the Real Physics. John Wiley & Sons. 2012: 13–78 (英語). The main relationships comprising the NS equations are the basic conservation laws for mass, momentum, and energy. To have a complete equation set we also need an equation of state relating temperature, pressure, and density... 
  2. ^ Millennium Prize Problems—Navier–Stokes Equation, claymath.org, Clay Mathematics Institute, March 27, 2017 [2017-04-02], (原始內容存檔於2015-12-22) (英語) 
  3. ^ Fefferman, Charles L. Existence and smoothness of the Navier–Stokes equation (PDF). claymath.org. Clay Mathematics Institute. [2017-04-02]. (原始內容 (PDF)存檔於2015-04-15) (英語). 
  4. ^ Fluid Mechanics(Schaum's Series), M. Potter, D.C. Wiggert, Schaum's Outlines, McGraw-Hill (USA), 2008, ISBN 978-0-07-148781-8
  5. ^ Vectors, Tensors, and the basic Equations of Fluid Mechanics, R. Aris, Dover Publications, 1989, ISBN (10) 0-486-66110-5
  6. ^ Parker, C. B. McGraw Hill Encyclopaedia of Physics 2nd. 1994. ISBN 0-07-051400-3 (英語). 
  7. ^ Encyclopaedia of Physics (2nd Edition), R.G. Lerner, G.L. Trigg, VHC publishers, 1991, ISBN (Verlagsgesellschaft) 3-527-26954-1, ISBN(VHC Inc.)0-89573-752-3
  8. ^ Gorban, A.N.; Karlin, I. V. Beyond Navier–Stokes equations: capillarity of ideal gas. Contemporary Physics (Review article). 2016, 58 (1): 70–90. Bibcode:2017ConPh..58...70G. S2CID 55317543. arXiv:1702.00831 . doi:10.1080/00107514.2016.1256123. 
  9. ^ Cercignani, C. The Boltzmann equation and fluid dynamics. Friedlander, S.; Serre, D. (編). Handbook of mathematical fluid dynamics 1. Amsterdam: North-Holland. 2002: 1–70. ISBN 978-0444503305 (英語). 
  10. ^ Nie, X.B.; Chen, S.Y.; Robbins, M.O. A continuum and molecular dynamics hybrid method for micro-and nano-fluid flow. Journal of Fluid Mechanics (Research article). 2004, 500: 55–64 [2021-10-12]. Bibcode:2004JFM...500...55N. doi:10.1017/S0022112003007225. (原始內容存檔於2018-08-09) (英語). 
  11. ^ Öttinger, H.C. Stochastic processes in polymeric fluids. Berlin, Heidelberg: Springer Science & Business Media. 2012. ISBN 9783540583530. doi:10.1007/978-3-642-58290-5 (英語). 
  12. ^ Chen, Weijia; Chen, JC. Combined compact difference method for solving the incompressible Navier-Stokes equations. International Journal for Numerical Methods in Fluids. 2011-06-06, 68 (10). ISSN 0271-2091. doi:10.1002/fld.2602. 
  • Inge L. Rhyming Dynamique des fluides, 1991 PPUR.
  • Polyanin A.D., Kutepov A.M., Vyazmin A.V., Kazenin D.A., Hydrodynamics, Mass and Heat Transfer in Chemical Engineering, Taylor & Francis, London, 2002. ISBN 0-415-27237-8.

外部連結