在數值線性代數中,穩定雙共軛梯度法(英語:Biconjugate gradient stabilized method,通常簡稱為BiCGSTAB)是一種由荷蘭數學家 H. A. van der Vorst 提出的用於數值求解非對稱線性方程組的迭代方法。它是雙共軛梯度法(BiCG)的一個變種,比雙共軛梯度法本身以及諸如共軛梯度平方法(CGS)等其他變種有更快速和更平滑的收斂性。它是一種 Krylov 子空間方法。
算法步驟
無預處理穩定雙共軛梯度法
要求解線性方程組 ,穩定雙共軛梯度法從初始解 開始按以下步驟迭代:
- 任意選擇向量 使得 ,例如,
- 對
- 若 足夠精確則退出
預處理穩定雙共軛梯度法
預處理通常被用來加速迭代方法的收斂。要使用預處理子 來求解線性方程組 ,預處理穩定雙共軛梯度法從初始解 開始按以下步驟迭代:
- 任意選擇向量 使得 ,例如,
- 對
- 若 足夠精確則退出
這個形式等價於將無預處理的穩定雙共軛梯度法應用於顯式預處理後的方程組
- ,
其中 ,,。換句話說,左預處理和右預處理都可以通過這個形式實施。
推導
雙共軛梯度法的多項式形式
在雙共軛梯度法中,搜索方向 和 以及殘量 和 通過以下遞推關係更新:
常數 和 取值為
其中 ,使得殘量和搜索方向分別滿足雙正交性和雙共軛性,也就是對於 ,
不難證明,
其中 和 是關於 的 次多項式。這些多項式滿足以下遞推關係:
從雙共軛梯度法導出穩定雙共軛梯度 法
雙共軛梯度法的殘量和搜索方向不是必須顯式跟蹤的。換句話說,雙共軛梯度法的迭代是可以隱式進行的。穩定雙共軛梯度法中希望得到
的遞推關係,其中 , 為適當選取的常數。以此代替 的目的是希望 可以使 有比 更快速和更平滑的收斂性。
根據 和 的遞推關係以及 的定義,
於是還需要一條關於 的遞推關係。這同樣可以從雙共軛梯度法的遞推關係中導出:
類似於 ,穩定雙共軛梯度法定義
寫成向量形式, 和 的遞推關係就是
為了導出 的遞推關係,定義
於是 的遞推關係就可以寫成
這對應於
確定穩定雙共軛梯度法的常數
現在只需確定雙共軛梯度法的常數 和 以及選擇一個合適的 。
在雙共軛梯度法中,, 其中
由於穩定雙共軛梯度法不顯式跟蹤 或 , 不能立即用這條公式計算出來。但是,它可以和純量
關聯起來。由於雙正交性, 正交於 ,其中 是關於 的任意 次多項式。因此在點積 和 中只需考慮 和 的最高次項。 和 的最高次項係數分別是 和 。因此
於是
關於 的簡單公式可以類似地導出。在雙共軛梯度法中,
類似於上面的情況,由於雙正交性和雙共軛性,在點積中只需考慮 和 的最高次項。 和 的最高次項係數恰巧是相同的。因此,它們可以在公式中被同時替換為 ,於是
最後,穩定雙共軛梯度法選擇 使得 的 2-範數作為 的函數被最小化。這在
時達到,因此 的最優值是
相關主題
參考文獻