using Krylov
using LinearAlgebra, Printf
m = 5
n = 8
λ = 1.0e-3
A = rand(m, n)
b = A * ones(n)
xy_exact = [A λ*I] \ b # In Julia, this is the min-norm solution!
(x, y, stats) = craig(A, b, λ=λ, atol=0.0, rtol=1.0e-20, verbose=1)
show(stats)
# Check that we have a minimum-norm solution.
# When λ > 0 we solve min ‖(x,s)‖ s.t. Ax + λs = b, and we get s = λy.
@printf("Primal feasibility: %7.1e\n", norm(b - A * x - λ^2 * y) / norm(b))
@printf("Dual feasibility: %7.1e\n", norm(x - A' * y) / norm(x))
@printf("Error in x: %7.1e\n", norm(x - xy_exact[1:n]) / norm(xy_exact[1:n]))
if λ > 0.0
@printf("Error in y: %7.1e\n", norm(λ * y - xy_exact[n+1:n+m]) / norm(xy_exact[n+1:n+m]))
end
CRAIG: system of 5 equations in 8 variables
k ‖r‖ ‖x‖ ‖A‖ κ(A) α β timer
0 8.96e+00 0.00e+00 0.00e+00 0.00e+00 ✗ ✗ ✗ ✗ ✗ ✗ ✗ ✗ 0.00s
1 3.92e-01 2.77e+00 3.24e+00 3.24e+00 3.2e+00 1.4e-01 0.00s
2 1.35e-01 2.81e+00 3.35e+00 4.74e+00 8.2e-01 2.8e-01 0.00s
3 5.35e-02 2.82e+00 3.40e+00 5.95e+00 5.2e-01 2.1e-01 0.00s
4 4.96e-02 2.82e+00 3.50e+00 7.12e+00 6.0e-01 5.6e-01 0.00s
5 1.63e-10 2.82e+00 3.57e+00 8.42e+00 7.1e-01 2.3e-09 0.00s
SimpleStats
niter: 5
solved: true
inconsistent: false
indefinite: false
npcCount: 0
residuals: []
Aresiduals: []
κ₂(A): []
allocation timer: 3.42μs
timer: 76.83μs
status: solution good enough for the tolerances given
Primal feasibility: 1.8e-11
Dual feasibility: 9.6e-17
Error in x: 1.8e-11
Error in y: 1.1e-11