克蘭克-尼科爾森方法(英語:Crank–Nicolson method)是一種數值分析的有限差分法,可用於數值求解熱方程以及類似形式的偏微分方程[1]。它在時間方向上是隱式的二階方法,可以寫成隱式的龍格-庫塔法,數值穩定。該方法誕生於20世紀,由約翰·克蘭克與菲利斯·尼科爾森發展[2]。
可以證明克蘭克-尼科爾森方法對於擴散方程(以及許多其他方程)是無條件穩定[3]。但是,如果時間步長Δt乘以熱擴散率,再除以空間步長平方Δx2的值過大(根據馮諾依曼穩定性分析,以大於1/2為準),近似解中將存在虛假的振盪或衰減。基於這個原因,當要求大時間步或高空間解析度的時候,往往會採用數值精確較差的後向歐拉法進行計算,這樣即可以保證穩定,又避免了解的偽振盪。
克蘭克-尼科爾森方法在空間域上的使用中心差分;而時間域上應用梯形公式,保證了時間域上的二階收斂。例如,一維偏微分方程

令
,則通過克蘭克-尼科爾森方法導出的差分方程是第n步上採用前向歐拉方法與第n+1步上採用後向歐拉方法的平均值(注意,克蘭克-尼科爾森方法本身不是這兩種方法簡單地取平均,方程對解隱式依賴)。
(前向歐拉方法)
(後向歐拉方法)
(克蘭克-尼科爾森方法)
對於F,通過中心差分方法使其在空間上是離散的。
注意,這是一個隱式方法,需要求解代數方程組以得到時間域上的下一個u值。如果偏微分方程是非線性的,中心差分後得到的方程依舊是非線性方程系統,因此在時間步上推進會涉及求解非線性代數方程組。許多問題中,特別是線性擴散,代數方程中的矩陣是三對角的,通過三對角矩陣算法可以高效求解,這樣,算法的時間複雜度由直接求解全矩陣的
轉化為
。

通過克蘭克-尼科爾森方法將得到離散方程

引入變量
:

這是一個三對角問題,應用三對角矩陣算法(追趕法)即可得到
,而不需要對矩陣直接求逆。

離散化後則會得到非線性方程系統。但是某些情況下,通過使用a的舊值,即用
替代
,可將問題線性化。其他時候,也可能在保證穩定性的基礎上使用顯式方法估計
這種模型可以用於描述水流中含穩定污染流,但只有一維信息的情況。它可以簡化為一維問題並得到有價值的信息。
可對水中污染溶質富集的問題進行建模,這種問題由三部分組成:已知的擴散方程(
為常量),平流分量(即由速度場導致的系統在空間上的變化,表示為常量Ux),以及與縱向通道k旁流的相互作用。

其中C表示污染物的富集水平,下標N和M分別對應上一通道和下一通道。
克蘭克-尼科爾森方法(i對應位置,j對應時間)將以上偏微分方程中的每個部分變換為






現在引入以下常量用於簡化計算:



把 <1>, <2>, <3>, <4>, <5>, <6>, α, β 和 λ 代入 <0>. 把新時間項(j+1)代入到左邊,當前時間項(j)代入到右邊,將得到

第一個通道只能與下一個通道(M)有關係,因此表達式可以簡化為:

同樣地, 最後一個通道只與前一個通道(N)有關聯,因此表達式可以簡化為

為求解此線性方程組,需要知道邊界條件在通道始端就已經給定了。
: 當前時間步某通道的初始條件
: 下一時間步某通道的初始條件
: 前一通道到當前時間步下某通道的初始條件
: 下一通道到當前時間步下某通道的初始條件
對於通道的末端最後一個節點,最方便的條件是是絕熱近似,則

當且只當

時,這一條件才被滿足。
以3個通道,5個節點為例,可以將線性系統問題表示為
![{\displaystyle {\begin{bmatrix}AA\end{bmatrix}}{\begin{bmatrix}C^{j+1}\end{bmatrix}}=[BB][C^{j}]+[d]}](https://wikimedia.org/api/rest_v1/media/math/render/svg/8e2c0004cff53a3084cd60a0ff6963149780390b)
其中,

需要清楚的是,AA和BB是由四個不同子矩陣組成的矩陣,


其中上述矩陣的的矩陣元對應於下一個矩陣和額外的4x4零矩陣。請注意,矩陣AA和BB的大小為12x12



&

這裡的d矢量用於保證邊界條件成立。在此示例中為12x1的矢量。

為了找到任意時間下污染物的聚集情況,需要對以下方程進行迭代計算:
![{\displaystyle {\begin{bmatrix}C^{j+1}\end{bmatrix}}={\begin{bmatrix}AA^{-1}\end{bmatrix}}([BB][C^{j}]+[d])}](https://wikimedia.org/api/rest_v1/media/math/render/svg/82b9594d4023d1133ab12023a4b8a801803b0c86)
將擴散問題延伸到二維的笛卡爾網格,推導方程類似,但結果會是{{link-en|帶形矩陣|Banded matrix||的方程式,不是三角矩陣,二維的熱方程

假設網格滿足
的特性,即可通過克蘭克-尼科爾森方法將得到離散方程
![{\displaystyle {\begin{aligned}u_{i,j}^{n+1}&=u_{i,j}^{n}+{\frac {1}{2}}{\frac {a\Delta t}{(\Delta x)^{2}}}{\big [}(u_{i+1,j}^{n+1}+u_{i-1,j}^{n+1}+u_{i,j+1}^{n+1}+u_{i,j-1}^{n+1}-4u_{i,j}^{n+1})\\&\qquad {}+(u_{i+1,j}^{n}+u_{i-1,j}^{n}+u_{i,j+1}^{n}+u_{i,j-1}^{n}-4u_{i,j}^{n}){\big ]}\end{aligned}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/5d074ece8b5df3b7f5e563a01d0fcf58768cd407)
此方程可以再重組,配合柯朗數再進行簡化

在克蘭克-尼科爾森方法下,不需要為了穩定性而限制柯朗數的上限,不過為了數值穩定度,柯朗數仍不能太高,可以將方程式重寫如下:

許多的現象都可以用熱方程(金融數學上稱為擴散方程)來建模,因此克蘭克-尼科爾森方法也可以用在這些領域中[4]。尤其金融衍生工具定價用的布萊克-休斯模型可以轉換為熱方程,因此期權定價的數值解可以用克蘭克-尼科爾森方法求得。
因為期權定價若超過基本假設(例如改變股息)時,無法求得解析解,需要用上述方式求得。不過若是非平滑的最後條件(大部份的金融商品都是如此),克蘭克-尼科爾森方法會有數值的震盪,無法用濾波方式平緩。在期權定價上會反映在履約價Γ的變動。因此,一開始幾個步驟需要用其他比較不會震盪的方法(如全隱式有限差分法)。