Warm-start
Most Krylov methods accept a user-provided initial guess instead of starting from zero.
workspace = CgWorkspace(A, b)
cg!(workspace, A, b, itmax=100)
if !issolved(workspace)
# Use the approximate solution `workspace.x` as starting point
cg!(workspace, A, b, workspace.x, itmax=100)
end
If the user has an initial guess x0
, it can be provided directly.
cg(A, b, x0)
If a Krylov method doesn't have the option to warm start, it can still be done explicitly. We provide an example with cg_lanczos!
.
workspace = CgLanczosWorkspace(A, b)
cg_lanczos!(workspace, A, b)
x₀ = workspace.x # Ax₀ ≈ b
r = b - A * x₀ # r = b - Ax₀
cg_lanczos!(workspace, A, r)
Δx = workspace.x # AΔx = r
x = x₀ + Δx # Ax = b
Explicit restarts cannot be avoided in certain block methods, such as TriMR, due to the preconditioners.
# [E A] [x] = [b]
# [Aᴴ F] [y] [c]
M = inv(E)
N = inv(F)
x₀, y₀, stats = trimr(A, b, c, M=M, N=N)
# E and F are not available inside TriMR
b₀ = b - Ex₀ - Ay
c₀ = c - Aᴴx₀ - Fy
Δx, Δy, stats = trimr(A, b₀, c₀, M=M, N=N)
x = x₀ + Δx
y = y₀ + Δy